Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(29)

Side by Side Diff: sky/examples/raw/spinning_image.dart

Issue 1190123003: Decouple Canvas from DisplayList and map Picture and PictureRecorder more directly to their Skia co… (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: j/k -- this one should actually be fully merged and testable Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 import 'dart:math' as math; 5 import 'dart:math' as math;
6 import 'dart:sky'; 6 import 'dart:sky';
7
7 import 'package:sky/mojo/net/image_cache.dart' as image_cache; 8 import 'package:sky/mojo/net/image_cache.dart' as image_cache;
9 import 'package:sky/rendering/object.dart';
abarth-chromium 2015/06/23 02:28:45 ditto
iansf 2015/06/23 22:46:09 Done.
8 10
9 double timeBase = null; 11 double timeBase = null;
10 12
11 Image image = null; 13 Image image = null;
12 String url1 = "https://www.dartlang.org/logos/dart-logo.png"; 14 String url1 = "https://www.dartlang.org/logos/dart-logo.png";
13 String url2 = "http://i2.kym-cdn.com/photos/images/facebook/000/581/296/c09.jpg" ; 15 String url2 = "http://i2.kym-cdn.com/photos/images/facebook/000/581/296/c09.jpg" ;
14 16
15 void beginFrame(double timeStamp) { 17 void beginFrame(double timeStamp) {
16 if (timeBase == null) timeBase = timeStamp; 18 if (timeBase == null) timeBase = timeStamp;
17 double delta = timeStamp - timeBase; 19 double delta = timeStamp - timeBase;
18 PictureRecorder canvas = new PictureRecorder(view.width, view.height); 20 PictureRecorder recorder = new PictureRecorder();
21 RenderCanvas canvas = new RenderCanvas(recorder, view.width, view.height);
19 canvas.translate(view.width / 2.0, view.height / 2.0); 22 canvas.translate(view.width / 2.0, view.height / 2.0);
20 canvas.rotate(math.PI * delta / 1800); 23 canvas.rotate(math.PI * delta / 1800);
21 canvas.scale(0.2, 0.2); 24 canvas.scale(0.2, 0.2);
22 Paint paint = new Paint()..color = const Color.fromARGB(255, 0, 255, 0); 25 Paint paint = new Paint()..color = const Color.fromARGB(255, 0, 255, 0);
23 if (image != null) 26 if (image != null)
24 canvas.drawImage(image, -image.width / 2.0, -image.height / 2.0, paint); 27 canvas.drawImage(image, -image.width / 2.0, -image.height / 2.0, paint);
25 view.picture = canvas.endRecording(); 28 view.picture = recorder.endRecording();
26 view.scheduleFrame(); 29 view.scheduleFrame();
27 } 30 }
28 31
29 void handleImageLoad(result) { 32 void handleImageLoad(result) {
30 if (result != image) { 33 if (result != image) {
31 print("${result.width}x${result.width} image loaded!"); 34 print("${result.width}x${result.width} image loaded!");
32 image = result; 35 image = result;
33 view.scheduleFrame(); 36 view.scheduleFrame();
34 } else { 37 } else {
35 print("Existing image was loaded again"); 38 print("Existing image was loaded again");
(...skipping 12 matching lines...) Expand all
48 51
49 return false; 52 return false;
50 } 53 }
51 54
52 void main() { 55 void main() {
53 image_cache.load(url1, handleImageLoad); 56 image_cache.load(url1, handleImageLoad);
54 image_cache.load(url1, handleImageLoad); 57 image_cache.load(url1, handleImageLoad);
55 view.setEventCallback(handleEvent); 58 view.setEventCallback(handleEvent);
56 view.setBeginFrameCallback(beginFrame); 59 view.setBeginFrameCallback(beginFrame);
57 } 60 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698