返回顶部
首页 > 资讯 > 精选 >怎么在CSS中反转贝塞尔曲线
  • 653
分享到

怎么在CSS中反转贝塞尔曲线

2023-06-08 06:06:57 653人浏览 薄情痞子
摘要

今天就跟大家聊聊有关怎么在CSS中反转贝塞尔曲线,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。css是什么意思css是一种用来表现html或XML等文件样式的计算机语言,主要是用来设

今天就跟大家聊聊有关怎么在CSS中反转贝塞尔曲线,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

css是什么意思

css是一种用来表现html或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一种定义样式结构如字体、颜色、位置等的语言,并且css样式可以直接存储于HTML网页或者单独的样式单文件中,而样式规则的优先级由css根据这个层次结构决定,从而实现级联效果,发展至今,css不仅能装饰网页,也可以配合各种脚本对于网页进行格式化。

首先来看一看我之前写的一个CSS轮播动画效果,为了让切换时动画的过渡更加的平滑我在animation-timing-function属性中并没有使用CSS提供的各种关键词,而使用了cubic-bezier(贝塞尔)函数。

怎么在CSS中反转贝塞尔曲线

贝塞尔函数乍一看会让人困惑摸不着头脑,但如果使用得当,它可以为动画的用户体验增添一种更棒的感觉。

在构建这个轮播动画的时候,我意识到当我给一页添加了显示的贝塞尔函数时,它前一页隐藏的贝塞尔函数则是反向的。我觉得我们分享这篇文章的内容是非常值得的,因为创建一个贝塞尔曲线并反转它可能看起来很棘手,但实际上非常的简单。

了解基础的easing

首先,Easing这个词用来描述元素动画在时间线上的加速与减速节奏。我们可以将其绘制成一个图表,其中x轴是时间,y轴是动画的进度。linear是没有加速或减速(一直以相同的速度移动)的图形,表现在图上就是一条直线:

怎么在CSS中反转贝塞尔曲线

非线性的Easing会让动画更自然、更逼真。我们可以对CSS中的transition和animation应用各种的easing,我们可以将这些值设置在transition-timing-function或者animation-timing-function属性上。总共有五个关键字可以设置:

  • linear – 上面已经介绍了

  • ease-in – 动画开始时很慢,并随着它的进行而加速。

  • ease-out – 动画开始很快,最后减速。

  • ease-in-out – 动画开始缓慢,中间加速,最后减速。

  • ease – 默认值,与ease-in-out的动画过程相反。

了解cubic-bezier

如果上面介绍的关键字值都不适合我们的动画,我们可以使用cubic-bezier贝塞尔函数创建自定义的曲线。下面是一个例子:

.my-element {  animation-name: slide;  animation-duration: 3s;  animation-timing-function: cubic-bezier(0.45, 0.25, 0.60, 0.95);}

我们可以将这些属性简写为一个,如下所示:

.my-element {  animation: slide 3s cubic-bezier(0.45, 0.25, 0.60, 0.95);}

你会注意到cubic-bezier贝塞尔函数有四个值。这四个值是绘制曲线所需的两对坐标。这些坐标代表什么意思呢?如果你使用过Illustrator,那么控制曲线大小和方向的向量点对你来说就会很熟悉。这就是我们用cubic-bezier贝塞尔函数绘制曲线所必须的点。

我们并不需要知道贝塞尔曲线背后的所有数学知识。因为有大佬为我们创建了方便的工具,例如LeaVerou的cubic-bezier.com,这个网站中我们可以可视化的创建一条贝塞尔曲线并复制它的坐标点值。我的轮播效果的贝塞尔曲线就是用这个工具创建的,它看起来是这样的:

怎么在CSS中反转贝塞尔曲线

在这里,可以看到我们需要的两个点:cubic-bezier(x1, y1, x2, y2)。

怎么在CSS中反转贝塞尔曲线

在正反两个方向上应用easing

上面的轮播图中应用了正反两个方向的动画 - 单击左箭头时,当前项目向右滑出视图,同时下一个项目向左滑入;如果点击右箭头,就会发生相反的情况。我最初的假设是,可以简单地反转动画使项目以相反方向滑出,如下所示:

.my-element--reversed {  animation: slide 3s cubic-bezier(0.45, 0.25, 0.60, 0.95) reverse;}

这里有一个问题:给animation添加reverse也反转了easing曲线!所以,现在我的动画在一个方向看起来很好,但在反方向上是不对的。

下面的演示中,第一个框显示正方向的动画,第二个框显示添加reverse后的情况。

怎么在CSS中反转贝塞尔曲线

你可以看到这两个动画的感觉完全不一样。第一个盒子在开始加速,并且随着动画的进展缓慢地减速,而第二个盒子开始时相当缓慢,然后在停止之前有一个加速的过程。

我们有两种方法来解决这个问题:

  • 创建一个新的keyframe animation来显示动画,然后设置为相同的easing。对于简单的动画这样设置无可厚非,但是如果遇到复杂的动画该怎么办呢?创建反向的动画需要做更多的工作,而且很容易出错。

  • 我们可以使用相同的keyframe animation(并设置animation-direction:reverse)并反转贝塞尔曲线,这样就实现了在正反两个方向上使用同一个easing的效果。这种方法并不难。

反转贝塞尔曲线,对应在坐标轴中就是将整体图形旋转180度:

怎么在CSS中反转贝塞尔曲线

通过简单的数学计算就可以得到反转后的点坐标,具体方法是:交换两个坐标点,并将每个值都用1减去。

例如,正方向的坐标是:x1, y1, x2, y2

那么,反方向的坐标就通过下面的公式得出:(1 - x2), (1 - y2), (1 - x1), (1 - y1)

在下面的演示中,第三个框是我们需要的效果:元素向相反的方向滑动,但是它与正方向的动画曲线是一样的。

怎么在CSS中反转贝塞尔曲线

我们来看看如何计算反向的贝塞尔曲线。

用CSS自定义属性来计算反向曲线

我们可以使用CSS自定义属来计算新的曲线!首先将每个值赋给一个变量:

:root {  --x1: 0.45;  --y1: 0.25;  --x2: 0.6;  --y2: 0.95;    --originalCurve: cubic-bezier(var(--x1), var(--y1), var(--x2), var(--y2));}

然后我们可以使用这些变量来计算新值:

:root {  --reversedCurve: cubic-bezier(calc(1 - var(--x2)), calc(1 - var(--y2)), calc(1 - var(--x1)), calc(1 - var(--y1)));}

现在,如果我们对第一组变量做任何的更改,反向曲线点将会被自动计算出来。为了在检查和调试代码时更容易发现问题,我喜欢将这些新值分配到它们自己的变量中:

:root {    --x1: 0.45;  --y1: 0.25;  --x2: 0.6;  --y2: 0.95;    --originalCurve: cubic-bezier(var(--x1), var(--y1), var(--x2), var(--y2));      --x1-r: calc(1 - var(--x2));  --y1-r: calc(1 - var(--y2));  --x2-r: calc(1 - var(--x1));  --y2-r: calc(1 - var(--y1));    --reversedCurve: cubic-bezier(var(--x1-r), var(--y1-r), var(--x2-r), var(--y2-r));}

现在剩下的就是将新的曲线应用到反向动画中:

.my-element--reversed {  animation: slide 3s var(--reversedCurve) reverse;}

看完上述内容,你们对怎么在CSS中反转贝塞尔曲线有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: 怎么在CSS中反转贝塞尔曲线

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

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

猜你喜欢
  • 怎么在CSS中反转贝塞尔曲线
    今天就跟大家聊聊有关怎么在CSS中反转贝塞尔曲线,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设...
    99+
    2023-06-08
  • 贝塞尔曲线、Path、PathMeasure理解在Android中
     1. 贝塞尔曲线在数学上的理解    3 点确定一断曲线,对于二阶贝塞尔曲线    在t 时间内,    从p0 到  q    从q  到 p1 上的点的连线,对应的切线,...
    99+
    2022-06-06
    path 贝塞尔 贝塞尔曲线 Android
  • Android怎么自定义view贝塞尔曲线
    这篇文章主要介绍了Android怎么自定义view贝塞尔曲线的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android怎么自定义view贝塞尔曲线文章都会有所收获,下面我们一起来看看吧。贝塞尔曲线以一个简单的...
    99+
    2023-07-02
  • Android怎么用Canvas绘制贝塞尔曲线
    这篇文章主要介绍了Android怎么用Canvas绘制贝塞尔曲线的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Android怎么用Canvas绘制贝塞尔曲线文章都会有所收获,下面我们一起来看看吧。用Canvas...
    99+
    2023-07-02
  • 怎么在Android应用中实现一个贝塞尔曲线
    这篇文章给大家介绍怎么在Android应用中实现一个贝塞尔曲线,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。贝塞尔曲线有一阶、二阶、三阶、N阶 一阶就是一条直线,有起点终点,没有控制点,对应方法就是canvas.dra...
    99+
    2023-05-31
    android 贝塞尔曲线 roi
  • android中贝塞尔曲线的应用示例
    前言: 贝塞尔曲线又称贝兹曲线,它的主要意义在于无论是直线或曲线都能在数学上予以描述。最初由保罗·德卡斯特里奥(Paul de Casteljau)于1959年运用德卡斯特里奥...
    99+
    2022-06-06
    示例 贝塞尔 贝塞尔曲线 Android
  • Android怎么自定义View绘制贝塞尔曲线
    本文小编为大家详细介绍“Android怎么自定义View绘制贝塞尔曲线”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android怎么自定义View绘制贝塞尔曲线”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。在...
    99+
    2023-07-02
  • Android怎么利用贝塞尔曲线绘制动画
    本篇内容主要讲解“Android怎么利用贝塞尔曲线绘制动画”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Android怎么利用贝塞尔曲线绘制动画”吧!彩虹系列通过动画控制绘制的结束点,就可以让贝...
    99+
    2023-06-30
  • 怎么用html5的canvas画布绘制贝塞尔曲线
    这篇文章主要介绍“怎么用html5的canvas画布绘制贝塞尔曲线”,在日常操作中,相信很多人在怎么用html5的canvas画布绘制贝塞尔曲线问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,...
    99+
    2024-04-02
  • 小程序怎么创建二次方贝塞尔曲线
    这篇文章主要讲解了“小程序怎么创建二次方贝塞尔曲线”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“小程序怎么创建二次方贝塞尔曲线”吧!canvasContext.quadraticCurveT...
    99+
    2023-06-26
  • 怎么用Android贝塞尔曲线绘制一个波浪球
    本篇内容介绍了“怎么用Android贝塞尔曲线绘制一个波浪球”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!效果如下所示:先来总结下 Wave...
    99+
    2023-06-30
  • 怎么用android实现贝塞尔曲线之波浪效果
    这篇文章主要介绍“怎么用android实现贝塞尔曲线之波浪效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么用android实现贝塞尔曲线之波浪效果”文章能帮助大家解决问题。1 前言贝塞尔曲线的...
    99+
    2023-07-02
  • OpenGL 实践中如何进行贝塞尔曲线绘制
    这篇文章给大家介绍OpenGL 实践中如何进行贝塞尔曲线绘制,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。说到贝塞尔曲线,大家肯定都不陌生,网上有很多关于介绍和理解贝塞尔曲线的优秀文章和动态图。以下两个是比较经典的动图...
    99+
    2023-06-04
  • Android中贝塞尔曲线的绘制方法示例代码
           贝塞尔曲线,很多人可能不太了解,什么叫做贝塞尔曲线呢?这里先做一下简单介绍:贝塞尔曲线也可以叫做贝济埃...
    99+
    2022-06-06
    示例 方法 贝塞尔 贝塞尔曲线 Android
  • 微信小程序怎么创建三次方贝塞尔曲线路径
    本篇内容介绍了“微信小程序怎么创建三次方贝塞尔曲线路径”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!canvasContext.bezier...
    99+
    2023-06-26
  • 怎么在Android应用中利用贝塞尔曲线实现一个购物车添加轨迹
    这期内容当中小编将会给大家带来有关怎么在Android应用中利用贝塞尔曲线实现一个购物车添加轨迹,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。效果如下:新建自定义View,重写构造方法,初始化Paint、...
    99+
    2023-05-31
    android 贝塞尔曲线 roi
  • Android自定义View绘制贝塞尔曲线中小红点的方法
    目录前言需求效果图代码主要问题简单画法使用贝塞尔曲线前言 上一篇文章用扇形图练习了一下安卓的多点触控,实现了单指旋转、二指放大、三指移动,四指以上同时按下进行复位的功能。今天这篇文章...
    99+
    2023-02-09
    Android绘制贝塞尔曲线 Android贝塞尔曲线小红点
  • CSS3贝塞尔曲线中如何实现链接悬停动画效果
    本篇内容介绍了“CSS3贝塞尔曲线中如何实现链接悬停动画效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!我们将使用 CSS3 动画过渡来创...
    99+
    2023-06-08
  • HTML5 Canvas中如何使用路径描画二阶、三阶贝塞尔曲线
    这篇文章主要介绍“HTML5 Canvas中如何使用路径描画二阶、三阶贝塞尔曲线”,在日常操作中,相信很多人在HTML5 Canvas中如何使用路径描画二阶、三阶贝塞尔曲线问题上存在疑惑,小编查阅了各式资料...
    99+
    2024-04-02
  • 使用Canvas怎么绘制一个贝赛尔曲线轨迹动画
    本篇文章为大家展示了使用Canvas怎么绘制一个贝赛尔曲线轨迹动画,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。二次贝赛尔曲线   function draw...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作