anime.js 实现带有描边动画效果的复选框(推荐)


Posted in Javascript onDecember 24, 2017

anime.js

anime.js是一个灵活的轻型JavaScript动画库。

它与CSS,个别变换,SVG,DOM属性和JS对象。

特征

  •  具体的动画参数
  •  具体目标值
  •  多个定时值
  •  播放控制
  •  运动路径

在网页或者是APP的开发中,动画运用得当可以起到锦上添花的作用。正确使用动画,不但可以有助于用户理解交互的作用,还可以大大提高网页应用的魅力和使用体验。并且在现在的网页开发中,动画已经成为了一个设计的标准,变得越来越重要。特别是在一些和用户交互的地方,使用动画能更好的?用户以反馈,提升用户的操作体验。

在网页开发中,有很多种技术来实现动画。在这篇文章中,我们使用anime.js这个轻量强大的javascript动画库来编写动画效果。使用它可以非常方便创建和管理动画。如果你还不是很熟悉这个库的使用方法,可以去看看以前写一篇入门文章。这篇文章主要是使用它来实现下面这个效果:

anime.js 实现带有描边动画效果的复选框(推荐)

这个动画效果非常简单,主要是有一个圆圈和一个白色的勾组成。使用CSS中的border-radius可以非常方便的创建这个圆。使用它可能比使用SVG来创建圆还要简单些并且代码量也少点,不过在这个效果中,由于那个白色的勾要用到SVG来实现,所以圆圈也使用SVG来实现。而且SVG现在变得越来越流行了,而且SVG是矢量可以随意放大缩小。下面就是这个圆圈的SVG代码:

<svg class="checkmark"
  xmlns="http://www.w3.org/2000/svg"
  width="32"
  height="32"
  viewBox="0 0 32 32">
 <circle class="circle"
   cx="16"
   cy="16"
   r="16"
   fill="#0c3"/>
</svg>

上面的代码简洁明了,主要是绘制了一个半径为16px的绿色的圆:

anime.js 实现带有描边动画效果的复选框(推荐)

先来实现一个简单的动画效果,把圆圈从无到有放大到完整的尺寸。要实现这个效果我们需要做两件事情:1、给圆圈一个类名;2、实例化一个anime.js的timeline,使用它来可以把多个动画效果组合在一起。当然你也不用timeline来创建动画效果,可以直接使用构造函数创建动画效果。不过使用timeline的好处是,可以更加方便的管理动画,比如各个效果之间的衔接和延迟等,我们可以更精细的控制动画效果。这里的缩放效果,直接是缩放这个SVG来实现的,代码如下所示:

var checkTimeline = anime.timeline({ autoplay: true, direction: 'alternate', loop: true });
checkTimeline
 .add({
 targets: '.checkmark',
 scale: [
  { value: [0, 1], duration: 600, easing: 'easeOutQuad' }
 ]
 })

简单解释下这段代码,首先定义了anime的一个实例,并且通过autoplay、direction和loop定义了动画是自动播放并且是一直循环交替来执行动画。通过targets参数来制定要执行动画的元素即checkmark,从0到1进行缩放,动画时间是600毫秒,还定义了动画的运动曲线。

anime.js 实现带有描边动画效果的复选框(推荐)

在动画制作中,动画执行的周期时间的选择也是一个非常需要关注的点。一方面,我们都不希望用户等待的太久,这样会降低整个的交互体验,使用户在交互的过程中感到迟钝。另一方面,我们也不希望用户在操作的过程中,一切的交互行为马上发生,这样也会显的突兀。在这个实例中,整个放大缩小的动画周期还是有一点点长,当然在开发阶段,适当的延长点有利于调试。但是在实际生产环境中,UI动画还是越简单越好。所以在动画开发中,就是要不断地通过调试来达到理想的状态。实际上配合一些动画曲线工具,可以使动画的体验更加的舒服自然,这里可以参考下Google的一个动画曲线的指南。

使用曲线在动画开发中是一个必不可少的一部分,它可以使动画的体验更加舒服自然。在实际开发中,为不同类型的动画选择不同的动画曲线也是做动画时,必须要注意的一点。曲线选择也受制于具体动画的场景,比如形状与形状之间的动画,抛物线运动等等,总而言之就是要复合物理运动的一个规律。在CSS3中经常使用的运动曲线是ease-in、ease-out和ease-in-out这三个,比如ease-out表示缓出动画,缓出使动画在开头处比线性动画更快,还会在结尾处减速。ease-out缓入动画,缓入动画开头慢结尾快,与缓出动画正好相反。一般在UI界面动画中,适合使用缓出动画即ease-out。所以,在这个复选框的动画实例中,适合使用缓出动画。

接下来是勾的动画。像勾这类的形状通常由SVG中的路径(path)来实现。具体路径的详细介绍,可以去这篇文章看看。在实际开发中,一般都是使用诸如AI或者是Inkscape等矢量设计工具来设计,然后导出SVG格式。具体到这个勾,实现起来也非常简单,三个锚点就可以实现一个勾的形状。最后设置linecap的属性的值为2.5px来实现勾的两端的圆角效果。

这里要注意的一点的是:要在整个设计过程中,遵守一定的设计原则。比如在这个效果中,一致性就是一个重要的设计原则。如果在静态的图形中,使用了圆角,那么在动画中最好也要保持这个圆角。当然你也可以使用方的角。总之,在整个过程中,请保持UI的一致性。

anime.js 实现带有描边动画效果的复选框(推荐)

导出来代码如下:

<path class="check"
  d="M9 16l5 5 9-9"
  fill="none"
  stroke="#fff"
  stroke-width="2.5"
  stroke-linecap="round">

和圆整合一下,效果如下:

anime.js 实现带有描边动画效果的复选框(推荐)

现在看起来还不错,只剩下最后一步就是这个勾要做一个绘制的动画效果。使用SVG实现描边动画效果讲了很多了。在anime.js中,实现一个描边绘制动画也非常简单,它提供了anime.setDashoffset这个方法来计算路径(path)的长度,使用它就可以实现一个绘制的动画效果。代码如下:

checkTimeline
 .add({ ... }) /* Previous steps */
 .add({
 targets: '.check',
 strokeDashoffset: {
  value: [anime.setDashoffset, 0],
  duration: 700,
  delay: 200,
  easing: 'easeOutQuart'
 }

还是老套路,先选择要做动画的元素。后面是来设置路径(path)的dashoffset的值,初始的值整个路径(path)的长度,整个路径是在画布外的不可见;通过anime.setDashoffset方法,把它的值设置为0,出现在画布中,就可以实现绘制动画效果。

最后还通过设置勾的transform来移动它的位置,使它居于圆圈的中心位置。

OK,一个带有动画效果的复选框就完成了!可以发现使用anime.js来开发动画效果还是很简单的。

anime.js 实现带有描边动画效果的复选框(推荐)

总结

以上所述是小编给大家介绍的anime.js 实现带有描边动画效果的复选框(推荐),希望对大家有所帮助。

Javascript 相关文章推荐
通用于ie和firefox的函数 GetCurrentStyle (obj, prop)
Dec 27 Javascript
javascript CSS画图之基础篇
Jul 29 Javascript
javascript Keycode对照表
Oct 24 Javascript
javascript 判断中文字符长度的函数代码
Aug 27 Javascript
鼠标经过显示二级菜单js特效
Aug 13 Javascript
js判断是否为ie的方法小结
Jan 13 Javascript
JS实现漂亮的淡蓝色滑动门效果代码
Sep 23 Javascript
Jquery实现$.fn.extend和$.extend函数
Apr 14 Javascript
详解js几个绕不开的事件兼容写法
Aug 30 Javascript
基于ajax和jsonp的原生封装(实例)
Oct 16 Javascript
vue keep-alive请求数据的方法示例
May 16 Javascript
javascript 原型与原型链的理解及实例分析
Nov 23 Javascript
vue项目常用组件和框架结构介绍
Dec 24 #Javascript
JavaScript数组排序reverse()和sort()方法详解
Dec 24 #Javascript
JS生成随机打乱数组的方法示例
Dec 23 #Javascript
JavaScript实现的超简单计算器功能示例
Dec 23 #Javascript
Angular实现较为复杂的表格过滤,删除功能示例
Dec 23 #Javascript
Vue.js 的移动端组件库mint-ui实现无限滚动加载更多的方法
Dec 23 #Javascript
9种使用Chrome Firefox 自带调试工具调试javascript技巧
Dec 22 #Javascript
You might like
PHP调用.NET的WebService 简单实例
2015/03/27 PHP
php计算整个目录大小的方法
2015/06/01 PHP
php成功操作redis cluster集群的实例教程
2019/01/13 PHP
PHP框架实现WebSocket在线聊天通讯系统
2019/11/21 PHP
Jquery替换已存在于element上的event的方法
2010/03/09 Javascript
js几个验证函数代码
2010/03/25 Javascript
jquery DOM操作 基于命令改变页面
2010/05/06 Javascript
把input初始值不写value的具体实现方法
2013/07/04 Javascript
javascript实现链接单选效果的方法
2015/05/13 Javascript
详细分析JavaScript变量类型
2015/07/08 Javascript
使用jQuery获取data-的自定义属性
2015/11/10 Javascript
js实现统计字符串中特定字符出现个数的方法
2016/08/02 Javascript
浅谈js中子页面父页面方法 变量相互调用
2016/08/04 Javascript
JavaScript实现的反序列化json字符串操作示例
2018/07/18 Javascript
微信小程序定位当前城市的方法
2018/07/19 Javascript
Angular实现svg和png图片下载实现
2019/05/05 Javascript
jqGrid表格底部汇总、合计行footerrow处理
2019/08/21 Javascript
原生js实现轮播图特效
2020/05/04 Javascript
JS箭头函数和常规函数之间的区别实例分析【 5 个区别】
2020/05/27 Javascript
Vue在H5 项目中使用融云进行实时个人单聊通讯
2020/12/14 Vue.js
[02:19]DOTA2上海特级锦标赛 观赛指南 Spectator Guide
2016/02/04 DOTA
python模块之re正则表达式详解
2017/02/03 Python
Python实现定时任务
2017/02/08 Python
python web基础之加载静态文件实例
2018/03/20 Python
python修改list中所有元素类型的三种方法
2018/04/09 Python
mac下如何将python2.7改为python3
2018/07/13 Python
对python多线程SSH登录并发脚本详解
2019/02/14 Python
浅谈Python描述数据结构之KMP篇
2020/09/06 Python
大学毕业登记表自我鉴定
2013/10/09 职场文书
中学生班主任评语
2014/01/30 职场文书
四年级评语大全
2014/04/21 职场文书
离婚协议书标准格式
2014/10/04 职场文书
前台接待岗位职责
2015/02/03 职场文书
2015年村计划生育工作总结
2015/04/28 职场文书
用python删除文件夹中的重复图片(图片去重)
2021/05/12 Python
设置IIS Express并发数
2022/07/07 Servers