- From: Ian Hickson via cvs-syncmail <cvsmail@w3.org>
- Date: Thu, 28 Apr 2011 18:00:27 +0000
- To: public-html-commits@w3.org
Update of /sources/public/html5/2dcontext In directory hutz:/tmp/cvs-serv25487 Modified Files: Overview.html Log Message: sync 2dcontext with latest pub system changes (mark 2) (whatwg r6036) Index: Overview.html =================================================================== RCS file: /sources/public/html5/2dcontext/Overview.html,v retrieving revision 1.104 retrieving revision 1.105 diff -u -d -r1.104 -r1.105 --- Overview.html 5 Apr 2011 15:10:21 -0000 1.104 +++ Overview.html 28 Apr 2011 18:00:25 -0000 1.105 @@ -1,7 +1,4 @@ -<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"><!-- when publishing, change bits marked ZZZ - ZZZ: Set PUB to 1 for TR/ drafts, 0 for dev drafts; PUB-Y lines are used if it's 1 and PUB-N lines if it's 0. - ZZZ: Set YEAR, SHORTDAY, and LONGDAY accordingly. They are used by the INSERT FOO bits below. - --><html lang="en-US-x-Hixie"><title>HTML Canvas 2D Context</title><style type="text/css"> +<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"><html lang="en-US-x-Hixie"><title>HTML Canvas 2D Context</title><style type="text/css"> pre { margin-left: 2em; white-space: pre-wrap; } h2 { margin: 3em 0 1em 0; } h3 { margin: 2.5em 0 1em 0; } @@ -298,8 +295,7 @@ </style><style type="text/css"> .domintro:before { display: table; margin: -1em -0.5em -0.5em auto; width: auto; content: 'This box is non-normative. Implementation requirements are given below this box.'; color: black; font-style: italic; border: solid 2px; background: white; padding: 0 0.25em; } - </style> -<link href="data:text/css,.impl%20{%20display:%20none;%20}%0Ahtml%20{%20border:%20solid%20yellow;%20}%20.domintro:before%20{%20display:%20none;%20}" id="author" rel="alternate stylesheet" title="Author documentation only"><link href="data:text/css,.impl%20{%20background:%20%23FFEEEE;%20}%20.domintro:before%20{%20background:%20%23FFEEEE;%20}" id="highlight" rel="alternate stylesheet" title="Highlight implementation requirements"><script type="text/javascript"> + </style><link href="data:text/css," id="complete" rel="stylesheet" title="Complete specification"><link href="data:text/css,.impl%20{%20display:%20none;%20}%0Ahtml%20{%20border:%20solid%20yellow;%20}%20.domintro:before%20{%20display:%20none;%20}" id="author" rel="alternate stylesheet" title="Author documentation only"><link href="data:text/css,.impl%20{%20background:%20%23FFEEEE;%20}%20.domintro:before%20{%20background:%20%23FFEEEE;%20}" id="highlight" rel="alternate stylesheet" title="Highlight implementation requirements"><script type="text/javascript"> function getCookie(name) { var params = location.search.substr(1).split("&"); for (var index = 0; index < params.length; index++) { @@ -344,13 +340,14 @@ <h1>HTML Canvas 2D Context</h1> <h2 class="no-num no-toc" id="generatedID"></h2> - <h2 class="no-num no-toc" id="editor-s-draft-28-february-2011">Editor's Draft 28 February 2011</h2> + <h2 class="no-num no-toc" id="editor-s-draft-28-april-2011">Editor's Draft 28 April 2011</h2> <dl><dt>Latest Published Version:</dt> <dd><a href="http://www.w3.org/TR/2dcontext/">http://www.w3.org/TR/2dcontext/</a></dd> <dt>Latest Editor's Draft:</dt> <dd><a class="latest-link" href="http://dev.w3.org/html5/2dcontext/">http://dev.w3.org/html5/2dcontext/</a></dd> -<!-- ZZZ: add the new version after it has shipped --> <dt>Previous Versions:</dt> + <dd><a href="http://www.w3.org/TR/2011/WD-2dcontext-20110405/">http://www.w3.org/TR/2011/WD-2dcontext-20110405/</a></dd> + <dd><a href="http://www.w3.org/TR/2011/WD-2dcontext-20110113/">http://www.w3.org/TR/2011/WD-2dcontext-20110113/</a></dd> <dd><a href="http://www.w3.org/TR/2010/WD-2dcontext-20101019/">http://www.w3.org/TR/2010/WD-2dcontext-20101019/</a></dd> <dd><a href="http://www.w3.org/TR/2010/WD-2dcontext-20100624/">http://www.w3.org/TR/2010/WD-2dcontext-20100624/</a></dd> <dd><a href="http://www.w3.org/TR/2010/WD-2dcontext-20100304/">http://www.w3.org/TR/2010/WD-2dcontext-20100304/</a></dd> @@ -381,12 +378,12 @@ </div><hr class="top"><h2 class="no-num no-toc" id="abstract">Abstract</h2><p>This specification defines the 2D Context for the HTML - <code>canvas</code> element.<h2 class="no-num no-toc" id="status-of-this-document">Status of This document</h2><!-- intro boilerplate (required) --><p><em>This section describes the status of this document at the + <code>canvas</code> element.<h2 class="no-num no-toc" id="status-of-this-document">Status of This document</h2><p><em>This section describes the status of this document at the time of its publication. Other documents may supersede this document. A list of current W3C publications and the most recently formally published revision of this technical report can be found in the <a href="http://www.w3.org/TR/">W3C technical reports index</a> - at http://www.w3.org/TR/.</em></p><!-- where to send feedback (required) --><p>If you wish to make comments regarding this document in a manner + at http://www.w3.org/TR/.</em></p><p>If you wish to make comments regarding this document in a manner that is tracked by the W3C, please submit them via using <a href="http://www.w3.org/Bugs/Public/enter_bug.cgi?product=HTML%20WG">our public bug database</a>. If you do not have an account then you can enter feedback using this form:<form action="http://www.whatwg.org/specs/web-apps/current-work/file-spam.cgi" method="post"> @@ -441,21 +438,21 @@ editor also maintains <a href="http://www.whatwg.org/issues/">a list of all e-mails that he has not yet tried to address</a>. These bugs, issues, and e-mails apply to multiple HTML-related specifications, - not just this one.</p><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- stability (required) --><p>Implementors should be aware that this specification is not + not just this one.</p><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>Implementors should be aware that this specification is not stable. <strong>Implementors who are not taking part in the discussions are likely to find the specification changing out from under them in incompatible ways.</strong> Vendors interested in implementing this specification before it eventually reaches the Candidate Recommendation stage should join the aforementioned mailing lists and take part in the discussions.<div id="multipage-common"> - </div><!-- not everyone agrees with this (requested before html5 fpwd) --><p>The publication of this document by the W3C as a W3C Working + </div><p>The publication of this document by the W3C as a W3C Working Draft does not imply that all of the participants in the W3C HTML working group endorse the contents of the specification. Indeed, for any section of the specification, one can usually find many members of the working group or of the W3C as a whole who object strongly to the current text, the existence of the section at all, or the idea that the working group should even spend time discussing the concept - of that section.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- version history or list of changes (required) --><p>The latest stable version of the editor's draft of this + of that section.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>The latest stable version of the editor's draft of this specification is always available on <a href="http://dev.w3.org/html5/">the W3C CVS server</a> and in the <a href="http://svn.whatwg.org/webapps/">WHATWG Subversion repository</a>. The <a href="http://www.whatwg.org/specs/web-apps/current-work/complete.html">latest editor's working copy</a> (which may contain unfinished text in the @@ -471,17 +468,17 @@ <dd>CVSWeb interface with side-by-side diffs: <a href="http://dev.w3.org/cvsweb/html5/">http://dev.w3.org/cvsweb/html5/</a></dd> <dd>Annotated summary with unified diffs: <a href="http://html5.org/tools/web-apps-tracker">http://html5.org/tools/web-apps-tracker</a></dd> <dd>Raw Subversion interface: <code>svn checkout http://svn.whatwg.org/webapps/</code></dd> - </dl><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING LIST TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- status of document, group responsible (required) --><p>The W3C <a href="http://www.w3.org/html/wg/">HTML Working + </dl><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING LIST TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>The W3C <a href="http://www.w3.org/html/wg/">HTML Working Group</a> is the W3C working group responsible for this specification's progress along the W3C Recommendation track. - This specification is the 28 February 2011 Editor's Draft. - </p><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- relationship to other work (required) --><p>Work on this specification is also done at the <a href="http://www.whatwg.org/">WHATWG</a>. The W3C HTML working group + This specification is the 28 April 2011 Editor's Draft. + </p><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>Work on this specification is also done at the <a href="http://www.whatwg.org/">WHATWG</a>. The W3C HTML working group actively pursues convergence with the WHATWG, as required by the <a href="http://www.w3.org/2007/03/HTML-WG-charter">W3C HTML working - group charter</a>.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- context and rationale (required) --><!-- (this text is from the RDFa+HTML spec --><p>This specification is an extension to the HTML5 language. All + group charter</a>.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- UNDER NO CIRCUMSTANCES IS THE PRECEDING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>This specification is an extension to the HTML5 language. All normative content in the HTML5 specification, unless specifically overridden by this specification, is intended to be the basis for - this specification.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><!-- required patent boilerplate --><p>This document was produced by a group operating under the <a href="http://www.w3.org/Consortium/Patent-Policy-20040205/">5 + this specification.</p><!-- UNDER NO CIRCUMSTANCES IS THE FOLLOWING PARAGRAPH TO BE REMOVED OR EDITED WITHOUT TALKING TO IAN FIRST --><p>This document was produced by a group operating under the <a href="http://www.w3.org/Consortium/Patent-Policy-20040205/">5 February 2004 W3C Patent Policy</a>. W3C maintains a <a href="http://www.w3.org/2004/01/pp-impl/40318/status" rel="disclosure">public list of any patent disclosures</a> made in connection with the deliverables of the group; that page also includes instructions for disclosing a @@ -489,7 +486,6 @@ individual believes contains <a href="http://www.w3.org/Consortium/Patent-Policy-20040205/#def-essential">Essential Claim(s)</a> must disclose the information in accordance with <a href="http://www.w3.org/Consortium/Patent-Policy-20040205/#sec-Disclosure">section 6 of the W3C Patent Policy</a>.<h2 class="no-num no-toc" id="contents">Table of Contents</h2> -<!--begin-toc--> <ol class="toc"> <li><a href="#conformance-requirements"><span class="secno">1 </span>Conformance requirements</a></li> <li><a href="#the-canvas-state"><span class="secno">2 </span>The canvas state</a></li> @@ -508,7 +504,7 @@ <li><a href="#examples"><span class="secno">15 </span>Examples</a></li> <li><a class="no-num" href="#references">References</a></li> <li><a class="no-num" href="#acknowledgements">Acknowledgements</a></ol> -<!--end-toc--><hr><h2 id="conformance-requirements"><span class="secno">1 </span>Conformance requirements</h2><p>This specification is an HTML specification. All the conformance +<hr><h2 id="conformance-requirements"><span class="secno">1 </span>Conformance requirements</h2><p>This specification is an HTML specification. All the conformance requirements, conformance classes, definitions, dependencies, terminology, and typographical conventions described in the core HTML5 specification apply to this specification. <a href="#refsHTML5">[HTML5]</a><p>Interfaces are defined in terms of Web IDL. <a href="#refsWEBIDL">[WEBIDL]</a><p>This specification defines the <dfn id="canvas-context-2d" title="canvas-context-2d"><code>2d</code></dfn> context type, whose @@ -530,35 +526,15 @@ // state void <a href="#dom-context-2d-save" title="dom-context-2d-save">save</a>(); // push state on state stack void <a href="#dom-context-2d-restore" title="dom-context-2d-restore">restore</a>(); // pop state stack and restore state -<!-- - // v5 we've also received requests for: - attribute boolean <span title="dom-context-2d-forceHighQuality">forceHighQuality</span> // (default false) - // when enabled, it would prevent the UA from falling back on lower-quality but faster rendering routines - // useful e.g. for when an image manipulation app uses <canvas> both for UI previews and the actual work ---> // transformations (default transform is the identity matrix) void <a href="#dom-context-2d-scale" title="dom-context-2d-scale">scale</a>(in double x, in double y); void <a href="#dom-context-2d-rotate" title="dom-context-2d-rotate">rotate</a>(in double angle); void <a href="#dom-context-2d-translate" title="dom-context-2d-translate">translate</a>(in double x, in double y); void <a href="#dom-context-2d-transform" title="dom-context-2d-transform">transform</a>(in double a, in double b, in double c, in double d, in double e, in double f); void <a href="#dom-context-2d-settransform" title="dom-context-2d-setTransform">setTransform</a>(in double a, in double b, in double c, in double d, in double e, in double f); -<!-- - // v5 we've also received requests for: - void skew(...); - void reflect(...); // or mirror(...) ---> // compositing attribute double <a href="#dom-context-2d-globalalpha" title="dom-context-2d-globalAlpha">globalAlpha</a>; // (default 1.0) attribute DOMString <a href="#dom-context-2d-globalcompositeoperation" title="dom-context-2d-globalCompositeOperation">globalCompositeOperation</a>; // (default source-over) -<!-- - // v5 we've also received requests for: - - turning off antialiasing to avoid seams when patterns are painted next to each other - - might be better to overdraw? - - might be better to just draw at a higher res then downsample, like for 3d? - - nested layers - - the ability to composite an entire set of drawing operations with one shadow all at once - http://lists.whatwg.org/pipermail/whatwg-whatwg.org/2008-August/015567.html ---> // colors and styles attribute any <a href="#dom-context-2d-strokestyle" title="dom-context-2d-strokeStyle">strokeStyle</a>; // (default black) attribute any <a href="#dom-context-2d-fillstyle" title="dom-context-2d-fillStyle">fillStyle</a>; // (default black) @@ -608,10 +584,7 @@ attribute DOMString <a href="#dom-context-2d-textalign" title="dom-context-2d-textAlign">textAlign</a>; // "start", "end", "left", "right", "center" (default: "start") attribute DOMString <a href="#dom-context-2d-textbaseline" title="dom-context-2d-textBaseline">textBaseline</a>; // "top", "hanging", "middle", "alphabetic", "ideographic", "bottom" (default: "alphabetic") void <a href="#dom-context-2d-filltext" title="dom-context-2d-fillText">fillText</a>(in DOMString text, in double x, in double y, in optional double maxWidth); - void <a href="#dom-context-2d-stroketext" title="dom-context-2d-strokeText">strokeText</a>(in DOMString text, in double x, in double y, in optional double maxWidth);<!-- v5DVT - void <span title="dom-context-2d-fillVerticalText">fillVerticalText</span>(in DOMString text, in double x, in double y, in optional double maxHeight); - void <span title="dom-context-2d-strokeVerticalText">strokeVerticalText</span>(in DOMString text, in double x, in double y, in optional double maxHeight); --> - <a href="#textmetrics">TextMetrics</a> <a href="#dom-context-2d-measuretext" title="dom-context-2d-measureText">measureText</a>(in DOMString text); + void <a href="#dom-context-2d-stroketext" title="dom-context-2d-strokeText">strokeText</a>(in DOMString text, in double x, in double y, in optional double maxWidth); <a href="#textmetrics">TextMetrics</a> <a href="#dom-context-2d-measuretext" title="dom-context-2d-measureText">measureText</a>(in DOMString text); // drawing images void <a href="#dom-context-2d-drawimage" title="dom-context-2d-drawImage">drawImage</a>(in <span>HTMLImageElement</span> image, in double dx, in double dy, in optional double dw, in double dh); @@ -669,18 +642,7 @@ any method call with a numeric argument whose value is infinite or a NaN value must be ignored.</p> - <!-- - Philip Taylor wrote: - > My experience with some 3d canvas code is that infinities come up in - > naturally harmless places, e.g. having a function that scales by x then - > translates by 1/x and wanting it to work when x=0 (which ought to draw - > nothing, since anything it draws is zero pixels wide), and it's a bit - > annoying to track down and fix those issues, so I'd probably like it if - > they were harmless in canvas methods. Opera appears to silently not draw - > anything if the transformation matrix is not finite, but Firefox throws - > exceptions when passing in non-finite arguments. - --> - + <p>Whenever the CSS value <code title="">currentColor</code> is used as a color in this API, the "computed value of the 'color' property" for the purposes of determining the computed value of the <code title="">currentColor</code> keyword is the computed value of the @@ -740,27 +702,9 @@ drawing state it describes. If there is no saved state, the method must do nothing.</p> - <!-- v5 -idea from Mihai: -> 5. Drawing states should be saveable with IDs, and for easier restoring. -> -> save(id) -> restore(id) -> -> If id is not provided, then save() works as defined now. The same for -> restore(). -> -> Currently, it's not trivial to save and restore a specific state. -...and from Philip: -> I think a more convenient syntax would be: -> var state = ctx.save(); -> ctx.restore(state); -> But how would it interact with normal calls to ctx.restore()? - --> - + </div><h2 id="transformations"><span class="secno">3 </span><dfn title="dom-context-2d-transformation">Transformations</dfn></h2><p>The transformation matrix is applied to coordinates when creating - shapes and paths.</p><!-- conformance criteria for actual drawing - are described in the various sections below --><div class="impl"> + shapes and paths.</p><div class="impl"> <p>When the context is created, the transformation matrix must initially be the identity transform. It may then be adjusted using @@ -884,9 +828,7 @@ <p>All drawing operations are affected by the global compositing attributes, <code title="dom-context-2d-globalAlpha"><a href="#dom-context-2d-globalalpha">globalAlpha</a></code> and <code title="dom-context-2d-globalCompositeOperation"><a href="#dom-context-2d-globalcompositeoperation">globalCompositeOperation</a></code>.</p> - <!-- conformance criteria for painting are described in the "drawing - model" section below --> - + <p>The <dfn id="dom-context-2d-globalalpha" title="dom-context-2d-globalAlpha"><code>globalAlpha</code></dfn> attribute gives an alpha value that is applied to shapes and images before they are composited onto the canvas. The value must be in the @@ -954,12 +896,6 @@ destination image instead of the source image and vice versa.</span></dd> -<!-- no clear definition of this operator (doesn't correspond to a PorterDuff operator) - <dt><dfn title="gcop-darker"><code>darker</code></dfn></dt> - - <dd><span class="note">Display the sum of the source image and destination image, - with color values approaching 0 as a limit.</span></dd> ---> <dt><dfn id="gcop-lighter" title="gcop-lighter"><code>lighter</code></dfn></dt> @@ -1039,32 +975,7 @@ </dl><div class="impl"> - <!-- v5 feature requests: - - * Getting and setting colours by component to bypass the CSS value parsing. - - Either: - context.fillStyle.red += 1; - - Or: - var array = context.fillStyle; - array[1] += 1; - context.fillStyle = array; - - * A more performant way of setting colours in general, e.g.: - - context.setFillColor(r,g,b,a) // already supported by webkit - - Or: - - context.fillStyle = 0xRRGGBBAA; // set a 32bit int directly - - * fill rule for deciding between winding and even-odd algorithms. - SVG has fill-rule: nonzero | evenodd - http://www.w3.org/TR/SVG/painting.html#FillProperties - - --> - + <p>The <dfn id="dom-context-2d-strokestyle" title="dom-context-2d-strokeStyle"><code>strokeStyle</code></dfn> attribute represents the color or style to use for the lines around shapes, and the <dfn id="dom-context-2d-fillstyle" title="dom-context-2d-fillStyle"><code>fillStyle</code></dfn> @@ -1113,10 +1024,7 @@ U+002E FULL STOP (representing the decimal point), if the alpha value is greater than zero then one or more digits in the range 0-9 (U+0030 to U+0039) representing the fractional part of the alpha - value, and finally a U+0029 RIGHT PARENTHESIS.</p> <!-- if people - complain this is unreadable, expand it into a <dl> with two nested - <ol>s --> - + value, and finally a U+0029 RIGHT PARENTHESIS.</p> <p>When the context is created, the <code title="dom-context-2d-strokeStyle"><a href="#dom-context-2d-strokestyle">strokeStyle</a></code> and <code title="dom-context-2d-fillStyle"><a href="#dom-context-2d-fillstyle">fillStyle</a></code> attributes must initially have the string value <code title="">#000000</code>.</p> @@ -1261,15 +1169,6 @@ <p>Gradients must be painted only where the relevant stroking or filling effects requires that they be drawn.</p> -<!-- - <p>Support for actually painting gradients is optional. Instead of - painting the gradients, user agents may instead just paint the first - stop's color. However, <code - title="dom-context-2d-createLinearGradient">createLinearGradient()</code> - and <code - title="dom-context-2d-createRadialGradient">createRadialGradient()</code> - must always return objects when passed valid arguments.</p> ---> </div><hr><p>Patterns are represented by objects implementing the opaque <code><a href="#canvaspattern">CanvasPattern</a></code> interface.<dl class="domintro"><dt><var title="">pattern</var> = <var title="">context</var> . <code title="dom-context-2d-createPattern"><a href="#dom-context-2d-createpattern">createPattern</a></code>(<var title="">image</var>, <var title="">repetition</var>)</dt> @@ -1314,21 +1213,19 @@ <code>HTMLImageElement</code>, <code>HTMLCanvasElement</code>, or <code>HTMLVideoElement</code>. If the <var title="">image</var> is null, the implementation must raise a <code>TYPE_MISMATCH_ERR</code> - exception.</p> <!-- drawImage() has an equivalent paragraph --> + exception.</p> <p>If the <var title="">image</var> argument is an <code>HTMLImageElement</code> object that is not <span title="img-good">fully decodable</span>, or if the <var title="">image</var> argument is an <code>HTMLVideoElement</code> object whose <code title="dom-media-readyState">readyState</code> attribute is either <code title="dom-media-HAVE_NOTHING">HAVE_NOTHING</code> or <code title="dom-media-HAVE_METADATA">HAVE_METADATA</code>, then the - implementation must return null.</p> <!-- drawImage() has an - equivalent paragraph --> - + implementation must return null.</p> <p>If the <var title="">image</var> argument is an <code>HTMLCanvasElement</code> object with either a horizontal dimension or a vertical dimension equal to zero, then the implementation must raise an <code>INVALID_STATE_ERR</code> exception.</p> - <!-- drawImage() has an equivalent paragraph --> + <p>Patterns must be painted so that the top left of the first image is anchored at the origin of the coordinate space, and images are @@ -1351,14 +1248,14 @@ pixel's coordinates to the original image's dimensions. (That is, the filter uses 'repeat' behavior, regardless of the value of <var title="">repetition</var>.) - <!-- drawImage() has a similar paragraph with different rules --> + <p>When the <code title="dom-context-2d-createPattern"><a href="#dom-context-2d-createpattern">createPattern()</a></code> method is passed an animated image as its <var title="">image</var> argument, the user agent must use the poster frame of the animation, or, if there is no poster frame, the first frame of the animation.</p> - <!-- drawImage() has an equivalent paragraph --> + <p>When the <var title="">image</var> argument is an <code>HTMLVideoElement</code>, then the frame at the <span>current @@ -1367,15 +1264,9 @@ <span title="concept-video-intrinsic-height">intrinsic height</span> of the <span>media resource</span> (i.e. after any aspect-ratio correction has been applied).</p> - <!-- drawImage() has an equivalent paragraph --> - - <!-- - Requests for v5 features: - * apply transforms to patterns, so you don't have to create - transformed patterns manually by rendering them to an off-screen - canvas then using that canvas as the pattern. - --> + + </div><h2 id="line-styles"><span class="secno">6 </span>Line styles</h2><dl class="domintro"><dt><var title="">context</var> . <code title="dom-context-2d-lineWidth"><a href="#dom-context-2d-linewidth">lineWidth</a></code> [ = <var title="">value</var> ]</dt> <dd> @@ -1523,29 +1414,7 @@ <p>When the context is created, the <code title="dom-context-2d-miterLimit"><a href="#dom-context-2d-miterlimit">miterLimit</a></code> attribute must initially have the value <code>10.0</code>.</p> - <!-- -v5: dashed lines have been requested. Philip Taylor provides these -notes on what would need to be defined for dashed lines: -> I don't think it's entirely trivial to add, to the detail that's -> necessary in a specification. The common graphics APIs (at least -> Cairo, Quartz and java.awt.Graphics, and any SVG implementation) all -> have dashes specified by passing an array of dash lengths (alternating -> on/off), so that should be alright as long as you define what units -> it's measured in and what happens when you specify an odd number of -> values and how errors are handled and what happens if you update the -> array later. But after that, what does it do when stroking multiple -> subpaths, in terms of offsetting the dashes? When you use strokeRect, -> where is offset 0? Does moveTo reset the offset? How does it interact -> with lineCap/lineJoin? All the potential issues need test cases too, -> and the implementations need to make sure they handle any edge cases -> that the underlying graphics library does differently. (SVG Tiny 1.2 -> appears to skip some of the problems by leaving things undefined and -> allowing whatever behavior the graphics library has.) - -Another request has been for hairline width lines, that remain -hairline width with transform. ack Shaun Morris. - --> - + </div><h2 id="shadows"><span class="secno">7 </span><dfn>Shadows</dfn></h2><p>All drawing operations are affected by the four global shadow attributes.<dl class="domintro"><dt><var title="">context</var> . <code title="dom-context-2d-shadowColor"><a href="#dom-context-2d-shadowcolor">shadowColor</a></code> [ = <var title="">value</var> ]</dt> @@ -1651,7 +1520,7 @@ <li> <p>Perform a 2D Gaussian Blur on <var title="">B</var>, using <var title="">σ</var> as the standard deviation.</p> - <!-- wish i could find a reference for this --> </li> + </li> </ol><p>User agents may limit values of <var title="">σ</var> to an implementation-specific maximum value to avoid exceeding @@ -2000,11 +1869,7 @@ a new subpath with the point (<var title="">x</var>, <var title="">y</var>) as the only point in the subpath.</p> - <!-- v5 feature request: - * points as a primitive shape - http://home.comcast.net/~urbanjost/canvas/vogle4.html - --> - + <p>The <dfn id="dom-context-2d-fill" title="dom-context-2d-fill"><code>fill()</code></dfn> method must fill all the subpaths of the current path, using @@ -2052,13 +1917,7 @@ to the rectangle with the top left corner at (0,0) and the width and height of the coordinate space.</p> - <!-- v5 - Jordan OSETE suggests: - * support ways of extending the clipping region (union instead of intersection) - - also "add", "subtract", "replace", "intersect" and "xor" - * support ways of resetting the clipping region without save/restore - --> - + <p>The <dfn id="dom-context-2d-ispointinpath" title="dom-context-2d-isPointInPath"><code>isPointInPath(<var title="">x</var>, <var title="">y</var>)</code></dfn> method must return true if the point given by the <var title="">x</var> and <var title="">y</var> coordinates passed to the method, when treated as @@ -2069,7 +1928,7 @@ path. If either of the arguments is infinite or NaN, then the method must return false.</p> - </div><h2 id="focus-management"><span class="secno">10 </span>Focus management</h2><!-- a v4 feature --><p>When a canvas is interactive, authors should include focusable + </div><h2 id="focus-management"><span class="secno">10 </span>Focus management</h2><p>When a canvas is interactive, authors should include focusable elements in the element's fallback content corresponding to each focusable part of the canvas.<p>To indicate which focusable part of the canvas is currently focused, authors should use the <code title="dom-context-2d-drawFocusRing"><a href="#dom-context-2d-drawfocusring">drawFocusRing()</a></code> method, @@ -2200,9 +2059,8 @@ document.getElementsByTagName('canvas')[0].addEventListener('click', processClick, false); redraw(); </script></pre> -<!-- http://software.hixie.ch/utilities/js/live-dom-viewer/saved/340 --> - </div><h2 id="text"><span class="secno">11 </span>Text</h2><!-- a v3 feature --><dl class="domintro"><dt><var title="">context</var> . <code title="dom-context-2d-font"><a href="#dom-context-2d-font">font</a></code> [ = <var title="">value</var> ]</dt> + </div><h2 id="text"><span class="secno">11 </span>Text</h2><dl class="domintro"><dt><var title="">context</var> . <code title="dom-context-2d-font"><a href="#dom-context-2d-font">font</a></code> [ = <var title="">value</var> ]</dt> <dd> @@ -2348,7 +2206,7 @@ </div><p>The <code title="dom-context-2d-textBaseline"><a href="#dom-context-2d-textbaseline">textBaseline</a></code> attribute's allowed keywords correspond to alignment points in the - font:<p><img alt="The top of the em square is roughly at the top of the glyphs in a font, the hanging baseline is where some glyphs like आ are anchored, the middle is half-way between the top of the em square and the bottom of the em square, the alphabetic baseline is where characters like Á, ÿ, f, and Ω are anchored, the ideographic baseline is where glyphs like 私 and 達 are anchored, and the bottom of the em square is roughly at the bottom of the glyphs in a font. The top and bottom of the bounding box can be far from these baselines, due to glyphs extending far outside the em square." height="300" src="http://www.w3.org/TR/html5/images/baselines.png" width="738"><p>The keywords map to these alignment points as follows:<dl><dt><dfn id="dom-context-2d-textbaseline-top" title="dom-context-2d-textBaseline-top"><code>top</code></dfn> + font:<p><img alt="The top of the em square is roughly at the top of the glyphs in a font, the hanging baseline is where some glyphs like आ are anchored, the middle is half-way between the top of the em square and the bottom of the em square, the alphabetic baseline is where characters like Á, ÿ, f, and Ω are anchored, the ideographic baseline is where glyphs like 私 and 達 are anchored, and the bottom of the em square is roughly at the bottom of the glyphs in a font. The top and bottom of the bounding box can be far from these baselines, due to glyphs extending far outside the em square." height="300" src="http://dev.w3.org/html5/spec/images/baselines.png" width="738"><p>The keywords map to these alignment points as follows:<dl><dt><dfn id="dom-context-2d-textbaseline-top" title="dom-context-2d-textBaseline-top"><code>top</code></dfn> <dd>The top of the em square</dd> <dt><dfn id="dom-context-2d-textbaseline-hanging" title="dom-context-2d-textBaseline-hanging"><code>hanging</code></dfn> @@ -2394,9 +2252,7 @@ 'direction' property of the inline box set to <span>the directionality</span> of the <code>canvas</code> element. <a href="#refsCSS">[CSS]</a></li> - <!-- if you insert a step here, make sure to adjust the next step's - final words --> - + <li><p>If the <var title="">maxWidth</var> argument was specified and the hypothetical width of the inline box in the hypothetical line box is greater than <var title="">maxWidth</var> CSS pixels, @@ -2507,157 +2363,7 @@ </li> - </ol><!--v5DVT - this is commented out until CSS can get its act together -enough to actual specify vertical text rendering (how long have we -been waiting now?) - -WHEN EDITING THIS, FIX THE PARTS MARKED "XXX" BELOW - - <p>The <dfn - title="dom-context-2d-fillVerticalText"><code>fillVerticalText()</code></dfn> - and <dfn - title="dom-context-2d-strokeVerticalText"><code>strokeVerticalText()</code></dfn> - methods take three or four arguments, <var title="">text</var>, <var - title="">x</var>, <var title="">y</var>, and optionally <var - title="">maxHeight</var>, and render the given <var - title="">text</var> as vertical text at the given (<var - title="">x</var>, <var title="">y</var>) coordinates ensuring that - the text isn't taller than <var title="">maxHeight</var> if - specified, using the current <code - title="dom-context-2d-font">font</code> and <code - title="dom-context-2d-textAlign">textAlign</code> - values. Specifically, when the methods are called, the user agent - must run the following steps:</p> - - <ol> - - <li><p>If <var title="">maxHeight</var> is present but less than or - equal to zero, return without doing anything; abort these - steps.</p></li> - - <li><p>Let <var title="">font</var> be the current font of the - context, as given by the <code - title="dom-context-2d-font">font</code> attribute.</p></li> - - <li><p>Replace all the <span title="space character">space - characters</span> in <var title="">text</var> with U+0020 SPACE - characters.</p></li> - - <li><p>Form a <em class="XXX">whatever CSS ends up calling - vertical line boxes and inline boxes</em> containing the text <var - title="">text</var>, with all the properties at their initial - values except the 'font' property of the inline box set to <var - title="">font</var> and the 'direction' property of the inline - box set to <span>the directionality</span> of the <code>canvas</code> - element.</p></li> - - <!- - if you insert a step here, make sure to adjust the next step's - final words - -> - - <li><p>If the <var title="">maxHeight</var> argument was specified - and the hypothetical height of the <em class="XXX">box</em> - in the hypothetical line box is greater than <var - title="">maxHeight</var> CSS pixels, then change <var - title="">font</var> to have a more condensed font (if one is - available or if a reasonably readable one can be synthesized by - applying an appropriate scale factor to the font) or a smaller - font, and return to the previous step.</p></li> - - <li> - - <p>Let the <var title="">anchor point</var> be a point on the <em - class="XXX">inline box</var>, determined by the <code - title="dom-context-2d-textAlign">textAlign</code>, as follows:</p> - - <p>Vertical position:</p> - - <dl> - - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">start</code></dt> - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">left</code> and <span>the directionality</span> of the - <code>canvas</code> element is 'ltr'</dt> - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">right</code> and <span>the directionality</span> of the - <code>canvas</code> element is 'rtl'</dt> - - <dd>Let the <var title="">anchor point</var>'s vertical - position be the top edge of the <em class="XXX">inline - box</em>.</dd> - - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">end</code></dt> - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">right</code> and <span>the directionality</span> of the - <code>canvas</code> element is 'ltr'</dt> - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">left</code> and <span>the directionality</span> of the - <code>canvas</code> element is 'rtl'</dt> - - <dd>Let the <var title="">anchor point</var>'s vertical - position be the bottom edge of the <em class="XXX">inline - box</em>.</dd> - - - <dt> If <code - title="dom-context-2d-textAlign">textAlign</code> is <code - title="">center</code></dt> - - <dd>Let the <var title="">anchor point</var>'s vertical position - be half way between the top and bottom edges of the <em - class="XXX">inline box</em>.</dd> - - </dl> - - <p>Let the horizontal position be half way between the left and - right edges of the em box of the first available font of the <em - class="XXX">inline box</em>.</p> - - </li> - - <li> - - <p>Paint the hypothetical inline box as the shape given by the - text's glyphs, as transformed by the <span - title="dom-context-2d-transformation">current transformation - matrix</span>, and anchored and sized so that before applying the - <span title="dom-context-2d-transformation">current transformation - matrix</span>, the <var title="">anchor point</var> is at (<var - title="">x</var>, <var title="">y</var>) and each CSS pixel is - mapped to one coordinate space unit.</p> - - <p>For <code - title="dom-context-2d-fillVerticalText">fillVerticalText()</code> - <code title="dom-context-2d-fillStyle">fillStyle</code> must be - applied and <code - title="dom-context-2d-strokeStyle">strokeStyle</code> must be - ignored. For <code - title="dom-context-2d-strokeVerticalText">strokeVerticalText()</code> - the reverse holds and <code - title="dom-context-2d-strokeStyle">strokeStyle</code> must be - applied and <code - title="dom-context-2d-fillStyle">fillStyle</code> must be - ignored.</p> - - <p>Text is painted without affecting the current path, and is - subject to <span title="shadows">shadow effects</span>, <span - title="dom-context-2d-globalAlpha">global alpha</span>, the <span - title="clipping region">clipping region</span>, and <span - title="dom-context-2d-globalCompositeOperation">global composition - operators</span>.</p> - - </li> - - </ol> - -v5DVT (also check for '- -' bits in the part above) --><p>The <dfn id="dom-context-2d-measuretext" title="dom-context-2d-measureText"><code>measureText()</code></dfn> + </ol><p>The <dfn id="dom-context-2d-measuretext" title="dom-context-2d-measureText"><code>measureText()</code></dfn> method takes one argument, <var title="">text</var>. When the method is invoked, the user agent must replace all the <span title="space character">space characters</span> in <var title="">text</var> with @@ -2686,10 +2392,10 @@ area of the canvas that the clipping region covers, not just the box given by the em square height and measured text width.</p> - <!-- v5: Drawing text along a given path --> - <!-- v5: Adding text to a path --> - <!-- see also: http://www.w3.org/TR/SVG11/text.html#TextpathLayoutRules --> - <!-- see also: http://developer.mozilla.org/en/docs/Drawing_text_using_a_canvas --> + + + + </div><p class="note">A future version of the 2D context API may provide a way to render fragments of documents, rendered using CSS, straight @@ -2698,7 +2404,7 @@ can be used.<p>This method can be invoked with three different sets of arguments:<ul class="brief"><li><code title="">drawImage(<var title="">image</var>, <var title="">dx</var>, <var title="">dy</var>)</code> <li><code title="">drawImage(<var title="">image</var>, <var title="">dx</var>, <var title="">dy</var>, <var title="">dw</var>, <var title="">dh</var>)</code> <li><code title="">drawImage(<var title="">image</var>, <var title="">sx</var>, <var title="">sy</var>, <var title="">sw</var>, <var title="">sh</var>, <var title="">dx</var>, <var title="">dy</var>, <var title="">dw</var>, <var title="">dh</var>)</code> - </ul><!-- v3: drawImage() of an ImageData object might make sense (when resizing as well as filtering) - ack Charles Pritchard --><p>Each of those three can take either an + </ul><p>Each of those three can take either an <code>HTMLImageElement</code>, an <code>HTMLCanvasElement</code>, or an <code>HTMLVideoElement</code> for the <var title="">image</var> argument.<dl class="domintro"><dt><var title="">context</var> . <code title="dom-context-2d-drawImage"><a href="#dom-context-2d-drawimage">drawImage</a></code>(<var title="">image</var>, <var title="">dx</var>, <var title="">dy</var>)</dt> @@ -2710,7 +2416,7 @@ <p>Draws the given image onto the canvas. The arguments are interpreted as follows:</p> - <p><img alt="The sx and sy parameters give the x and y coordinates of the source rectangle; the sw and sh arguments give the width and height of the source rectangle; the dx and dy give the x and y coordinates of the destination rectangle; and the dw and dh arguments give the width and height of the destination rectangle." height="356" src="http://www.w3.org/TR/html5/images/drawImage.png" width="356"></p> + <p><img alt="The sx and sy parameters give the x and y coordinates of the source rectangle; the sw and sh arguments give the width and height of the source rectangle; the dx and dy give the x and y coordinates of the destination rectangle; and the dw and dh arguments give the width and height of the destination rectangle." height="356" src="http://dev.w3.org/html5/spec/images/drawImage.png" width="356"></p> <p>If the first argument isn't an <code>img</code>, <code>canvas</code>, or <code>video</code> element, throws a @@ -2735,21 +2441,19 @@ <code>HTMLImageElement</code>, <code>HTMLCanvasElement</code>, or <code>HTMLVideoElement</code>. If the <var title="">image</var> is null, the implementation must raise a <code>TYPE_MISMATCH_ERR</code> - exception.</p> <!-- createPattern() has an equivalent paragraph --> + exception.</p> <p>If the <var title="">image</var> argument is an <code>HTMLImageElement</code> object that is not <span title="img-good">fully decodable</span>, or if the <var title="">image</var> argument is an <code>HTMLVideoElement</code> object whose <code title="dom-media-readyState">readyState</code> attribute is either <code title="dom-media-HAVE_NOTHING">HAVE_NOTHING</code> or <code title="dom-media-HAVE_METADATA">HAVE_METADATA</code>, then the - implementation must return without drawing anything.</p> <!-- - createPattern() has an equivalent paragraph --> - + implementation must return without drawing anything.</p> <p>If the <var title="">image</var> argument is an <code>HTMLCanvasElement</code> object with either a horizontal dimension or a vertical dimension equal to zero, then the implementation must raise an <code>INVALID_STATE_ERR</code> exception.</p> - <!-- createPattern() has an equivalent paragraph --> + <p>The source rectangle is the rectangle whose corners are the four points (<var title="">sx</var>, <var title="">sy</var>), (<span title=""><var title="">sx</var>+<var title="">sw</var></span>, <var title="">sy</var>), (<span title=""><var title="">sx</var>+<var title="">sw</var></span>, <span title=""><var title="">sy</var>+<var title="">sh</var></span>), (<var title="">sx</var>, <span title=""><var title="">sy</var>+<var title="">sh</var></span>).</p> @@ -2771,10 +2475,7 @@ <p>The original image data of the source image must be used, not the image as it is rendered (e.g. <code title="attr-dim-width">width</code> and <code title="attr-dim-height">height</code> attributes on the source element have no effect). The image data must be processed in the - original direction, even if the dimensions given are negative. <!-- - remove that last sentence if it causes confusion. Someone once - suggested that 5,5,-2,-2 was different than 3,3,2,2; this is trying - to clarify that this is no the case. --></p> + original direction, even if the dimensions given are negative. </p> <p class="note">This specification does not define the algorithm to use when scaling the image, if necessary.</p> @@ -2791,18 +2492,14 @@ filtering algorithm requires a pixel value from outside the original image data, it must instead use the value from the nearest edge pixel. (That is, the filter uses 'clamp-to-edge' behavior.)</p> - <!-- see CORE-32111 and: - http://krijnhoetmer.nl/irc-logs/whatwg/20100818#l-737 - http://www.w3.org/Bugs/Public/show_bug.cgi?id=10799#c11 - --> - <!-- createPattern() has a similar paragraph with different rules --> + <p>When the <code title="dom-context-2d-drawImage"><a href="#dom-context-2d-drawimage">drawImage()</a></code> method is passed an animated image as its <var title="">image</var> argument, the user agent must use the poster frame of the animation, or, if there is no poster frame, the first frame of the animation.</p> - <!-- createPattern() has an equivalent paragraph --> + <p>When the <var title="">image</var> argument is an <code>HTMLVideoElement</code>, then the frame at the <span>current @@ -2811,7 +2508,7 @@ <span title="concept-video-intrinsic-height">intrinsic height</span> of the <span>media resource</span> (i.e. after any aspect-ratio correction has been applied).</p> - <!-- createPattern() has an equivalent paragraph --> + <p>Images are painted without affecting the current path, and are subject to <a href="#shadows" title="shadows">shadow effects</a>, <a href="#dom-context-2d-globalalpha" title="dom-context-2d-globalAlpha">global alpha</a>, the <a href="#clipping-region" title="clipping region">clipping region</a>, and <a href="#dom-context-2d-globalcompositeoperation" title="dom-context-2d-globalCompositeOperation">global composition @@ -3241,7 +2938,7 @@ </script></pre> - </div><h2 class="no-num" id="references">References</h2><!--REFS--><p>All references are normative unless marked "Non-normative".</p><!-- Dates are only included for standards older than the Web, because the newer ones keep changing. --><dl><dt id="refsBEZIER">[BEZIER]</dt> + </div><h2 class="no-num" id="references">References</h2><p>All references are normative unless marked "Non-normative".</p><dl><dt id="refsBEZIER">[BEZIER]</dt> <dd><cite>Courbes à poles</cite>, P. de Casteljau. INPI, 1959.</dd> <dt id="refsCSS">[CSS]</dt> @@ -3250,12 +2947,7 @@ Hickson, H. Lie. W3C.</dd> <dt id="refsCSSCOLOR">[CSSCOLOR]</dt> - <!-- - <dd><cite><a href="http://www.w3.org/TR/css3-color/">CSS Color - Module Level 3</a></cite>, T. Çelik, C. Lilley, L. - Baron. W3C.</dd> - --> - <dd><cite><a href="http://dev.w3.org/csswg/css3-color/">CSS Color + <dd><cite><a href="http://dev.w3.org/csswg/css3-color/">CSS Color Module Level 3</a></cite>, T. Çelik, C. Lilley, L. Baron. W3C.</dd> @@ -3279,11 +2971,7 @@ 1984.</dd> <dt id="refsWEBIDL">[WEBIDL]</dt> - <!-- - <dd><cite><a href="http://www.w3.org/TR/WebIDL/">Web - IDL</a></cite>, C. McCormack. W3C.</dd> - --> - <dd><cite><a href="http://dev.w3.org/2006/webapi/WebIDL/">Web + <dd><cite><a href="http://dev.w3.org/2006/webapi/WebIDL/">Web IDL</a></cite>, C. McCormack. W3C.</dd> </dl><h2 class="no-num" id="acknowledgements">Acknowledgements</h2><p>For a full list of acknowledgements, please see the HTML5
Received on Thursday, 28 April 2011 18:00:32 UTC