Memo : Flutter x Dart [2015-2016]
  • Introduction
  • hello
    • helloworld
    • build flutter
    • build as standalone android app(old)
      • draw text
      • draw image
      • set icon
    • build as standalone apk(now)
    • build as ios app
    • build as linux app
    • build as mac app
    • build mojo
    • build as chromeapp
  • rendering
    • draw_rect
    • anime_rect
    • anime_rect(use animation.dart)
    • draw_image
    • rotate_image
    • draw_image_from_assets
    • sound_test(rendering & service)
    • touch_test
    • multitouch_test
    • [@]demo::mini game(spacewar!)
    • draw_text
    • draw_path
    • draw_vertexs
    • draw_vertexs_with_image
    • [@]demo:3d anime
    • input text from ime(RenderObject)
  • widget
    • text
    • network image
    • assets image
    • raw image
    • container
    • row
    • col
    • flexible
    • navigator
    • stateful component
    • scaffold
    • scaffold x drawer
    • scrollable viewport
    • scrollable list
    • input text from ime(EditableText)
  • dart:io
    • HttpClient Post & Get
    • NetworkInterface
    • TCP Socket
    • UDP Socket
    • File Path(dart:io & service)
    • File Create & Permission
  • dart:ui
    • draw rect
    • pointer event
  • mojo for flutter
    • get and post request
    • sensor test
    • [@]demo:gravity sensor
  • 2d physics for scratch
    • collision without rotation
    • [@]democollision without friction
    • [b]
  • 2d physics for newton
  • mojo for native
    • build mojo
  • 48 hour trial
    • create iron heart
    • tiny tetris
Powered by GitBook
On this page

Was this helpful?

  1. rendering

rotate_image

Previousdraw_imageNextdraw_image_from_assets

Last updated 5 years ago

Was this helpful?

// following code is checked in 2015/11/07
//
// need flutter.yaml from 2016/01/13
//
import 'package:flutter/widgets.dart';
import 'package:flutter/rendering.dart';
import 'dart:ui' as sky;
import 'dart:async';
import 'package:flutter/services.dart';

main() async {
  runApp(new DrawImageWidget());
}

class ImageLoader {
  static Future<sky.Image> load(String url) async {
    AssetBundle bundle = getAssetBundle();
    ImageResource resource = bundle.loadImage(url);
    return resource.first;
  }

  static AssetBundle getAssetBundle() {
    if (rootBundle != null) {
      return rootBundle;
    } else {
      return new NetworkAssetBundle(new Uri.directory(Uri.base.origin));
    }
  }
}

class DrawImageWidget extends OneChildRenderObjectWidget {
  double angle = 0.0;
  RenderObject createRenderObject() {
    return new DrawImageObject();
  }
}

class DrawImageObject extends RenderBox {
  double x = 50.0;
  double y = 50.0;
  double sx = 1.0;
  double sy = 1.0;
  double radians = 0.0;
  sky.Image image = null;

  @override
  void performLayout() {
    size = constraints.biggest;
  }

  @override
  bool hitTest(HitTestResult result, {Point position}) {
    result.add(new BoxHitTestEntry(this, position));
    return true;
  }

  void loadImage() {
    if (image == null) {

      ImageLoader.load("assets/a.png").then((sky.Image img) {
        image = img;
        // "assets/icon.jpeg" is error 2015/12/13 's flutter
        this.markNeedsPaint();
      });
    }
  }

  void paint(PaintingContext context, Offset offset) {
    loadImage();
    Paint paint = new Paint()
      ..color = new Color.fromARGB(0xff, 0xff, 0xff, 0xff);
    if (image == null) {
      Rect rect = new Rect.fromLTWH(x, y, 50.0, 50.0);
      context.canvas.drawRect(rect, paint);
    } else {
      context.canvas.setMatrix(new Matrix4.identity().storage);
      context.canvas.translate(10.0, 10.0);
      for (int i = 0; i < 3; i++) {
        context.canvas.translate(x + 5, y + 5);
        context.canvas.rotate(0.3);
        context.canvas.scale(0.5, 0.5);
        context.canvas.drawImage(image, new Point(0.0, 0.0), paint);
      }
      context.canvas.setMatrix(new Matrix4.identity().storage);
      context.canvas.translate(10.0, 400.0);
      for (int i = 0; i < 3; i++) {
        context.canvas.translate(x - 5, y - 5);
        context.canvas.rotate(-0.3);
        context.canvas.scale(0.5, 0.5);
        context.canvas.drawImage(image, new Point(0.0, 0.0), paint);
      }
    }
  }
}
# flutter.yaml
assets:
  - assets/icon.jpeg
  - assets/a.png
https://github.com/kyorohiro/hello_skyengine/tree/master/rotate_image