CSS3实现任意图片lowpoly动画效果实例


Posted in HTML / CSS onMay 11, 2017

这是一个利用CSS3的动画属性实现的结合lowpoly(低多边形风格)的效果,主要利用了CSS3 transform属性的rotate旋转,translate移动,scale缩放,CSS代码部分非常简单,唯一有趣的是 nth-of-type选择器的使用,这里UI设计师小伙伴不用望而却步,CSS部分完全可以拿来复用并根据自己的要求随意改变参数(所有不能复用的SVG动画代码都是耍流氓),然后,UI设计师再搭配上自己熟悉的AI利器,就可以完美的实现下面的效果了。

CSS3实现任意图片lowpoly动画效果实例 

分步骤拆解:

1. 低多边形风格的图片的制作

我的原图是下面这种:

CSS3实现任意图片lowpoly动画效果实例 

随手从电脑上找了一张背景图,然后借助一个神器 Image Triangulator,不得不感慨,这个工具真是太好用了,各位设计师需要做的只是在图片上打点(我是为了测试,很粗糙的添加了顶点,如果需要得到很出彩的效果,需要在明暗分隔的边缘精细添加)。

CSS3实现任意图片lowpoly动画效果实例 

CSS3实现任意图片lowpoly动画效果实例 

CSS3实现任意图片lowpoly动画效果实例

然后导出的pdf格式的文件,就可以用AI打开了。

2. 图片的处理

这里在AI里需要一步重要的操作, “释放剪切蒙版” ,如果不进行这步操作,生成的SVG代码里会有大量的路径裁剪遮罩标签 <clipPath> 以及polygon的clip-path属性。

CSS3实现任意图片lowpoly动画效果实例 

释放剪切路径后选中图形就可以看到此时图片已经由一个个三角形色块组成了。

导出SVG代码可以看到密密麻麻的多边形标签 <polygon fill="" points=""/>

Image Triangulator生成lowpoly风格的图片;AI处理,释放剪切蒙版

此处需注意,这个软件生成的PDF是带未处理的底图的,SVG文件里有 <img> 标签,所以边缘那里可以多加几个点,或者截取掉一部分,防止边缘出现镂空。

3. 在线生成的低多边形背景图片的处理

如果需要的仅是一个背景图,建议使用网站 http://qrohlf.com/trianglify-generator/ ,可以自定义尺寸、颜色和晶格大小,支持生成SVG格式。比如下面这种:

CSS3实现任意图片lowpoly动画效果实例 

利用这个在线工具生成的图片不处理的话里面会是 <path> 路径标签,并且有描边属性,需要在AI里处理一下,全选,去掉所有的描边属性。此时,再导出的SVG文件就是对应的多边形标签 <polygon> 了。

截止到这一步,我们的图形处理部分就已经结束了,剩下的是动画效果的实现

4. CSS3动画

先说一下动画实现的初步设想。我希望这些已经生成的多边形碎片进行旋转、位移和尺寸的变化,这对CSS来说,也是很容易实现的一个效果,但我需要的是散布的不同效果,位移的方向不同,距离不同,缩放不同,可我这种JavaScript渣渣又不会写随机函数,还好CSS3提供了一个强大的选择器 nth-of-type(an+b) ,利用它,我可以赋予不同的多边形碎片不同的动画属性值。

简单了解一下nth-of-type(an+b),n从0开始取值,依次加1,所以你会得到第a+b个,2a+b个,3a+b个……元素。

比如,我希望我的 <polygon> 多边形分成6组,每组设定不同的动画属性,我的写法如下:

polygon:nth-of-type(6n+1){transform: translate(x , y) scale() rotate();}

这是顺序为6n+1(即1,7,13,19……)的多边形的动画效果,同理,下一组为polygon:nth-of-type(6n+2),即选择了第2,8,14,20……个多边形,依次向后推,直到polygon:nth-of-type(6n+6)

现在附上全部的代码及注释

结合下面的全部代码说一下:

<html>
<head>
<style>
/*以下为可复用的CSS代码部分*/
.cover{
position: absolute;
width: 800px;   
height: 445px;  
top: 20%;
left: 20%;
z-index: 2;
}
/*cover和svg的宽高位置都重合,唯一不同的是z-index属性*/
svg {
position: absolute;
width: 800px;   
height: 445px;      
top: 20%;
left: 20%;
overflow: visible;
z-index: 1;
}
polygon{
transition:all 1s ease;
transform-origin: 50% 50%;           
}
/*以下为设定的6组动画效果*/
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+1){
transform: translate(-400% , -400%) scale(1.5) rotate(100deg);
opacity: .3
}
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+2){
transform: translate(800% , -400%) scale(1.1) rotate(200deg);
opacity: .4;
}
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+3){
transform: translate(-800% , 400%) scale(1.2) rotate(200deg);
opacity: .3;
}
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+4){
transform: translate(-400% , 800%) scale(1.4) rotate(200deg);
opacity: .4
}
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+5){
transform: translate(400% , 400%) scale(1.3) rotate(100deg);
opacity: .3
}
.cover:hover + svg #lowpoly polygon:nth-of-type(6n+6){
transform: translate(800% , 400%) scale(1.2) rotate(200deg);
opacity: .3
}
</style></head>
<body><div class="cover"></div><!--定义的触发区域-->
<svg>
<g id="lowpoly">
……此处为若干<polygon>标签 即需要自行替换的部分
</g>
</svg></body></html>

由于SVG在执行动画效果后碎成满屏,如果我们的动画要设置成鼠标移入破碎,鼠标移出复原的效果,需要一个区域来进行动作的触发,这就是我们定义cover的意义,且层级属性要高于SVG属性。

CSS3实现任意图片lowpoly动画效果实例 

关于动画效果的触发,我用的是 :hover 鼠标经过,需要其他触发事件可以求助前端攻城狮。

svg的 overflow 属性一定要定义为可见 visible ,以确动画效果后超出svg尺寸的部分可见。

关于polygon的动画属性的设定,这种 transition:all 1s ease 表示所有的动画时间为1s,缓动效果。 transform-origin: 50% 50% 定义了变换的原点为每个元素自己的center。

关于6组不同的动画效果,我设定了位移translate,缩放scale,选择rotate以及透明度opacity的变化。

这里X轴和Y轴的位移,建议自己划定一个范围,值越大,扩散度越高,比如我的X和Y方向都是-800%~800%。另外关于旋转的角度,rotate(),为了符合物理规律,偏移的路径越远的旋转的角度更大,反之亦然。

如果你想设定更多的不同的效果,只需要改nth-of-type(an+b)中n的系数a就可以了。

如果懒得修改尝试,UI设计师在套用这个模板时,只需要把自己制作(或者自动生成)的 <polygon> 标签进行替换就可以。比如我们试一下把那张背景图套用进去,就能轻松得到下面这种动画效果。

CSS3实现任意图片lowpoly动画效果实例 

知识点总结

1.关于低多边形lowpoly风格图片的制作(重点为自己制作任意图形)

2.CSS3选择器nth-of-type(an+b)的使用  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
css3+jq创作含苞待放的荷花
Feb 20 HTML / CSS
传统HTML页面实现模块化加载的方法
Oct 15 HTML / CSS
canvas绘制文本内容自动换行的实现代码
Jan 14 HTML / CSS
HTML5中判断用户是否正在浏览页面的方法
May 03 HTML / CSS
CSS3 画基本图形,圆形、椭圆形、三角形等
Sep 20 HTML / CSS
基于canvas使用贝塞尔曲线平滑拟合折线段的方法
Jan 10 HTML / CSS
H5 video poster属性设置视频封面的方法
May 25 HTML / CSS
萌新的HTML5 入门指南
Nov 06 HTML / CSS
HTML通过表单实现酒店筛选功能
May 18 HTML / CSS
css3应用示例:新增的选择器
Mar 16 HTML / CSS
CSS 实现角标效果的完整代码
Jun 28 HTML / CSS
HTML页面点击按钮关闭页面的多种方式
Dec 24 HTML / CSS
利用纯CSS3实现文字向右循环闪过效果实例(可用于移动端)
Jun 15 #HTML / CSS
css3图片边框border-image的用法
Jun 30 #HTML / CSS
css3 border-radius属性详解
Jul 05 #HTML / CSS
详解纯CSS3制作的20种loading动效
Jul 05 #HTML / CSS
css3模拟jq点击事件的实例代码
Jul 06 #HTML / CSS
css3截图_动力节点Java学院整理
Jul 11 #HTML / CSS
css3过渡_动力节点Java学院整理
Jul 11 #HTML / CSS
You might like
php通过array_merge()函数合并关联和非关联数组的方法
2015/03/18 PHP
PHP+Ajax实现验证码的实时验证
2016/07/20 PHP
php实现的rc4加密解密类定义与用法示例
2018/08/16 PHP
JavaScript 学习笔记(十二) dom
2010/01/21 Javascript
5分钟理解JavaScript中this用法分享
2013/11/09 Javascript
纯JS实现根据CSS的class选择DOM
2014/03/22 Javascript
JS判断变量是否为空判断是否null
2014/07/25 Javascript
javascript实现禁止右键和F12查看源代码
2014/12/26 Javascript
js实现文字滚动效果
2016/03/03 Javascript
jQuery css() 方法动态修改CSS属性
2016/09/25 Javascript
js验证手机号、密码、短信验证码代码工具类
2020/06/24 Javascript
JavaScript模块化之使用requireJS按需加载
2017/04/12 Javascript
js运算符的一些特殊用法
2018/07/29 Javascript
vue2.0 中使用transition实现动画效果使用心得
2018/08/13 Javascript
vue+SSM实现验证码功能
2018/12/07 Javascript
[12:51]71泪洒现场!是DOTA2让经典重现
2014/03/24 DOTA
[01:03:54]Liquid vs IG 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
[01:54]TI珍贵瞬间系列(五):压力
2020/08/29 DOTA
Python使用正则匹配实现抓图代码分享
2015/04/02 Python
Python实现的计算马氏距离算法示例
2018/04/03 Python
Python调用.NET库的方法步骤
2019/12/27 Python
Python如何读写二进制数组数据
2020/08/01 Python
Manjaro、pip、conda更换国内源的方法
2020/11/17 Python
python爬虫beautifulsoup解析html方法
2020/12/07 Python
CSS3 Columns分列式布局方法简介
2014/05/03 HTML / CSS
CSS3 函数技巧 用css 实现js实现的事情(clac Counters Tooltip)
2017/08/15 HTML / CSS
基于MUI框架使用HTML5实现的二维码扫描功能
2018/03/01 HTML / CSS
购买瑞典当代设计的腕表和太阳眼镜:TRIWA
2016/10/30 全球购物
美国儿童服装、家具和玩具精品店:Maisonette
2019/11/24 全球购物
四川internet信息高速公路(C#)笔试题
2012/02/29 面试题
大学生文员专业个人求职信范文
2014/01/05 职场文书
个人评价范文分享
2014/01/11 职场文书
如何撰写岗位职责
2014/02/01 职场文书
网络编辑岗位职责范本
2014/02/10 职场文书
三问三解心得体会
2014/09/05 职场文书
社区三八妇女节活动总结
2015/02/06 职场文书