| 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 |