前言:css3中的animation方法,可以帮助我们实现图片自动播放的效果。
css3的动画属性:下列表格中列举出@keyframes规则和所有动画属性:
这些语法还有一种合并简写的方法:
什么是轮播图:在css这个阶段实现的轮播图其实是将n张图片左浮动横向并排放入一个div容器内,图片设置统一尺寸,div宽度设置n个图片的总尺寸,然后放入相框容器div,相框设置1个图片的大小并设置溢出隐藏,以保证正确显示一个照片。然后使用CSS3动画,通过对photos进行位移,从而达到显示不同的图片,每次偏移一个图片的宽度,即可显示下一张图片。
特别指出----在css阶段,我们常见的轮播图分为左右滑动式的和渐变式的。本文就是对这两种实现轮播图的方式进行讲解。
轮播图:
1.html的样式:
对于两种形式的轮播图在html中的框架结构是一样的,所以两个都采用轮播图的标准结构;
需要注意的是 在使用渐变式轮播图的时候为了让轮播图可以变得连贯顺畅,所以我们在末尾复制一份第一张图片,渐变式则不需要。
2.css样式:
基本的css的样式也是一样的:基本图片样式,保证图片大小尺寸统一,容器基础样式等;
上面介绍的这些基础的样式是一样的,下面我们讲解一下用什么样的方式来实现左右滑动式和渐变式的轮播图:
我们通过对ul添加动画的方式来实现轮播图的效果:
上面用到2D转换-translate来改变突变的位置,我们也可以通过left来改变图片的位置;
这样的动画每一阶段会过渡一张图片。
注意:合理按排好动画执行的时间,动画分为几个阶段,每个阶段过渡一张图片每次过渡需要多少时间。
1.
过渡完成后新的图片停留并展示一段时间
这个问题有两种解决思路
第一种就是通过animation-timing-function控制动画执行曲线,(我现在采用的方式),通过这种方式,就是上面代码中的这个
animation-timing-function: cubic-bezier(0, 1.04, 0, 0.99);
每个阶段的前面快速过渡大面积的动画,然后后面较长的时间内过渡小部分的剩余画面,从而实现一种假的静止状态.
2.
我们也可以通过上面的代码中一样,通过设定时间百分比时在两个时间段同时写一个距离就可以达到在一个位置停留的效果。
渐变式:
主要就是通过改变透明度来实现渐变轮播图的效果:
注意:1.因为我们是为每一张图片实现渐变的效果,所以我们给每一个li添加动画。
2.我们通过设置animation-delay也就是开始前停顿时间,通过对每个li添加不同的停顿时间,然后合理安排图片在动画的哪个阶段实现就能达到渐变的效果了,我在这里是采用动画开始时将图片隐藏然后在0-25%这个阶段使图片显示,然后再使他在后面的执行中消失,实现的,具体可以详细研究一下上面的代码.
以上就是我通过查阅资料和视频对css实现轮播图的理解