返回顶部
首页 > 资讯 > 精选 >css3如何实现元素弧线运动
  • 588
分享到

css3如何实现元素弧线运动

2023-06-08 04:06:55 588人浏览 安东尼
摘要

这篇文章将为大家详细讲解有关css3如何实现元素弧线运动,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。如何使用CSS控制元素弧线运动我们都知道,CSS3的新属性transfrom过渡效果可以实现元素位移、

这篇文章将为大家详细讲解有关css3如何实现元素弧线运动,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

如何使用CSS控制元素弧线运动

我们都知道,CSS3的新属性transfrom过渡效果可以实现元素位移、旋转、缩放。结合animation属性,就可以实现元素的动画效果。但是如何通过css实现元素实现弧线运动呢:

css3如何实现元素弧线运动

如上图动画效果所示,圆球弧线运动,分析运动:

  • 将小球的运动拆分成X轴和Y轴两个运动来看,此时X轴的小球是以 (慢—快) 这样的速度运动;

  • 而Y轴的方向小球是以(快—慢)这样的速度运动;

  • 结合两个轴的运动,实现弧线效果

三次贝塞尔(Cubic Bezier)函数

animation属性中有一个 animation-timing-function 属性,动画的速度函数。而这个属性 使用名为三次贝塞尔(Cubic Bezier)函数的数学函数,来生成速度曲线。

css3如何实现元素弧线运动

cubic-bezier (x1,y1,x2,y2):(三次贝塞尔函数的具体含义请查阅相关资料):

css3如何实现元素弧线运动 
 

可以通过这个网站 传送门 去实时调节曲线的取值。而animation-timing-function属性中 已经提供了几个 已经封装好的速度函数:也就是我们常用的 ease、linear、ease-in、ease-out、ease-in-out。
 

css3如何实现元素弧线运动

效果实现

首先我们能想到的就是将X轴Y轴的位移动画拆开。但是一个元素的动画同一时间只能执行一个动画(最后申明的)。所以我们可以换位思考,用两个父子元素。给父级元素添加X轴位移动画,给子元素增加Y轴位移动画,具体代码如下:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>元素弧线运动</title>    <style>        .box{            width: 400px;            height: 400px;            border: 2px solid #ff8800;        }        span{            display: block;            width: 40px;            height: 40px;            border: 1px solid #222;            animation: center1 2s ease-in forwards;        }        span:after{            content: '';            display: block;            width: 40px;            height: 40px;            -WEBkit-border-radius: 20px;            -moz-border-radius: 20px;            border-radius: 20px;            background: greenyellow;            animation: center2 2s ease-out forwards;        }        @keyframes center1 {            to{transfORM: translateX(360px)}        }        @keyframes center2 {            to{transform: translateY(360px)}        }    </style></head><body><div class="box">    <span></span></div></body></html>

此时我用的是元素的伪类after替代了子元素,效果一样.给span一个给色border可以观察两个元素分别的运动轨迹,以便于观察,动画效果如下:

css3如何实现元素弧线运动

此时还是能比较明显的看出绿色小球是做的弧线运动。

扩展:

此时如果觉得弧线不够大不够明显,我们可以自己调整次贝塞尔(Cubic Bezier)函数的值。根据网站 传送门 。

  • 选择ease-in 的曲线效果,此时我们改变 x1,y1的值(将红色点向右拉)。然后复制此时的cubic-bezier()值。将这个值取代原本span的动画 ease-in 的位置。

  • 选择ease-out 的曲线效果,此时我们改变 x2,y2的值(将蓝色点向右拉)。然后复制此时的cubic-bezier()值。将这个值取代原本span伪类after 的动画 ease-out 的位置。

此时的CSS代码如下:

span{            display: block;            width: 40px;            height: 40px;            border: 1px solid #222;            animation: center1 2s cubic-bezier(.66,.01,1,1) forwards;        }        span:after{            content: '';            display: block;            width: 40px;            height: 40px;            -webkit-border-radius: 20px;            -moz-border-radius: 20px;            border-radius: 20px;            background: greenyellow;            animation: center2 2s cubic-bezier(0,0,.36,1) forwards;        }

而此时的动画效果的弧线,就更加的明显了:
 

css3如何实现元素弧线运动

关于“css3如何实现元素弧线运动”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: css3如何实现元素弧线运动

本文链接: https://lsjlt.com/news/251653.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • css3如何实现元素弧线运动
    这篇文章将为大家详细讲解有关css3如何实现元素弧线运动,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。如何使用CSS控制元素弧线运动我们都知道,CSS3的新属性transfrom过渡效果可以实现元素位移、...
    99+
    2023-06-08
  • 如何运用CSS3动画实现高亮光弧效果
    小编给大家分享一下如何运用CSS3动画实现高亮光弧效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!代码如下:<!Doct...
    99+
    2024-04-02
  • CSS3如何控制HTML元素实现动画效果
    本篇内容介绍了“CSS3如何控制HTML元素实现动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.对元素transform的控制代码...
    99+
    2023-07-04
  • css3如何实现元素的平移
    这篇文章主要讲解了“css3如何实现元素的平移”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css3如何实现元素的平移”吧! 在...
    99+
    2024-04-02
  • 如何使用CSS3伪元素实现自动打字动画
    这篇文章主要介绍了如何使用CSS3伪元素实现自动打字动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用CSS3伪元素实现的自动打字动画原...
    99+
    2024-04-02
  • css3如何实现元素过渡效果
    本文小编为大家详细介绍“css3如何实现元素过渡效果”,内容详细,步骤清晰,细节处理妥当,希望这篇“css3如何实现元素过渡效果”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 ...
    99+
    2024-04-02
  • css3如何实现元素左右翻转
    这篇文章主要介绍了css3如何实现元素左右翻转,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 方法:1、使用“a...
    99+
    2024-04-02
  • css3元素如何固定不滚动
    本文小编为大家详细介绍“css3元素如何固定不滚动”,内容详细,步骤清晰,细节处理妥当,希望这篇“css3元素如何固定不滚动”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 ...
    99+
    2024-04-02
  • 纯css如何实现元素下出现横线动画
    这篇文章主要介绍了纯css如何实现元素下出现横线动画,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。效果图:html: <div class='...
    99+
    2023-06-08
  • 如何使用css3实现轨迹运动
    这篇文章主要介绍如何使用css3实现轨迹运动,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!实现效果:实现代码:<div class="haorooms-dot &qu...
    99+
    2024-04-02
  • bootstrap中如何实现元素左浮动
    这篇文章将为大家详细讲解有关bootstrap中如何实现元素左浮动,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 在bootstrap中,可以...
    99+
    2024-04-02
  • jQuery如何实现动态创建元素?
    ...
    99+
    2024-04-02
  • css3如何控制元素隐藏
    这篇文章将为大家详细讲解有关css3如何控制元素隐藏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 控制方式:1、使用“display:non...
    99+
    2024-04-02
  • css3筛选如何除去第一个元素的元素
    本篇内容主要讲解“css3筛选如何除去第一个元素的元素”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css3筛选如何除去第一个元素的元素”吧! ...
    99+
    2024-04-02
  • CSS动画:如何实现元素的抖动效果
    CSS动画:如何实现元素的抖动效果摘要:CSS动画是网页设计中常用的一种效果,它能够为网页增加动态和生动的感觉。本文将介绍如何使用CSS动画实现元素的抖动效果,并附上具体的代码示例供参考。引言在网页设计中,动画效果能够吸引用户的注意力,增加...
    99+
    2023-11-21
    CSS动画 元素 抖动效果
  • css3如何设置子元素居中
    这篇文章主要讲解了“css3如何设置子元素居中”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css3如何设置子元素居中”吧! 方...
    99+
    2024-04-02
  • CSS3动画如何实现
    本篇内容主要讲解“CSS3动画如何实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“CSS3动画如何实现”吧!我们先来看看示例 注意: 这里呢,我们用 my...
    99+
    2024-04-02
  • css3如何实现动画
    css3实现动画的方法:1、在通过transition设置过渡,添加transform设置形状,从而可以实现动画效果;2、添加animation属性,设置动画效果即可。具体使用示例:通过transition设置过渡,添加transform设...
    99+
    2024-04-02
  • vue元素如何实现动画过渡效果
    这篇文章将为大家详细讲解有关vue元素如何实现动画过渡效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1 在 vue 中,使用 <transition> 标...
    99+
    2024-04-02
  • jquery如何实现元素向上滑动消失
    本文小编为大家详细介绍“jquery如何实现元素向上滑动消失”,内容详细,步骤清晰,细节处理妥当,希望这篇“jquery如何实现元素向上滑动消失”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作