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

Side by Side Diff: sky/examples/raw/spinning_arabic.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: Rebased version of previous patch 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
8 double timeBase = null; 8 double timeBase = null;
9 LayoutRoot layoutRoot = new LayoutRoot(); 9 LayoutRoot layoutRoot = new LayoutRoot();
10 10
11 void beginFrame(double timeStamp) { 11 void beginFrame(double timeStamp) {
12 if (timeBase == null) 12 if (timeBase == null)
13 timeBase = timeStamp; 13 timeBase = timeStamp;
14 double delta = timeStamp - timeBase; 14 double delta = timeStamp - timeBase;
15 PictureRecorder canvas = new PictureRecorder(view.width, view.height); 15 PictureRecorder recorder = new PictureRecorder();
16 Canvas canvas = new Canvas(recorder, view.width, view.height);
16 canvas.translate(view.width / 2.0, view.height / 2.0); 17 canvas.translate(view.width / 2.0, view.height / 2.0);
17 canvas.rotate(math.PI * delta / 1800); 18 canvas.rotate(math.PI * delta / 1800);
18 canvas.drawRect(new Rect.fromLTRB(-100.0, -100.0, 100.0, 100.0), 19 canvas.drawRect(new Rect.fromLTRB(-100.0, -100.0, 100.0, 100.0),
19 new Paint()..color = const Color.fromARGB(255, 0, 255, 0)); 20 new Paint()..color = const Color.fromARGB(255, 0, 255, 0));
20 21
21 double sin = math.sin(delta / 200); 22 double sin = math.sin(delta / 200);
22 layoutRoot.maxWidth = 150.0 + (50 * sin); 23 layoutRoot.maxWidth = 150.0 + (50 * sin);
23 layoutRoot.layout(); 24 layoutRoot.layout();
24 25
25 canvas.translate(layoutRoot.maxWidth / -2.0, (layoutRoot.maxWidth / 2.0) - 125 ); 26 canvas.translate(layoutRoot.maxWidth / -2.0, (layoutRoot.maxWidth / 2.0) - 125 );
26 layoutRoot.paint(canvas); 27 layoutRoot.paint(canvas);
27 28
28 view.picture = canvas.endRecording(); 29 view.picture = recorder.endRecording();
29 view.scheduleFrame(); 30 view.scheduleFrame();
30 } 31 }
31 32
32 void main() { 33 void main() {
33 var document = new Document(); 34 var document = new Document();
34 var arabic = document.createText("هذا هو قليلا طويلة من النص الذي يجب التفاف . "); 35 var arabic = document.createText("هذا هو قليلا طويلة من النص الذي يجب التفاف . ");
35 var more = document.createText(" و أكثر قليلا لجعله أطول. "); 36 var more = document.createText(" و أكثر قليلا لجعله أطول. ");
36 var block = document.createElement('p'); 37 var block = document.createElement('p');
37 block.style['display'] = 'paragraph'; 38 block.style['display'] = 'paragraph';
38 block.style['direction'] = 'rtl'; 39 block.style['direction'] = 'rtl';
39 block.style['unicode-bidi'] = 'plaintext'; 40 block.style['unicode-bidi'] = 'plaintext';
40 block.appendChild(arabic); 41 block.appendChild(arabic);
41 block.appendChild(more); 42 block.appendChild(more);
42 43
43 layoutRoot.rootElement = block; 44 layoutRoot.rootElement = block;
44 45
45 view.setBeginFrameCallback(beginFrame); 46 view.setBeginFrameCallback(beginFrame);
46 view.scheduleFrame(); 47 view.scheduleFrame();
47 } 48 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698