我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何实现Javascript的BOOM动画效果

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何实现Javascript的BOOM动画效果

如何实现Javascript的BOOM动画效果,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

缘起

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

如何实现Javascript的BOOM动画效果

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

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

如何实现Javascript的BOOM动画效果

实现

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

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

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

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

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

如何实现Javascript的BOOM动画效果

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

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

如何实现Javascript的BOOM动画效果

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

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

如何实现Javascript的BOOM动画效果

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

3、boom 爆炸!

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

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

如何实现Javascript的BOOM动画效果

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

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

看完上述内容,你们掌握如何实现Javascript的BOOM动画效果的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何实现Javascript的BOOM动画效果

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

用JavaScript实现动画效果(转)

大家在使用Dreamweaver中的时间线功能或以做出很有趣的动画效果,Dreamweaver会自动为用户生成特定的程序代码,大家有没有想过动画的实现原理呢?其实原理是很简单的,主要是使用了一个计时器函数,下面我为大家  演示一个简单的动画
2023-06-03

用JavaScript实现动画效果 (转)

用JavaScript实现动画效果 (转)[@more@]主页: .NET">http://www.maxss.netEMail: maxss.net@163.com  大家在使用Dreamweaver中的时间线功能或以做出很有趣的动画效果
2023-06-03

jQuery如何实现动画效果?

jQuery提供了全面的动画函数,通过DOM操作和CSS修改来实现动画效果。DOM操作函数用于修改元素的属性、样式和内容,而CSS修改函数则用于设置和修改元素的CSS属性。jQuery还支持动画队列、动画事件以及高级动画技术,如过度、时间线和关键帧动画。这些功能使得创建动态和交互式网页变得容易,并提供了高度的灵活性、队列功能和广泛的兼容性。
jQuery如何实现动画效果?
2024-04-08

JavaScript动画原理之如何使用js进行动画效果的实现

在现在做页面很多时候都会用上动画效果,比如下拉菜单,侧边搜索栏,层的弹出与关闭等等,下面这篇文章主要给大家介绍了关于JavaScript动画原理之如何使用js进行动画效果实现的相关资料,需要的朋友可以参考下
2023-05-14

JavaScript+Canvas实现带跳动效果的粒子动画

这篇文章主要为大家详细介绍了如何通过JavaScript和Canvas实现带跳动效果的粒子动画,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下
2023-03-14

Android Flutter如何实现3D动画效果

这篇文章主要讲解了“Android Flutter如何实现3D动画效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android Flutter如何实现3D动画效果”吧!AnimatedW
2023-06-29

编程热搜

目录