当前位置: 首页 > news >正文

BOOM:一款有趣的Javascript动画效果

BOOM:一款有趣的Javascript动画效果


实践出真知,有的时候看到一些有趣的现象就想着用自己所学的知识复现一下。

缘起

前几天在 github 上看到同事的一个这样的小项目,在 IOS 上实现了这样一个小动画效果,看上去蛮炫的,效果图:

我就寻思着,在浏览器环境下,用 Javascript 怎么实现呢?

在浓烈的好奇心驱使下,最终利用 Javascript 和 CSS3 完成了模仿上面的效果,通过调用方法,可以将页面上的图片一键爆炸,我给它起了个 boomJS 的名字,贴张效果图:

实现

我感觉效果还是可以的,因为没有使用 canvas ,所以无法取到图片上每个像素的颜色值。使用了一些比较讨(sha)巧(bi)的方法,下面简单讲讲如何实现的:

1、构造新图容器,隐藏原图

原本的图是 标签的图,一张整图,最终的效果当然不是在原图上 boom ,看上去连贯的动画本质上只是一个障眼法,利用 Javascript 做了一些巧妙的变换,所以第一步所做的就是取到原图的高宽及相对浏览器视窗的定位,再创建一个新的容器附着在原图之上,然后隐藏原图。

这个方法里面我主要用到了 getBoundingClientRect 这个方法,该方法返回元素的大小及其相对于视口的位置,完美满足我的需要。

嗯,这一步做了什么呢?简单的如下所示:

2、生成一张张是碎裂小图

最后效果是图片 boom 一下裂开,所以第二步要做的就是模拟出一小块一小块小图,这里每一个小块就是一个新的 div ,然后利用图片的定位 background-position 将其定位到合适的位置,嘿,看看效果:

可以看到,这里分割成了很多个小块,每个小块其实是一个 div 然后,这些小块被添加到我们上一步中设置的容器当中,然后利用原图设置 div 的背景图,所有 div 利用的都是原图一张背景图,接着图片定位就可以完成这样一个效果,说起来很简单,但是中间经历了很多计算,如何分割图片,图片的 width 与 height 比(是横图还是竖图),每个小块 div 的定位及小 div 背景图的定位,具体的可以到这里看看:boomJS。

最后为了好看,设置了圆角,但是这样爆炸的话,感觉不够真实,图片一块一块的清晰可辨。所以利用缩放 scale ,随机让每个小块放大或者缩小,再看看缩放后的效果:

嗯,模糊了很多,效果近一步增强,这样爆开来比较真实。

3、boom 爆炸!

嗯,到了鸡冻人心的最后一步,要做的就是给每一个 div 小块设置运动轨迹,然后同时爆开。

过程比较繁琐,需要先算出图片的中心点,然后每个 div 块点以中心为基准点向外做直线运动,不得不说,做这个我还特意恶补了一下高中的几何知识(囧)。为了效果更加真实,每个 div 块运动的直线距离添加一个正负值恰当的随机数,那么就可以达到有的块炸的比较远,有的块炸的比较近。利用未缩放的小块图片做一下大概的示意图:

最后在炸裂的瞬间,让每个小块渐变消失,就可以完成上面 Gif 所示的效果了。

总结一下,其实过程当中还有很多细节没有提及,比较重要的是动画触发的时序控制,因为最近在研读 jQuery 源码,就简单的利用了 jQuery 的队列来实现控制时序。

提到了就安利一下,我在 github 上关于 jQuery 源码的全文注解,感兴趣的可以围观一下。jQuery v1.10.2 源码注解。

然后本文没有贴代码,这个动画效果完整的代码在我的 github 上,有兴趣也可以围观一下:boomJSmJS

本文较短,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。


作者:佚名

来源:51CTO

相关文章:

  • Spark的三种集群deploy模式对比
  • 国际网络安全攻防盛宴——SSCTF线上赛顺利收官
  • 不懂编程和数据库也能创建表单
  • 20年来首次:英特尔痛失全球市场桂冠,智能芯片王者争霸AI致胜
  • ASP.NET MVC Preview生命周期分析
  • ie9下浏览器 cosole.log()会阻止j下面的s加载
  • .NET Core引入性能分析引导优化
  • OneDrive 消费者版本全面缩减免费存储容量
  • Oracle 为什么必须收购 Salesforce?
  • 杰和科技:深度客制,从根本上实现客户价值创造
  • 《Android程序设计》一第3章-3.0 Android应用的主要组件
  • Linux-权限管理(ACL权限)
  • Dom4j解析xml内容——(三)
  • javascript面向对象之创建对象
  • 由中序和后序重建二叉树
  • 【Leetcode】101. 对称二叉树
  • [译]Python中的类属性与实例属性的区别
  • Angular 4.x 动态创建组件
  • Centos6.8 使用rpm安装mysql5.7
  • CSS居中完全指南——构建CSS居中决策树
  • css系列之关于字体的事
  • hadoop入门学习教程--DKHadoop完整安装步骤
  • Js基础知识(一) - 变量
  • laravel5.5 视图共享数据
  • maya建模与骨骼动画快速实现人工鱼
  • SpringCloud(第 039 篇)链接Mysql数据库,通过JpaRepository编写数据库访问
  • 不发不行!Netty集成文字图片聊天室外加TCP/IP软硬件通信
  • 翻译 | 老司机带你秒懂内存管理 - 第一部(共三部)
  • 飞驰在Mesos的涡轮引擎上
  • 简单易用的leetcode开发测试工具(npm)
  • 利用DataURL技术在网页上显示图片
  • 聊聊flink的TableFactory
  • 学习HTTP相关知识笔记
  • [地铁译]使用SSD缓存应用数据——Moneta项目: 低成本优化的下一代EVCache ...
  • #数学建模# 线性规划问题的Matlab求解
  • #中国IT界的第一本漂流日记 传递IT正能量# 【分享得“IT漂友”勋章】
  • (52)只出现一次的数字III
  • (AngularJS)Angular 控制器之间通信初探
  • (超简单)使用vuepress搭建自己的博客并部署到github pages上
  • (六)Hibernate的二级缓存
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (转)全文检索技术学习(三)——Lucene支持中文分词
  • (轉貼) UML中文FAQ (OO) (UML)
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • .mat 文件的加载与创建 矩阵变图像? ∈ Matlab 使用笔记
  • .NET 8 中引入新的 IHostedLifecycleService 接口 实现定时任务
  • .NET 8.0 发布到 IIS
  • .NET C# 使用 SetWindowsHookEx 监听鼠标或键盘消息以及此方法的坑
  • .NET 简介:跨平台、开源、高性能的开发平台
  • .NET 命令行参数包含应用程序路径吗?
  • .NET/C# 判断某个类是否是泛型类型或泛型接口的子类型
  • .net企业级架构实战之7——Spring.net整合Asp.net mvc
  • .Net中的设计模式——Factory Method模式
  • @data注解_一枚 架构师 也不会用的Lombok注解,相见恨晚
  • @RunWith注解作用