OLD | NEW |
1 library CanvasTest; | 1 library CanvasTest; |
2 import '../../pkg/unittest/lib/unittest.dart'; | 2 import '../../pkg/unittest/lib/unittest.dart'; |
3 import '../../pkg/unittest/lib/html_config.dart'; | 3 import '../../pkg/unittest/lib/html_config.dart'; |
4 import 'dart:html'; | 4 import 'dart:html'; |
5 | 5 |
6 main() { | 6 main() { |
7 CanvasElement canvas; | 7 CanvasElement canvas; |
8 CanvasRenderingContext2D context; | 8 CanvasRenderingContext2D context; |
9 int width = 100; | 9 int width = 100; |
10 int height = 100; | 10 int height = 100; |
11 | 11 |
12 canvas = new CanvasElement(width:width, height:height); | 12 canvas = new CanvasElement(width:width, height:height); |
13 document.body.nodes.add(canvas); | 13 document.body.nodes.add(canvas); |
14 | 14 |
15 context = canvas.context2d; | 15 context = canvas.context2D; |
16 | 16 |
17 useHtmlConfiguration(); | 17 useHtmlConfiguration(); |
18 test('CreateImageData', () { | 18 test('CreateImageData', () { |
19 ImageData image = context.createImageData(canvas.width, | 19 ImageData image = context.createImageData(canvas.width, |
20 canvas.height); | 20 canvas.height); |
21 List<int> data = image.data; | 21 List<int> data = image.data; |
22 | 22 |
23 expect(data, hasLength(40000)); | 23 expect(data, hasLength(40000)); |
24 checkPixel(data, 0, [0, 0, 0, 0]); | 24 checkPixel(data, 0, [0, 0, 0, 0]); |
25 checkPixel(data, width * height - 1, [0, 0, 0, 0]); | 25 checkPixel(data, width * height - 1, [0, 0, 0, 0]); |
26 | 26 |
27 data[100] = 200; | 27 data[100] = 200; |
28 expect(data[100], equals(200)); | 28 expect(data[100], equals(200)); |
29 }); | 29 }); |
30 | 30 |
31 // TODO(antonm): enable again. | 31 // TODO(antonm): enable again. |
32 if (false) | 32 if (false) |
33 test('toDataUrl', () { | 33 test('toDataUrl', () { |
34 var canvas = new CanvasElement(width: 100, height: 100); | 34 var canvas = new CanvasElement(width: 100, height: 100); |
35 var context = canvas.context2d; | 35 var context = canvas.context2D; |
36 context.fillStyle = 'red'; | 36 context.fillStyle = 'red'; |
37 context.fill(); | 37 context.fill(); |
38 | 38 |
39 var url = canvas.toDataUrl('image/png'); | 39 var url = canvas.toDataUrl('image/png'); |
40 | 40 |
41 var img = new ImageElement(); | 41 var img = new ImageElement(); |
42 img.onLoad.listen(expectAsync1((_) { | 42 img.onLoad.listen(expectAsync1((_) { |
43 expect(img.complete, true); | 43 expect(img.complete, true); |
44 })); | 44 })); |
45 img.onError.listen((_) { | 45 img.onError.listen((_) { |
46 guardAsync(() { | 46 guardAsync(() { |
47 expect(true, isFalse, reason: 'URL failed to load.'); | 47 expect(true, isFalse, reason: 'URL failed to load.'); |
48 }); | 48 }); |
49 }); | 49 }); |
50 img.src = url; | 50 img.src = url; |
51 }); | 51 }); |
52 } | 52 } |
53 | 53 |
54 void checkPixel(List<int> data, int offset, List<int> rgba) | 54 void checkPixel(List<int> data, int offset, List<int> rgba) |
55 { | 55 { |
56 offset *= 4; | 56 offset *= 4; |
57 for (var i = 0; i < 4; ++i) { | 57 for (var i = 0; i < 4; ++i) { |
58 expect(data[offset + i], equals(rgba[i])); | 58 expect(data[offset + i], equals(rgba[i])); |
59 } | 59 } |
60 } | 60 } |
OLD | NEW |