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垂直手风琴菜单
Jun 28 HTML / CSS
纯CSS3实现鼠标悬停提示气泡效果
Feb 28 HTML / CSS
使用CSS Grid布局实现网格的流动
Dec 30 HTML / CSS
css3编写浏览器背景渐变背景色的方法
Mar 05 HTML / CSS
使用html2canvas将页面转成图并使用用canvas2image下载
Apr 04 HTML / CSS
html5 canvas 使用示例
Oct 22 HTML / CSS
html5之Canvas路径绘图、坐标变换应用实例
Dec 26 HTML / CSS
HTML5和以前HTML4的区别整理
Oct 20 HTML / CSS
HTML5中的autofocus(自动聚焦)属性介绍
Apr 23 HTML / CSS
移动端HTML5实现文件上传功能【附代码】
Mar 25 HTML / CSS
HTML5本地数据库基础操作详解
Apr 26 HTML / CSS
css3 选择器
May 11 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调用shell的方法
2014/11/05 PHP
Yii框架通过请求组件处理get,post请求的方法分析
2019/09/03 PHP
laravel 根据不同组织加载不同视图的实现
2019/10/14 PHP
javascript GUID生成器实现代码
2009/10/31 Javascript
JQuery中getJSON的使用方法
2010/12/13 Javascript
javascript分页代码实例分享(js分页)
2013/12/13 Javascript
jquery map方法使用示例
2014/04/23 Javascript
js函数调用的方式
2014/05/06 Javascript
javascript实现信息增删改查的方法
2015/07/25 Javascript
jQuery实现的手机发送验证码倒计时效果代码分享
2015/08/24 Javascript
实例详解jQuery Mockjax 插件模拟 Ajax 请求
2016/01/12 Javascript
浅析Javascript中bind()方法的使用与实现
2016/04/29 Javascript
Angular 中 select指令用法详解
2016/09/29 Javascript
jQuery实现元素的插入
2017/02/27 Javascript
详解webpack2+node+react+babel实现热加载(hmr)
2017/08/24 Javascript
echarts同一页面中四个图表切换的js数据交互方法示例
2018/07/03 Javascript
微信小程序使用map组件实现检索(定位位置)周边的POI功能示例
2019/01/23 Javascript
Element Alert警告的具体使用方法
2020/07/27 Javascript
Django admin实现图书管理系统菜鸟级教程完整实例
2017/12/12 Python
Python实现的井字棋(Tic Tac Toe)游戏示例
2018/01/31 Python
flask入门之文件上传与邮件发送示例
2018/07/18 Python
python并发编程多进程 互斥锁原理解析
2019/08/20 Python
pytorch 实现张量tensor,图片,CPU,GPU,数组等的转换
2020/01/13 Python
详解python中各种文件打开模式
2020/01/19 Python
CSS3 RGBA色彩模式使用实例讲解
2016/04/26 HTML / CSS
Monnier Freres中文官网:法国领先的奢侈品配饰在线零售商
2017/11/01 全球购物
印度购买眼镜和太阳镜网站:Coolwinks
2018/09/26 全球购物
世界上最大的冷却器制造商:Igloo Coolers
2019/07/23 全球购物
全球最大化妆品零售网站:SkinStore
2020/10/24 全球购物
新年寄语大全
2014/04/12 职场文书
难忘的一天教学反思
2014/04/30 职场文书
横幅标语大全
2014/06/17 职场文书
工作失误检讨书(经典集锦版)
2014/10/17 职场文书
2016年大学生实习单位评语
2015/12/01 职场文书
python代码实现备忘录案例讲解
2021/07/26 Python