什么是CSS motion path模块?如何制作运动路径动画?

什么是css motion path模块?本篇文章和大家一起详细了解下css motion path模块,谈谈它的用法,介绍一下使用该模块如何制作简单和复杂的路径动画

什么是CSS motion path模块?如何制作运动路径动画?

CSS 中有一个非常有意思的模块 — CSS Motion Path Module Level 1,翻译过来也就是运动路径。本文将对 motion path 一探究竟,通过本文,你可以了解到:

什么是 CSS motion path使用 CSS motion path 制作简单路径动画使用 CSS motion path 制作复杂路径动画

什么是 CSS Motion Path 运动路径?

什么是 CSS Motion Path 运动路径?利用这个规范规定的属性,我们可以控制元素按照特定的路径进行位置变换的动画。并且,这个路径可以是非常复杂的一条路径。

在进一步介绍 CSS Motion Path 之前,我们先看看使用传统的 CSS 的能力,我们如何实现路径动画。

立即学习“前端免费学习笔记(深入)”;

CSS 传统方式实现直线路径动画

在之前,我们希望将一个物体从 A 点直线运动到 B 点,通常而言可以使用 transform: translate()top | left | bottom | right 或者 是 margin 之类的可以改变物体位置的属性。

简单的一个 Demo:

div {    width: 60px;    height: 60px;    background: #000;    animation: move infinite 1s alternate linear;}@keyframes move {    100% {        transform: translate(100px, 100px);    }}

对于简单的从 A 点直线运动到 B 点的效果如下:

1.gif

CSS 传统方式实现曲线路径动画

当然,CSS 也可以实现一些简单的曲线路径动画的。如果我们希望从 A 点运动到 B 点走的不是一条直线,而是一条曲线,该怎么做呢?

对于一些简单的圆弧曲线路径,还是可以借助一些巧妙的办法实现的,看看下面这个例子。

这次,我们使用了两个元素,子元素是希望被曲线运动的小球,但是实际上我们是通过设定了父元素的 transform-origin,让父元素进行了一个 transform: rotate() 的运动带动了子元素的小球:

.g-container {    position: relative;    width: 10vmin;    height: 70vmin;    transform-origin: center 0;    animation: rotate 1.5s infinite alternate;}.g-ball {    position: absolute;    width: 10vmin;    height: 10vmin;    border-radius: 50%;    background: radial-gradient(circle, #fff, #000);    bottom: 0;    left: 0;}@keyframes rotate {    100% {        transform: rotate(90deg);    }}

为了方便理解,在运动的过程中,我让父元素的轮廓显现出来:

2.gif

这样,我们算是勉强得到了一个非直线路径运动动画,它的实际运动轨迹是一条曲线。

然而,这基本上是之前 CSS 能做到的极限了,使用纯 CSS 的方法,没办法实现更复杂的路径动画,譬如下面这样一条路径动画:

2-2.gif

直到现在,我们有了一种更为强大的专门做这个事情的规范,也就是本文的主角 — CSS Motion Path

CSS Motion Path 实现直线路径动画

CSS Motion Path 规范主要包含以下几个属性:

offset-path:接收一个 SVG 路径(与 SVG 的path、CSS 中的 clip-path 类似),指定运动的几何路径offset-distance:控制当前元素基于 offset-path 运动的距离offset-position:指定 offset-path 的初始位置offset-anchor:定义沿 offset-path 定位的元素的锚点。 这个也算好理解,运动的元素可能不是一个点,那么就需要指定元素中的哪个点附着在路径上进行运动offset-rotate:定义沿 offset-path 定位时元素的方向,说人话就是运动过程中元素的角度朝向

下面,我们使用 Motion Path 实现一个简单的直线位移动画。

div {    width: 60px;    height: 60px;    background: linear-gradient(#fc0, #f0c);    offset-path: path("M 0 0 L 100 100");    offset-rotate: 0deg;    animation: move 2000ms infinite alternate ease-in-out;}@keyframes move {    0% {        offset-distance: 0%;    }    100% {        offset-distance: 100%;    }}

offset-path 接收一个 SVG 的 path 路径,这里我们的路径内容是一条自定义路径 path("M 0 0 L 100 100"),翻译过来就是从 0 0 点运动到 100px 100px 点。

offset-path 接收一个 SVG 路径,指定运动的几何路径。与 SVG 的path、CSS 中的 clip-path 类似,对于这个 SVG Path 还不太了解的可以戳这里先了解下 SVG 路径内容:SVG 路径

我们会得到如下结果:

3.gif

通过控制元素的 offset-distance0% 变化到 100% 进行元素的路径动画。

当然,上述的动画是最基本的,我可以充分利用 path 的特性,增加多个中间关键帧,稍微改造下上述代码:

div {    // 只改变运动路径,其他保持一致    offset-path: path("M 0 0 L 100 0 L 200 0 L 300 100 L 400 0 L 500 100 L 600 0 L 700 100 L 800 0");    animation: move 2000ms infinite alternate linear;}@keyframes move {    0% {        offset-distance: 0%;    }    100% {        offset-distance: 100%;    }}

这里最主要还是运用了 path 中的 L 指令,得到了如下图这样一条直线路径:

4.png

最终的效果如下,与利用 transform: translate() 添加多个关键帧类似:

5.gif

完整的 Demo :CodePen Demo — CSS Motion Path Demo

地址:https://codepen.io/Chokcoco/pen/gOgqoem

CSS Motion Path 实现曲线路径动画

上面的运动轨迹都是由直线构成,下面我们看看如何使用 CSS Motion Path 实现曲线路径动画。

其实原理还是一模一样,只需要在 offset-path: path() 中添加曲线相关的路径即可。

在 SVG 的 Path 中,我们取其中一种绘制曲线的方法 — 贝塞尔曲线,譬如下述这条 path,其中的 path 为 d="M 10 80 C 80 10, 130 10, 190 80 S 300 150, 360 80"

  

对应这样一条连续的贝塞尔曲线:

6.png

将对应的路径应用在 offset-path: path 中:

div:nth-child(2) {    width: 40px;    height: 40px;    background: linear-gradient(#fc0, #f0c);    offset-path: path('M 10 80 C 80 10, 130 10, 190 80 S 300 150, 360 80');}@keyframes move {    0% {        offset-distance: 0%;    }    100% {        offset-distance: 100%;    }}

可以得到如下运动效果:

7.gif

可以看到,元素是沿着贝塞尔曲线的路径进行运动的,并且,由于这次没有限制死 offset-rotate,元素的朝向也是跟随路径的朝向一直变化的。(可以联想成开车的时候,车头一直跟随道路会进行变化的,带动整个车身的角度变化)

完整的 Demo :CodePen Demo — CSS Motion Path Demo

地址:https://codepen.io/Chokcoco/pen/gOgqoem

理解 offset-anchor 运动锚点

OK,那么接下来,我们再看看 offset-anchor 如何理解。

还是上述的 DEMO,我们把小正方形替换成一个三角形,并且把运动的曲线给画到页面上,像是这样:

8.gif

其中,三角形是通过 clip-path 实现的:

    width: 40px;    height: 40px;    clip-path: polygon(0 0, 100% 50%, 0 100%);    background: linear-gradient(#fc0, #f0c);

9.png

通常而言,沿着曲线运动的是物体的中心点(类比 transform-origin),在这里,我们可以通过 offset-anchor 改变运动的锚点,譬如,我们希望三角形的最下方沿着曲线运动:

.ball {    width: 40px;    height: 40px;    clip-path: polygon(0 0, 100% 50%, 0 100%);    offset-path: path('M 10 80 C 80 10, 130 10, 190 80 S 300 150, 360 80');    offset-anchor: 0 100%;    background: linear-gradient(#fc0, #f0c);    animation: move 3000ms infinite alternate linear;}@keyframes move {    0% {        offset-distance: 0%;    }    100% {        offset-distance: 100%;    }}

10.gif

经过实测,Can i use 上写着 offset-anchor 属性的兼容性在为 Chrome 79+、Firefox 72+,但是实际只有 Firefox 支持,Chrome 下暂时无法生效~

完整的 Demo :CodePen Demo — CSS Motion Path offset-anthor Demo

地址:https://codepen.io/Chokcoco/pen/poRGZeE

运用 Motion Path 制作动画效果

OK,上面我们基本把原理给过了一遍,下面我们就看看,运用 Motion Path,可以在实践中如何运用。

利用 Motion Path 制作按钮效果

利用运动路径,我们可以制作一些简单的按钮点击效果。在之前,我在 CodePen 上见到过这样一种按钮点击效果:

11.gif

其原理是运用了 background-radial 去生成每一个小圆点,通过控制 background-position 控制小圆点的位移

详细的 Demo 代码:CodePen Demo — Bubbly button (Design by Gal Shir)

地址:https://codepen.io/Chokcoco/pen/bGGMLdd

但是小圆点的运动路径基本上都是直线,运用本文的 Motion Path,我们也可以实现一些类似的效果,核心代码如下,HTML 这里我们使用了 Pug 模板,CSS 使用了 SASS

.btn  -for(var i=0; i<60; i++)    span.dot
.btn {  position: relative;  padding: 1.5rem 4.5rem;}.btn .dot {  position: absolute;  width: 4px;  height: 4px;    @for $i from 1 through $count {     &:nth-child(#{$i}) {        top: 50%;        left: 50%;        transform: translate3d(-50%, -50%, 0) rotate(#{360 / $count * $i}deg);      }  }    &::before {    content: "";    position: absolute;    top: 0;    left: 0;    width: 4px;    height: 4px;    border-radius: 50%;    offset-path: path("M0 1c7.1 0 10.7 2 14.3 4s7.1 4 14.3 4 10.7-2 14.3-4 7.2-4 14.3-4 10.7 2 14.3 4 7.1 4 14.3 4 10.7-2 14.3-4 7.1-4 14.3-4 10.7 2 14.3 4 7.1 4 14.3 4 10.7-2 14.3-4 7.1-4 14.3-4 10.7 2 14.3 4 7.1 4 14.3 4");    offset-distance: 0;  }}.btn.is-animating:active .dot:nth-child(4n+1)::before {  animation: dot var(--animation-time) var(--animation-timging-function);}.btn.is-animating:active .dot:nth-child(4n+2)::before {  border: 1px solid var(--color-primary);  background: transparent;  animation: dot var(--animation-time) var(--animation-timging-function) 0.1s;}.btn.is-animating:active .dot:nth-child(4n+3)::before {  animation: dot var(--animation-time) var(--animation-timging-function) 0.2s;}.btn.is-animating:active .dot:nth-child(4n)::before {  border: 1px solid var(--color-primary);  background: transparent;  animation: dot var(--animation-time) var(--animation-timging-function) 0.3s;}@keyframes dot {  0% {    offset-distance: 0%;    opacity: 1;  }  90% {    offset-distance: 60%;    opacity: .5;  }  100% {    offset-distance: 100%;    opacity: 0;  }}

别看代码多有一点点复杂,但是不难理解,本质就是给每个子元素小点点设置同样的 offset-path: path(),给不同分组下的子元素设定不同的旋转角度,并且利用了动画延迟 animation-delay 设定了 4 组同时出发的动画。

这里我们的轨迹 path 不是直线,效果如下:

12.gif

完整的代码:CodePen Demo — Button Animation with CSS Offset Paths

地址:https://codepen.io/Chokcoco/pen/xxgMPzJ

利用 Motion-Path 绘制地图路径寻路动画

这个也是非常实用的,现在我们可以完全利用 CSS Motion-Path 实现地图上的寻路动画:

13.gif

该 Demo 源自 Ahmad Emran,完整的代码:CodePen Demo — CodePen Home Animation with offset-path | Only Using CSS & HTML

地址:https://codepen.io/ahmadbassamemran/pen/bXByBv

利用 Motion-Path 绘制路径动画

又或者,我们利用 Path 能绘制任意路径的特性,实现各种我们想要的路径,譬如加入购物车的抛物线,或者各类运动轨迹,都不在话下,这里再提供一个 Demo:

14.gif

CodePen Demo — CSS Motion Path offset-path animation

地址:https://codepen.io/Chokcoco/pen/dyNaZea

Can i Use – Motion-Path

来看看 Motion-Path 目前的兼容性如何?截止至 2021-04-27。

Can i Use – Motion-Path:

15.png

目前而言,除去 IE 浏览器,就等待 Safari 何时能够兼容了,具体是否使用,还需要根据目标群体浏览器使用情况进行取舍。

最后

好了,本文到此结束,介绍了运动路径动画 Motion Path,并且利用它实现了一些以往无法简单实现的路径动画效果,希望对你有帮助 :)

本文转载自:https://segmentfault.com/a/1190000039916159

作者:chokcoco

更多编程相关知识,请访问:编程视频!!

以上就是什么是CSS motion path模块?如何制作运动路径动画?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1620602.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 07:12:05
下一篇 2025年12月24日 07:12:16

相关推荐

  • 你值得了解的一种CSS获取图片主题色的小技巧(分享)

    本篇文章给大家分享一种利用 css 获取图片主题色的小技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 背景 起因是微信技术群里有个同学发问,有什么方法能够获取图片的主色呢?有一张图片,获取他的主色调: 利用获取到的这个颜色值,来实现类似这样的功能 — 容器中有一张…

    2025年12月24日 好文分享
    000
  • css3怎么将滚动条隐藏

    css3将滚动条隐藏的方法是,自定义滚动条的伪对象选择器【::-webkit-scrollbar】,例如【.element::-webkit-scrollbar { width: 0 !important }】。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 在…

    2025年12月24日
    000
  • 一起看看CSS filter中的那些神奇用途

    本篇文章带大家了解一下css filter 有哪些神奇用途。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 背景 基本概念 CSS filter 属性将模糊或颜色偏移等图形效果应用于元素形成滤镜,滤镜通常用于调整图像,背景和边框的渲染。它的值可以为 filter 函数 或使用 ur…

    2025年12月24日 好文分享
    000
  • 纯CSS3实现3d立体文字效果(源码分析)

    本篇文章带大家了解一下3d文字效果的实现原理,没有考虑代码的复用性和可移植性,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 1.单单纯纯的效果一 为了简化操作,我们使用和上一篇文章《纯CSS3文字效果推荐》一样的文档结构,后面的效果大差小不差,也就不再列出。 前端开发whqet …

    2025年12月24日 好文分享
    000
  • css3如何设置背景图片

    css3设置背景图片的方法是添加属性【background-image: url(css.jpg)】。background-image属性用来设置一个元素的背景图像,url中填写图像的url地址。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 如果我们要添加一张…

    2025年12月24日
    000
  • 使用css过渡有哪些触发方式

    触发方式有:1、通过伪类元素“:hover”触发,语法“元素{transition:属性 过渡时间}元素:hover{属性:属性值}”;2、通过“element.classList.add(“元素名称”)”语句触发css过渡效果。 本教程操作环境:windows7系统、CSS…

    2025年12月24日
    000
  • css3新增的伪类有哪些

    css3伪类:“:first-of-type”、“:last-of-type”、“:only-of-type”、“:only-child”、“:nth-child(2)”、“:enabled”、“:disabled”、“:checked”。 本教程操作环境:windows7系统、CSS3版、Dell…

    2025年12月24日
    000
  • 如何判断浏览器是否支持css3

    判断方法:1、使用“@supports”规则判断,语法格式“@supports(属性:值){标签名称{属性:值}}”2、使用“CSS.supports()”函数判断,语法格式“CSS.supports(“属性”,”值”)”。。 本教程操作环境:wind…

    2025年12月24日
    000
  • css3动画如何停止

    在css中,可以使用animation-play-state属性控制动画的暂停,语法“animation-play-state:paused”;该属性在不同浏览器的兼容性不同,需加上对应前缀(如“-ms-”,“ -webkit-”等)。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日 好文分享
    000
  • CSS3三角形如何实现不断放大

    本文给大家介绍css3三角形如何实现不断放大。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 CSS3三角形不断放大特效 图片预览 index.html代码 立即学习“前端免费学习笔记(深入)”; CSS3三角形不断放大特效 style.css代码 html {height: 10…

    2025年12月24日
    000
  • css3支持为网页添加多个背景图片吗

    css3支持为网页添加多个背景图片。在css中,可以通过直接在background-image属性中指定多个背景路径来为网页添加多个背景图片,语法格式“background-image: url(图片地址), url(图片地址)…;”。 本教程操作环境:windows7系统、CSS3&a…

    2025年12月24日
    000
  • css3中媒体查询的语法组成是什么

    媒体查询的语法组成是“@media not|only mediatype and (expressions) {CSS代码…;}”;媒体查询可由多种媒体组成,可以包含一个或多个表达式,表达式根据条件是否成立返回true或false。 本教程操作环境:windows7系统、CSS3&amp…

    2025年12月24日
    000
  • 用css3实现一个奥运五环

    css3实现奥运五环的方法:首先给5个div设置border-radius样式,制作五个圆环;然后使用position属性设置五个圆环的位置;最后使用z-index属性调整各环的层级关系即可。 本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。 五环…

    2025年12月24日
    000
  • css3中新增加的颜色模式有哪些

    css新增了3种颜色模式:1、RGBA模式,是在RGB模式上新增了Alpha透明度,例“rgba(255,0,0,0.5)”;2、HSL模式,例“hsl(360,50%,50%)”;3、HSLA模式,是在HSL模式上新增了Alpha透明度。 本教程操作环境:windows7系统、CSS3版、Dell…

    2025年12月24日
    000
  • 详解CSS3+SVG滤镜实现不规则边框的方法

    本篇文章将介绍一种配合 svg 滤镜实现各种不规则图形添加边框的小技巧。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 需求背景,给不规则图形添加边框 在我们日常开发中,时长会遇到一些非矩形、非圆形的图案。类似下面这些: 使用纯 CSS,搭配一些技巧,是可以制作出上面的图形的,当然…

    2025年12月24日 好文分享
    000
  • css怎么实现翻转效果

    css实现翻转效果的方法:首先创建一个演示方块,并为其添加transition和transform属性;然后将transition属性添加到需要翻转的p上;最后添加perspective和transform-style属性即可。 本文操作环境:Windows7系统、HTML5&&CS…

    2025年12月24日 好文分享
    000
  • 29个CSS面试题总结(知识点解析)

    本篇文章给大家分享29个css 面试知识点。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 CSS是层叠样式表( Cascading Style Sheets )的缩写,是一种样式表语言,用于描述以 HTML 之类的标记语言编写的文档的布局。 它是用于设计Web页面的三剑客之一,另…

    2025年12月24日
    000
  • CSS3如何实现流星雨效果?(代码示例)

    本篇文章给大家通过代码示例介绍一下使用css3如何实现流星雨效果。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【推荐教程:CSS视频教程】 说明:正文只讲述单个流星雨的实现方式,多个的效果只需要对单个的动画起始点、宽度稍加修改即可,具体示例见文末 github 地址。 难度系数…

    2025年12月24日
    000
  • 利用css实现一个抽奖动画效果

    首先我们先来看下最终的运行效果: 从效果图我们可以看到,抽奖会自动进行,并显示中奖信息。 这个效果基本是用CSS实现的,没有用图片,加一丢丢JS。完全没有考虑兼容性。 立即学习“前端免费学习笔记(深入)”; 具体步骤如下: 首先画一个转盘 幸运大转盘 /* 重置默认样式 */ * { margin:…

    2025年12月24日 好文分享
    000
  • css3中实现动画有哪两种方式

    css3中实现动画的两种方式分别是:1、分别利用transition属性和transform属性来设置过渡和形状;2、利用动画属性animation设置动画效果。 本文操作环境:windows10系统、css 3、thinkpad t480电脑。 1、利用transition设置过渡,添加trans…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信