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

Side by Side Diff: tools/dom/templates/html/impl/impl_CanvasRenderingContext2D.darttemplate

Issue 12774014: Update drawImage to create more fast paths. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 9 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 | Annotate | Revision Log
« no previous file with comments | « tools/dom/src/CanvasImageSource.dart ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 part of $LIBRARYNAME; 5 part of $LIBRARYNAME;
6 6
7 $(ANNOTATIONS)class $CLASSNAME$EXTENDS$IMPLEMENTS$NATIVESPEC { 7 $(ANNOTATIONS)class $CLASSNAME$EXTENDS$IMPLEMENTS$NATIVESPEC {
8 $!MEMBERS 8 $!MEMBERS
9 9
10 /** 10 /**
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
43 this.strokeStyle = 'hsla($h, $s%, $l%, $a)'; 43 this.strokeStyle = 'hsla($h, $s%, $l%, $a)';
44 } 44 }
45 45
46 @DomName('CanvasRenderingContext2D.arc') 46 @DomName('CanvasRenderingContext2D.arc')
47 void arc(num x, num y, num radius, num startAngle, num endAngle, 47 void arc(num x, num y, num radius, num startAngle, num endAngle,
48 [bool anticlockwise = false]) { 48 [bool anticlockwise = false]) {
49 $dom_arc(x, y, radius, startAngle, endAngle, anticlockwise); 49 $dom_arc(x, y, radius, startAngle, endAngle, anticlockwise);
50 } 50 }
51 51
52 /** 52 /**
53 * Draws an image from a CanvasImageSource to an area of this canvas.
54 *
55 * The image will be drawn to an area of this canvas defined by
56 * [destRect]. [sourceRect] defines the region of the source image that is
57 * drawn.
58 * If [sourceRect] is not provided, then
59 * the entire rectangular image from [source] will be drawn to this context.
60 *
61 * If the image is larger than canvas
62 * will allow, the image will be clipped to fit the available space.
63 *
64 * CanvasElement canvas = new CanvasElement(width: 600, height: 600);
65 * CanvasRenderingContext2D ctx = canvas.context2d;
66 * ImageElement img = document.query('img');
67 * img.width = 100;
68 * img.height = 100;
69 *
70 * // Scale the image to 20x20.
71 * ctx.drawImageToRect(img, new Rect(50, 50, 20, 20));
72 *
73 * VideoElement video = document.query('video');
74 * video.width = 100;
75 * video.height = 100;
76 * // Take the middle 20x20 pixels from the video and stretch them.
77 * ctx.drawImageToRect(video, new Rect(50, 50, 100, 100),
78 * sourceRect: new Rect(40, 40, 20, 20));
79 *
80 * // Draw the top 100x20 pixels from the otherCanvas.
81 * CanvasElement otherCanvas = document.query('canvas');
82 * ctx.drawImageToRect(otherCanvas, new Rect(0, 0, 100, 20),
83 * sourceRect: new Rect(0, 0, 100, 20));
84 *
85 * See also:
86 *
87 * * [CanvasImageSource] for more information on what data is retrieved
88 * from [source].
89 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage)
90 * from the WHATWG.
91 */
92 @DomName('CanvasRenderingContext2D.drawImage')
93 void drawImageToRect(CanvasImageSource source, Rect destRect,
94 {Rect sourceRect}) {
95 $if DART2JS
96 if (sourceRect == null) {
97 drawImageScaled(source,
98 destRect.left,
99 destRect.top,
100 destRect.width,
101 destRect.height);
102 } else {
103 drawImageScaledFromSource(source,
104 sourceRect.left,
105 sourceRect.top,
106 sourceRect.width,
107 sourceRect.height,
108 destRect.left,
109 destRect.top,
110 destRect.width,
111 destRect.height);
112 }
113 $else
114 if (sourceRect == null) {
115 $dom_drawImage(source,
116 destRect.left,
117 destRect.top,
118 destRect.width,
119 destRect.height);
120 } else {
121 $dom_drawImage(source,
122 sourceRect.left,
123 sourceRect.top,
124 sourceRect.width,
125 sourceRect.height,
126 destRect.left,
127 destRect.top,
128 destRect.width,
129 destRect.height);
130 }
131 $endif
132 }
133
134 /**
53 * Draws an image from a CanvasImageSource to this canvas. 135 * Draws an image from a CanvasImageSource to this canvas.
54 * 136 *
55 * The entire image from [source] will be drawn to this context with its top 137 * The entire image from [source] will be drawn to this context with its top
56 * left corner at the point ([destinationX], [destinationY]). If the image is 138 * left corner at the point ([destX], [destY]). If the image is
57 * larger than canvas will allow, the image will be cropped to fit the 139 * larger than canvas will allow, the image will be clipped to fit the
58 * available space. 140 * available space.
59 * 141 *
60 * CanvasElement canvas = new CanvasElement(width: 600, height: 600); 142 * CanvasElement canvas = new CanvasElement(width: 600, height: 600);
61 * CanvasRenderingContext2D ctx = canvas.context2d; 143 * CanvasRenderingContext2D ctx = canvas.context2d;
62 * ImageElement img = document.query('img'); 144 * ImageElement img = document.query('img');
63 * 145 *
64 * ctx.drawImage(img, 100, 100); 146 * ctx.drawImage(img, 100, 100);
65 * 147 *
66 * VideoElement video = document.query('video'); 148 * VideoElement video = document.query('video');
67 * ctx.drawImage(video, 0, 0); 149 * ctx.drawImage(video, 0, 0);
68 * 150 *
69 * CanvasElement otherCanvas = document.query('canvas'); 151 * CanvasElement otherCanvas = document.query('canvas');
70 * otherCanvas.width = 100; 152 * otherCanvas.width = 100;
71 * otherCanvas.height = 100; 153 * otherCanvas.height = 100;
72 * ctx.drawImage(otherCanvas, 590, 590); // will get cropped 154 * ctx.drawImage(otherCanvas, 590, 590); // will get clipped
73 * 155 *
74 * See also: 156 * See also:
75 * 157 *
76 * * [CanvasImageSource] for more information on what data is retrieved 158 * * [CanvasImageSource] for more information on what data is retrieved
77 * from [source]. 159 * from [source].
78 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage) 160 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage)
79 * from the WHATWG. 161 * from the WHATWG.
80 */ 162 */
81 @DomName('CanvasRenderingContext2D.drawImage') 163 @DomName('CanvasRenderingContext2D.drawImage')
82 void drawImage(CanvasImageSource source, num destinationX, num destinationY) { 164 $if DART2JS
83 $dom_drawImage(source, destinationX, destinationY); 165 @JSName('drawImage')
166 void drawImage(CanvasImageSource source, num destX, num destY) native;
167 $else
168 void drawImage(CanvasImageSource source, num destX, num destY) {
169 $dom_drawImage(source, destX, destY);
84 } 170 }
171 $endif
85 172
86 /** 173 /**
87 * Draws an image from a CanvasImageSource to an area of this canvas. 174 * Draws an image from a CanvasImageSource to an area of this canvas.
88 * 175 *
89 * The image will be drawn to an area of this canvas defined by 176 * The image will be drawn to this context with its top left corner at the
90 * [destinationRect]. If [sourceRect] is not provided, then 177 * point ([destX], [destY]) and will be scaled to be [destWidth] wide and
91 * the entire rectangular image from [source] will be drawn to this context. 178 * [destHeight] tall.
92 * If the dimensions of [source] or [sourceRect] 179 *
93 * differ from [destinationRect], then the image will be scaled to fit.
94 * If the image is larger than canvas 180 * If the image is larger than canvas
95 * will allow, the image will be cropped to fit the available space. 181 * will allow, the image will be clipped to fit the available space.
96 * 182 *
97 * CanvasElement canvas = new CanvasElement(width: 600, height: 600); 183 * CanvasElement canvas = new CanvasElement(width: 600, height: 600);
98 * CanvasRenderingContext2D ctx = canvas.context2d; 184 * CanvasRenderingContext2D ctx = canvas.context2d;
99 * ImageElement img = document.query('img'); 185 * ImageElement img = document.query('img');
100 * img.width = 100; 186 * img.width = 100;
101 * img.height = 100; 187 * img.height = 100;
102 * 188 *
103 * // Scale the image to 20x20. 189 * // Scale the image to 300x50 at the point (20, 20)
104 * ctx.drawImageAtScale(img, new Rect(50, 50, 20, 20)); 190 * ctx.drawImageScaled(img, 20, 20, 300, 50);
191 *
192 * See also:
193 *
194 * * [CanvasImageSource] for more information on what data is retrieved
195 * from [source].
196 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage)
197 * from the WHATWG.
198 */
199 @DomName('CanvasRenderingContext2D.drawImage')
200 $if DART2JS
201 @JSName('drawImage')
202 void drawImageScaled(CanvasImageSource source,
203 num destX, num destY, num destWidth, num destHeight) native;
204 $else
205 void drawImageScaled(CanvasImageSource source,
206 num destX, num destY, num destWidth, num destHeight) {
207 $dom_drawImage(source, destX, destY, destWidth, destHeight);
208 }
209 $endif
210
211 /**
212 * Draws an image from a CanvasImageSource to an area of this canvas.
213 *
214 * The image is a region of [source] that is [sourceWidth] wide and
215 * [destHeight] tall with top left corner at ([sourceX], [sourceY]).
216 * The image will be drawn to this context with its top left corner at the
217 * point ([destX], [destY]) and will be scaled to be [destWidth] wide and
218 * [destHeight] tall.
219 *
220 * If the image is larger than canvas
221 * will allow, the image will be clipped to fit the available space.
105 * 222 *
106 * VideoElement video = document.query('video'); 223 * VideoElement video = document.query('video');
107 * video.width = 100; 224 * video.width = 100;
108 * video.height = 100; 225 * video.height = 100;
109 * // Take the middle 20x20 pixels from the video and stretch them. 226 * // Take the middle 20x20 pixels from the video and stretch them.
110 * ctx.drawImageAtScale(video, new Rect(50, 50, 100, 100), 227 * ctx.drawImageScaledFromSource(video, 40, 40, 20, 20, 50, 50, 100, 100);
111 * sourceRect: new Rect(40, 40, 20, 20));
112 * 228 *
113 * // Draw the top 100x20 pixels from the otherCanvas. 229 * // Draw the top 100x20 pixels from the otherCanvas to this one.
114 * CanvasElement otherCanvas = document.query('canvas'); 230 * CanvasElement otherCanvas = document.query('canvas');
115 * ctx.drawImageAtScale(otherCanvas, new Rect(0, 0, 100, 20), 231 * ctx.drawImageScaledFromSource(otherCanvas, 0, 0, 100, 20, 0, 0, 100, 20 );
116 * sourceRect: new Rect(0, 0, 100, 20));
117 * 232 *
118 * See also: 233 * See also:
119 * 234 *
120 * * [CanvasImageSource] for more information on what data is retrieved 235 * * [CanvasImageSource] for more information on what data is retrieved
121 * from [source]. 236 * from [source].
122 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage) 237 * * [drawImage](http://www.whatwg.org/specs/web-apps/current-work/multipage /the-canvas-element.html#dom-context-2d-drawimage)
123 * from the WHATWG. 238 * from the WHATWG.
124 */ 239 */
125 @DomName('CanvasRenderingContext2D.drawImage') 240 @DomName('CanvasRenderingContext2D.drawImage')
126 void drawImageAtScale(CanvasImageSource source, Rect destinationRect, 241 $if DART2JS
127 {Rect sourceRect}) { 242 @JSName('drawImage')
128 if (sourceRect == null) { 243 void drawImageScaledFromSource(CanvasImageSource source,
129 $dom_drawImage(source, 244 num sourceX, num sourceY, num sourceWidth, num sourceHeight,
130 destinationRect.left, 245 num destX, num destY, num destWidth, num destHeight) native;
131 destinationRect.top, 246 $else
132 destinationRect.width, 247 void drawImageScaledFromSource(CanvasImageSource source,
133 destinationRect.height); 248 num sourceX, num sourceY, num sourceWidth, num sourceHeight,
134 } else { 249 num destX, num destY, num destWidth, num destHeight) {
135 $dom_drawImage(source, 250 $dom_drawImage(source, sourceX, sourceY, sourceWidth, sourceHeight,
136 sourceRect.left, 251 destX, destY, destWidth, destHeight);
137 sourceRect.top,
138 sourceRect.width,
139 sourceRect.height,
140 destinationRect.left,
141 destinationRect.top,
142 destinationRect.width,
143 destinationRect.height);
144 }
145 } 252 }
253 $endif
146 254
147 $if DART2JS 255 $if DART2JS
148 @DomName('CanvasRenderingContext2D.lineDashOffset') 256 @DomName('CanvasRenderingContext2D.lineDashOffset')
149 num get lineDashOffset => JS('num', 257 num get lineDashOffset => JS('num',
150 '#.lineDashOffset || #.webkitLineDashOffset', this, this); 258 '#.lineDashOffset || #.webkitLineDashOffset', this, this);
151 259
152 @DomName('CanvasRenderingContext2D.lineDashOffset') 260 @DomName('CanvasRenderingContext2D.lineDashOffset')
153 void set lineDashOffset(num value) => JS('void', 261 void set lineDashOffset(num value) => JS('void',
154 'typeof #.lineDashOffset != "undefined" ? #.lineDashOffset = # : ' 262 'typeof #.lineDashOffset != "undefined" ? #.lineDashOffset = # : '
155 '#.webkitLineDashOffset = #', this, this, value, this, value); 263 '#.webkitLineDashOffset = #', this, this, value, this, value);
264 $else
265 // TODO(amouravski): Add Dartium native methods for drawImage once we figure
266 // out how to not break native bindings.
156 $endif 267 $endif
157 } 268 }
269
OLDNEW
« no previous file with comments | « tools/dom/src/CanvasImageSource.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698