[META] Implement Motion Path Module Level 1

NEW
Unassigned

Status

()

Core
Layout
P3
enhancement
2 years ago
14 hours ago

People

(Reporter: yiorsi, Unassigned)

Tracking

(Blocks: 1 bug, {dev-doc-needed, DevAdvocacy})

Trunk
dev-doc-needed, DevAdvocacy
Points:
---

Firefox Tracking Flags

(Not tracked)

Details

(Whiteboard: [DevRel:P2], URL)

Attachments

(1 attachment)

Comment hidden (obsolete)
(Reporter)

Comment 1

2 years ago
The editors' draft specification is available at
http://dev.w3.org/fxtf/motion-1/

Motion paths allow authors to animate elements along an author-specified path.

Motion path animation provides an easy way for authors to declaratively specify animation of an element along a sequence of lines, arcs or splines. This is a CSS equivalent to the animateMotion tag, but for all HTML and SVG elements. (animateMotion only works with SVG elements, and only in browsers that support SMIL.)

The following CSS properties are implemented and proposed for shipping:
motion-path: none | path(<string>)
motion-offset: <length> | <percentage>
motion-rotation: [ auto | reverse ] && <angle>
motion: <motion-path> && <motion-offset> && <motion-rotation>

When the motion-offset property is animated, for example using Web Animations, the element moves along the path.

When motion-rotation is 'auto' (the default), the element automatically rotates as it follows the path.


The following motion-path options from the spec are not implemented or proposing for shipping at this time:  <url> , <basic-shape> , <geometry-box> , path <fill-rule>

Updated

2 years ago
Severity: normal → enhancement
Component: Untriaged → CSS Parsing and Computation
OS: Unspecified → All
Product: Firefox → Core
Hardware: Unspecified → All
Version: 42 Branch → Trunk
Keywords: dev-doc-needed

Comment 2

2 years ago
@Astley Chen Are you going to support this feature?
(In reply to percyley from comment #2)
> @Astley Chen Are you going to support this feature?

It's under consideration now, would you like to share your thoughts against the spec stability and current support level of browsers ? Your feedback is welcome.

Comment 4

2 years ago
Created attachment 8753754 [details]
Chrome-test.png

Comment 5

2 years ago
Chrome 46+ and Opera 33+ support this, but not fully supported.

They only support motion-path: none|path(). See https://bug1186329.bmoattachments.org/attachment.cgi?id=8753754

I think the next CSS specification will have more SVG features, developers are also very much look forward to these characteristics, such as the recent mozilla implementation of the background-clip: text.

Comment 6

2 years ago
https://groups.google.com/a/chromium.org/forum/#!msg/blink-dev/N4o2MoV1zuw/zKZrE43Mp7EJ
There were significant changes to this specification agreed at the CSS working group's face-to-face meeting last week, to merge this specification with the polar positioning feature in CSS round display.  We should wait until those changes shake out before working on an implementation here.
Status: UNCONFIRMED → NEW
Ever confirmed: true

Comment 8

a year ago
The specification has now been greatly changed:

motion-offset -> offset-distance
motion-path -> offset-path
motion-rotation -> offset-rotation
motion -> offset

Add:

offset-position
offset-anchor

offset-path(motion-path) add <angle> and <size>

Chrome has fully implemented the new specification: https://groups.google.com/a/chromium.org/forum/#!msg/blink-dev/o1C5NzGf9Q0/sbaLF1MbAgAJ
Priority: -- → P3
Keywords: DevAdvocacy
Whiteboard: [DevRel:P2]
(In reply to percyley from comment #8)
> Chrome has fully implemented the new specification:
> https://groups.google.com/a/chromium.org/forum/#!msg/blink-dev/o1C5NzGf9Q0/
> sbaLF1MbAgAJ

As far as I can see, Chrome doesn't support the 'offset' shorthand as defined in the spec. yet.

Sebastian
Blocks: 1323667
Summary: Support CSS motion path animation → [META] Implement Motion Path Module Level 1

Updated

14 hours ago
Component: CSS Parsing and Computation → Layout
You need to log in before you can comment on or make changes to this bug.