实现效果:打开手机京东,可以看到首页的头部,以这个头部为基础,仿写一个类似的样式。

思路:仔细观察可以发现,手机京东的头部是以一个搜索栏和轮播特效组成的,而这个搜索栏是以轮播特效做为背景的,现在运用css3关键帧动画,可以实现这样的头部效果。

测试:首先,写一个简单的测试来验证思路是否正确,这样可以排除其他样式的干扰;测试如下:

   1.两个嵌套的div,内部div1以简单的文字和图片模拟的搜索栏

 <body>
<div class="diva">
<div class="div1">头部
<img src="../img/放大镜.png">
</div>
</div>
</body>

   2.由于动画的主要原理在于改变背景图片的位置,这里先介绍一下background-img,知道的同学自行跳过吧

    由url插入图片

         div{
width: 300px;
height: 200px;
background: red;
background-image: url(../img/放大镜.png);
}

    效果:

    很明显看到,背景图片的大小不适合div的宽高,所以,用background-size设置图片的宽高

 background-image: url(../img/放大镜.png);
background-size: 20px 30px;

    效果:

    因为背景图默认的设置是重复背景图片,所以更改为禁止重复

 background-image: url(../img/放大镜.png);
background-size: 20px 30px;
background-repeat: no-repeat; /*禁止图片重复*/

    效果:

    这个时候呢,假如想调整图片的位置,就需要设置图片的position

 background-image: url(../img/放大镜.png);
background-size: 20px 30px;
background-repeat: no-repeat; /*禁止图片重复*/
background-position: 100px 50px; /*这里设置的是px坐标,也可以用left或者百分比的形式设置图片位置*/

    效果:

   3.给外部diva设置宽度、背景色和边框,便于观察;给内部div1添加宽高和背景图片,注意这里div1的宽度是背景图片宽度的总和;当然,div1中的图片也要适当调整宽高。

          .diva{
width: 100%;
background: red;
border: 5px solid blue;
}
.div1{
width: 900px;
height: 200px;
background-image: url(../img/轮播1.jpg),url(../img/轮播2.jpg),url(../img/轮播3.jpg);
background-repeat: no-repeat;
background-size: 300px 200px;
background-position: 0 0,300px 0,600px,0;
}
.div1 img{
width: 20px;
height: 20px;
}

    大概就是这个效果啦

   4.将div1的宽度设置为一张图片的宽度,就定义一个相当于用户的可见窗口

               .div1{
width: 300px; /*设置div宽度为一张图片的宽度*/
height: 200px;
border: 10px solid green;
background-image: url(../img/轮播1.jpg),url(../img/轮播2.jpg),url(../img/轮播3.jpg);
background-repeat: no-repeat;
background-size: 300px 200px;
background-position: 0 0,300px 0,600px,0;
}

    效果:

    5.由于设置的窗口大小,剩余的两张图片不可见了,相当于屋子里面有三个人,你从一个窗口看进去,只看到了一个人,其他人被墙壁遮住了,这时如果这个人往左走,离开窗口,第二个人走到窗口位置,就可以看到第二个人了。

          .div1{
width: 300px; /*设置div宽度为一张图片的宽度*/
height: 200px;
border: 10px solid green;
background-image: url(../img/轮播1.jpg),url(../img/轮播2.jpg),url(../img/轮播3.jpg);
background-repeat: no-repeat;
background-size: 300px 200px;
/*background-position: 0 0,300px 0,600px,0;*/
background-position: -300px 0,0 0,300px,0; /*图片左移*/
}

    效果:

    6.当这三个人不断重复这种移动,就会对窗户外的你形成轮播效果,css3的关键帧动画就可以实现这种重复不断的移动,不了解的同学可以自行百度,这里就不细说关键帧动画原理了。

css3关键代码:

 .home{
width: 320px; /*为了适应iphone5的分辨率设置的宽度*/
height: 200px;
background: url(../img/轮播1.jpg),url(../img/轮播2.jpg),url(../img/轮播3.jpg),url(../img/轮播1.jpg);
/*第四张图片与第一张图片一致是为了轮播的时候效果更加自然,否则从最后一张播放到第一张会造成生硬的停顿*/ background-repeat: no-repeat;
background-size: 320px 200px;
animation: kbg 9s linear infinite;
/*调用kbg关键帧动画,动画时长为9s,匀速运动,无限循环播放(除非页面被关闭)*/
}
@keyframes kbg{
0%{
background-position: 0 0,320px 0,640px 0,960px 0;
}
5%{
background-position: 0 0,320px 0,640px 0,960px 0;
} 30%{
background-position: -320px 0,0 0,320px 0,640px 0;
}
40%{
background-position: -320px 0,0 0,320px 0,640px 0;
} 60%{
background-position: -640px 0,-320px 0,0 0,320px 0;
}
70%{
background-position: -640px 0,-320px 0,0 0,320px 0;
} 95%{
background-position: -960px 0,-640px 0,-320px 0,0 0;
}
100%{
background-position: -960px 0,-640px 0,-320px 0,0 0;
}
}

总结:关键帧轮播的视觉效果就和手机京东差不多,所缺的就是一些细节的地方。可能有人说网上的轮播器一大把,这样做是重复造轮子,但是我坚信学以致用,多练习才能理解和掌握知识要点。

题外话:

    小妹初来乍到,望大家捧个人场,多多评论指正,最好加个关注呢,期待和各位的交流~

css3关键帧动画实现轮播效果的更多相关文章

  1. 纯CSS焦点轮播效果-功能可扩展

    个人博客: http://mcchen.club 纯CSS3实现模拟焦点轮播效果,支持JQ等扩展各项功能.废话少说,直接贴代码. <!DOCTYPE html> <html> ...

  2. 基于css3的轮播效果

    花了一上午来调整页面在ie10上的显示问题,sass编译生成的css文件在ie内核下一直不能正确加载,果然兼容性的问题还需要好好研究.转入正题,用css3实现轮播效果主要是基于css3的framewo ...

  3. CSS3图片轮播效果

    原文:CSS3图片轮播效果 在网页中用到图片轮播效果,单纯的隐藏.显示,那再简单不过了,要有动画效果,如果是自己写的话(不用jquery等),可能要费点时间.css3的出现,让动画变得不再是问题,而且 ...

  4. 使用 jQuery 中的淡入淡出动画,实现图片的轮播效果,每隔 2 秒钟切换一张图片,共 6 张图片

    查看本章节 查看作业目录 需求说明: 使用 jQuery 中的淡入淡出动画,实现图片的轮播效果,每隔 2 秒钟切换一张图片,共 6 张图片,切换到第 6 张后从头开始切换,在图片的下方显示 6 个小圆 ...

  5. jQuery个性化图片轮播效果

    jQuery个性化图片轮播效果 购物产品展示:图片轮播器<效果如下所示> 思路说明: 每隔一段时间,实现图片的自动切换及选项卡选中效果,鼠标划入图片动画停止,划出或离开动画开始 两个区域: ...

  6. Android使用ViewPager实现左右循环滑动及轮播效果

    边界的时候会看到一个不能翻页的动画,可能影响用户体验.此外,某些区域性的ViewPager(例如展示广告或者公告之类的ViewPager),可能需要自动轮播的效果,即用户在不用滑动的情况下就能够看到其 ...

  7. Bootstrap插件之Carousel轮播效果(2015年-05月-21日)

    <!DOCTYPE html><html><head lang="en"><meta charset="UTF-8"& ...

  8. 针对淡入淡出的定时轮播效果js

    如果不使用jquery的fadeIn和fadeOut的接口和不适用animate情况下,如果要做用js实现淡入淡出轮播效果,我所想到的办法就是使用css3新特性transition(注意好兼容性). ...

  9. 点击轮播图片左右button,实现轮播效果

    点击左右button.实现图片轮播效果.js代码例如以下: $(function () { var index = 1; var pPage = 1; var $v_citemss = $(" ...

随机推荐

  1. [译]WPF MVVM 架构 Step By Step(5)(添加actions和INotifyPropertyChanged接口)

    应用不只是包含textboxs和labels,还包含actions,如按钮和鼠标事件等.接下来我们加上一些像按钮这样的UI元素来看MVVM类怎么演变的.与之前的UI相比,这次我们加上一个"C ...

  2. Java 9 揭秘(5. 实现服务)

    Tips做一个终身学习的人. Implementing Services 在这章中,主要介绍如下内容: 什么服务,服务接口,服务提供者: 在 JDK 9之前和在JDK 9中如何实现服务 如何使用Jav ...

  3. C/C++输入两个任意日期求相隔天数

    将两个日期转换成与一个指定日期(例1970-01-01)之间的差然后计算 思路: 两个日期相隔天数的计算,首先可以将两个日期转换成time_t(从指定日期至1970年1月1日0时0分0秒相隔的秒数), ...

  4. 【知识整理】这可能是最好的RxJava 2.x 入门教程(二)

    这可能是最好的RxJava 2.x入门教程系列专栏 文章链接: 这可能是最好的RxJava 2.x 入门教程(一) GitHub 代码同步更新:https://github.com/nanchen22 ...

  5. 2017最新技术java高级架构、千万高并发、分布式集群、架构师入门到精通视频教程

    * { font-family: "Microsoft YaHei" !important } h1 { color: #FF0 } 15套java架构师.集群.高可用.高可扩展. ...

  6. 网页标题title的闪动提示

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  7. php对数组中的键与值进行合并处理

    $res=array(); $re=array_count_values($month); foreach( $re as $k=>$v){ $arr['month_name'] = strva ...

  8. 如何用VMware打开vmdk文件

    vmdk文件是一个虚拟机备份文件!你可以在vmware新建一个任何类型的虚拟机,命名为“test”,在“我的文档”找到vmware的虚拟机目录“test”,在"test"目录中可以 ...

  9. shell 中最常使用的 FD (file descriptor)

    在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是: 0 是一个文件描述符,表示标准输入(stdin)1 是一个文件描述符,表示标准输出(stdout) ...

  10. 【Android Developers Training】 17. 停止和重启一个Activity

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...