这是两款效果非常炫酷的鼠标hover图片CSS3动画特效。特效中在鼠标hover图片的时候,使用transition和transform来制作图片说明文本和图标的CSS3动画特效。
使用方法
示例中使用了bootstrap和fontawesome字体图标,需要在页面中引入相关文件。
<link href="path/to/css/bootstrap.min.css" rel="stylesheet"> <link href="path/to/css/font-awesome.min.css" rel="stylesheet">
鼠标hover图片效果-1
第一个鼠标hover图片的效果如下图:
该效果的HTML结构如下:
<div class="container"> <div class="row"> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/1.jpg"> <div class="box-content"> <h3 class="title">超现实作品-1</h3> <span class="post">未来科技</span> <ul class="social"> <li><a href="#"><i class="fa fa-facebook"></i></a></li> <li><a href="#"><i class="fa fa-twitter"></i></a></li> <li><a href="#"><i class="fa fa-instagram"></i></a></li> <li><a href="#"><i class="fa fa-google-plus"></i></a></li> </ul> </div> </div> </div> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/2.jpg"> <div class="box-content"> <h3 class="title">超现实作品-2</h3> <span class="post">未来科技</span> <ul class="social"> <li><a href="#"><i class="fa fa-facebook"></i></a></li> <li><a href="#"><i class="fa fa-twitter"></i></a></li> <li><a href="#"><i class="fa fa-instagram"></i></a></li> <li><a href="#"><i class="fa fa-google-plus"></i></a></li> </ul> </div> </div> </div> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/3.jpg"> <div class="box-content"> <h3 class="title">超现实作品-3</h3> <span class="post">未来科技</span> <ul class="social"> <li><a href="#"><i class="fa fa-facebook"></i></a></li> <li><a href="#"><i class="fa fa-twitter"></i></a></li> <li><a href="#"><i class="fa fa-instagram"></i></a></li> <li><a href="#"><i class="fa fa-google-plus"></i></a></li> </ul> </div> </div> </div> </div> </div>
制作该动画特效的CSS3代码如下:
.box{ text-align: center; overflow: hidden; color: #fff; position: relative; } .box:after{ content: ""; width: 100%; height: 100%; background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.08) 69%, rgba(0, 0, 0, 0.76) 100%); position: absolute; top: 0; left: 0; transition: all 0.5s ease 0s; } .box:hover:after{ background: linear-gradient(to bottom, rgba(0, 0, 0, 0.01) 0%, rgba(0, 0, 0, 0.09) 11%, rgba(0, 0, 0, 0.12) 13%, rgba(0, 0, 0, 0.19) 20%, rgba(0, 0, 0, 0.29) 28%, rgba(0, 0, 0, 0.29) 29%, rgba(0, 0, 0, 0.42) 38%, rgba(0, 0, 0, 0.46) 43%, rgba(0, 0, 0, 0.53) 47%, rgba(0, 0, 0, 0.75) 69%, rgba(0, 0, 0, 0.87) 84%, rgba(0, 0, 0, 0.98) 99%, rgba(0, 0, 0, 0.94) 100%); } .box img{ width: 100%; height: auto; } .box .box-content{ width: 100%; padding: 20px; margin-bottom: 20px; position: absolute; bottom: 0; left: 0; z-index: 1; } .box .title{ font-size: 22px; font-weight: 700; text-transform: uppercase; margin: 0 0 10px 0; transform: translateY(145px); transition: all 0.4s cubic-bezier(0.13, 0.62, 0.81, 0.91) 0s; } .box .post{ display: block; padding: 8px 0; font-size: 15px; transform: translateY(145px); transition: all 0.4s cubic-bezier(0.13, 0.62, 0.81, 0.91) 0s; } .box:hover .title, .box:hover .post{ transform: translateY(0); } .box .social{ list-style: none; padding: 0 0 5px 0; margin: 40px 0 25px; opacity: 0; position: relative; transform: perspective(500px) rotateX(-90deg) rotateY(0deg) rotateZ(0deg); transition: all 0.6s cubic-bezier(0, 0, 0.58, 1) 0s; } .box:hover .social{ opacity: 1; transform: perspective(500px) rotateX(0deg) rotateY(0deg) rotateZ(0deg); } .box .social:before{ content: ""; width: 50px; height: 2px; background: #fff; margin: 0 auto; position: absolute; top: -23px; left: 0; right: 0; } .box .social li{ display: inline-block; } .box .social li a{ display: block; width: 40px; height: 40px; line-height: 40px; border-radius: 50%; background: #6d3795; font-size: 20px; color: #fff; margin-right: 10px; transition: all 0.3s ease 0s; } .box .social li a:hover{ background: #bea041; } .box .social li:last-child a{ margin-right: 0; } @media only screen and (max-width:990px){ .box{ margin-bottom: 30px; } }
鼠标hover图片效果-2
第二个鼠标hover图片的效果如下图:
该效果的HTML结构如下:
<div class="container"> <div class="row"> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/1.jpg"> <div class="box-content"> <h3 class="title">超现实作品-1</h3> <span class="post">未来科技</span> </div> <ul class="social"> <li><a href="#"><i class="fa fa-search"></i></a></li> <li><a href="#"><i class="fa fa-link"></i></a></li> </ul> </div> </div> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/2.jpg"> <div class="box-content"> <h3 class="title">超现实作品-2</h3> <span class="post">未来科技</span> </div> <ul class="social"> <li><a href="#"><i class="fa fa-search"></i></a></li> <li><a href="#"><i class="fa fa-link"></i></a></li> </ul> </div> </div> <div class="col-md-4 col-sm-6"> <div class="box"> <img src="img/3.jpg"> <div class="box-content"> <h3 class="title">超现实作品-3</h3> <span class="post">未来科技</span> </div> <ul class="social"> <li><a href="#"><i class="fa fa-search"></i></a></li> <li><a href="#"><i class="fa fa-link"></i></a></li> </ul> </div> </div> </div> </div>
制作第二种鼠标hover图片动画特效的CSS3代码如下:
.box{ text-align: center; overflow: hidden; position: relative; } .box:after{ content: ""; width: 100%; height: 100%; background-color: rgba(0,63,91,0.6); position: absolute; top: 0; left: 0; opacity: 0; transition: all 0.5s ease 0s; } .box:hover:after{ opacity: 1; } .box img{ width: 100%; height: auto; } .box .box-content{ width: 100%; background: #255773; padding: 10px 0; color: #d5f7ff; position: absolute; bottom: -100%; left: 0; z-index: 1; transition: all 0.5s ease 0s; } .box:hover .box-content{ bottom: 0; } .box .title{ font-size: 22px; font-weight: 700; margin: 0 0 8px 0; text-transform: uppercase; } .box .post{ display: block; font-size: 15px; text-transform: capitalize; } .box .social{ width: 100%; list-style: none; padding: 0; margin: 0; position: absolute; top: 0; left: 0; z-index: 1; } .box .social li{ display: inline-block; margin-right: 7px; position: relative; transform: translateY(-100px); transition: all 0.5s ease 0s; } .box:hover .social li:first-child{ transition-delay: 0.5s; } .box:hover .social li:last-child{ transition-delay: 0.8s; } .box .social li:before{ content: ""; position: absolute; width: 1px; height: 50px; background: #f1e7c3; top: 0; left: 0; right: 0; margin: 0 auto; } .box:hover .social li{ transform: translateY(0); } .box .social li a{ display: block; width: 40px; height: 40px; line-height: 40px; border-radius: 50%; background: #f1e7c3; font-size: 20px; font-weight: 700; color: #003f5b; margin-top: 50px; opacity: 1; transition: all 0.3s ease 0s; } .box:hover .social li a{ opacity: 1; } .box .social li a:hover{ background: #ff9420; color: #fff; } @media only screen and (max-width:990px){ .box{ margin-bottom: 30px; } }