-
Notifications
You must be signed in to change notification settings - Fork 132
SVG 2 new features
Nikos Andronikos edited this page Aug 5, 2016
·
15 revisions
I'd like to move this into a proper matrix where we can list implementer feedback and support, but for now here's a basic list of what is new in SVG 2.
Note: this list is now mostly complete, but is still being tidied up
This list:
- Tries to describe new features and new behaviours
- Does not list features moved from one SVG spec to another (e.g. SVG Tiny 1.2 to SVG 2)
- Mesh gradient shape element and paint server
- Hatch path paint server
- 'context-fill' and 'context-stroke' values for 'fill' and 'stroke' These allow, for example, markers to inherit the stroke color.
- Marker auto-start-reverse
Has implementations in Firefox, WebKit, Blink, and Inkscape - Path features:
- Auto-closing paths.
- New line joins (miter-clip, arcs)
- Added bearing path commands 'B' and 'b'
- Allow closepath commands 'Z' and 'z' to fill in missing data from previous commands
- z-index support
- non-scaling-size, non-rotation, and fixed-position as options for vector-effect
- 'paint-order' property to control stroke and fill drawing order
- Allow markers on all shapes
- Allow scroll bars when overflow:scroll is set on svg elements
- Allow controlling radius of focal circle on radial gradients
- extend getBBox() with an argument that controls inclusion of fill or stroke
- Complete overhaul of text layout
- CSS based multi-line text:
- Text wrapping given a fixed width/height using inline-size.
- Text in a shape using the shape-inside and shape-subtract properties
- Text-on-a-path changes:
- Text on a shape.
- Text on either side of a path.
- Todo: Add more
- CSS based multi-line text:
- Text on a path changes:
- allow textPath element to directly specify path data through the path attribute
- Allow referencing basic shapes from textPath element
- Add 'side' attribute to textPath to enable control of which side of the path text is placed on
- Font features (alternative glyphs, etc.)
- Support @font-face rules on text element
- masks, filters and other graphics effects may now be applied to tspan and textPath elements
- support ::first-letter & ::first-line pseudo selectors on text element
- WOFF font support now required
- Use elements defined in terms of Web Components
- The root of the shadow tree is a ShadowRoot object.
- use elements may now reference an entire document
- Use element shadow trees now consist of actual SVGElement objects in a proper shadow DOM node tree, not SVGElementInstance pseudo-nodes.
- Events bubbling out of a use-element shadow tree must follow the shadow DOM re-targetting rules.
- Styles rules are resolved independently for clones versus the referenced graphics
- Some interactive animations are now triggered independently on the shadow content vs the referenced graphics.
- Never-rendered elements will now have a computed style of display: none
- The shadow tree must now have a ShadowRoot object, and implement extra functionality from shadow DOM specs.
- All elements in a subtree must now be cloned, not only graphics elements.
- The shadow tree has scoped stylesheets.
- Symbol elements can have x/y/width/height properties.
- Include WAI-ARIA attributes and define semantics
- Change role mapping for the ‘a’ element to depend on whether it is actually a valid link.
- ordering of systemLanguage preferences follows SMIL allowReorder definition
- Add lang attribute to replace xml:lang
- Require interactive user agents to include :focus and ::selection styles.
- clip and overflow no longer ignored when SVG document referenced via 'image'
- Allow bounding box are to be used for pointer-events via the 'bounding-box' value
- Replace SVG specific events with common equivalents
- unknown elements are treated as a 'g' or 'tspan' element
- Allow the 'script' element anywhere
- Allow 'animation elements' to be descended from the view element
- Allow the 'pathLength' attribute on all basic shapes
- Add 'text-decoration-fill' and 'text-decoration-stroke' properties
- Add left|middle|center keywords for refX and refY attributes
- Allow paint servers and markers to be a child element and referenced through child(n)
- Add additional attributes to the a element to synchronise with HTML
- Added tabindex attribute
- Update requirements for ‘id’ values to harmonize with HTML
- Whitespace now includes form feed (U+000C) to align with HTML and CSS
- Support white-space property in favour of xml:space attribute
- Support custom data attributes on all SVG elements
- Support percentages and CSS lengths in many places
- HTML link element supported and must load external style sheets
- Add crossorigin attribute to the image and script elements
- Inclusion of HTML audio, video, iframe, canvas, source, and track elements
- Made many attributes presentation attributes:
- 'd'
- what else?
- Convert some geometry attributes to 'geometry properties'
Geometry properties support lengths and percentages and auto:
- ellipse & circle: cx, cy
- circle: r
- ellipse: rx, ry
- svg, rect, image, foreignObject: x, y, width, height
- Support many properties defined by other specifications (list?)
- inner svg elements and foreignObject elements are no longer overflow:hidden by default
- SVG Root and foreignObject are no longer overflow:hidden by default
- Allow scroll bars to be shown for overflow:auto in special cases
- Remove DTD
- Removed SVG Fonts
- Removed externalResourcesRequired attribute
- Removed baseProfile and version attributes from the svg element
- Removed requiredFeatures attribute
- Removed the ‘contentStyleType’ attribute.
- Removed xml:base
- Removed defer keyword from preservedAspectRatio
- Removed the tref element
- removed the Alternate Glyph elements (altGlyph, altGlyphItem, glyphRef)
- Removed xlink:type, xlink:role, xlink:arcrole, xlink:show, and xlink:actuate attributes
- Removed the viewTarget attribute from the view element
- Remove contentScriptType attribute
- methods suspendRedraw, unsuspendRedraw, and unsuspendRedrawAll on SVGSVGElement
- rootElement attribute
- forceRedraw method on SVGSVGElement
- deselectAll method on SVGSVGElement
- xml:space
- xlink:href
- xlink:title
- selectSubString() method on SVGTextContentElement interface
- cursor element
To do: Draw up UML diagrams to show this info graphically
- Added "length" attribute and indexed property access to all list interfaces.
- Replace SVGMatrix with DOMMatrix or DOMMatrixReadOnly
- Replace SVGRect with DOMRect or DOMRectReadOnly
- Replace SVGPoint with DOMPoint or DOMPointReadOnly
- Moved members from SVGStylable and SVGLangSpace to SVGElement and removed those interfaces
- Added SVGGraphicsElement
- Moved members from SVGLocatable and SVGTransformable to SVGGraphicsElement and removed those interfaces
- Added SVGGeometryElement with isPointInFill and isPointInStroke methods
- Removed SVGExternalResourcesRequired interface
- Removed SVGColor and SVGICCCOlor interfaces
- Removed getPresentationAttribute method from SVGElement
- Add tabindex attribute, and focus and blur methods, to SVGElement
- Add activeElement attribute to Document
- SVGElement now inherits GlobalEventHandlers from HTML
- extend getBBox with an argument that controls inclusion of fill or stroke
- Remove xmlbase, xmllang, and xmlspace attributes from SVGElement interface
- Remove SVGViewSpec interface
- Remove getTransformToElement from SVGGraphicsElement
- Allow getCTM on outermost svg element
- Make animVal an alias for baseVal and no longer reflect animated value
- Added dataset attribute to SVGElement
- Moved methods pathLength, getTotalLength, and getPointAtLength to SVGGeometryElement
- Removed SVGElementInstance and SVGElementInstanceList interfaces
- Removed currentView and useCurrentView properties on SVGSVGElement
- Added SVGUnknownElement
- Removed the viewport attribute from SVGSVGElement
- SVGElement has been extended to replace the core functionality from SVGElementInstance.
- SVGSymbolElement now inherits from SVGGraphicsElement
- ShadowAnimation interface defined
- SVGStyleElement now implements LinkStyle
- Remove SVGPathSeg* interfaces
- Remove SVGAnimatedPathData interface
- Remove methods on SVGPatElement related to SVGPathSeg* and SVGAnimatedPathData
- Moved pathLength, getTotalLength() and getPointAtLength() on to SVGGeometryElement interface
- animatedPoints attribute of SVGAnimatedPoints now aliases the points attribute
- Remove SVGPaint interface
- Replace SVG specific events with common equivalents
- Define the SVGUseElementShadowRoot interface as an extension of the ShadowRoot interface, and require it to be used for use-element shadow trees