OLD | NEW |
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 = recorder.beginRecording(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 } |
OLD | NEW |