大家好,今天小编来为大家解答以下的问题,关于css好看的动画代码,css代码基础这个很多人还不知道,现在让我们一起来看看吧!
一、css如何实现无限轮播图动画(代码示例)
本篇文章给大家带来的内容是如何实现自动无限播放的轮播图动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。
在之前的文章【css如何实现图片的旋转展示效果】中介绍了手动无限轮播图的制作,本篇我们来看看自动无限轮播图动画的制作。下面我们就来看看动画效果是如何实现的。
HTML与之前文章里的示例非常相似。我们要有一个动画发生的舞台(#stage),一个将会旋转的div容器和一系列图像:
<div id="rotator" style="-webkit-animation-name: rotator;">
<a href="1.jpg"><img src="1.jpg" width="140"></a>
<a href="2.jpg"><img src="2.jpg" width="140"></a>
<a href="3.jpg"><img src="3.jpg" width="140"></a>
<a href="4.jpg"><img src="4.jpg" width="140"></a>
<a href="5.jpg"><img src="5.jpg" width="140"></a>
<a href="6.jpg"><img src="6.jpg" width="140"></a>
<a href="7.jpg"><img src="7.jpg" width="140"></a>
<a href="8.jpg"><img src="8.jpg" width="140"></a>
</div>内联样式属性引用下面的动画@keyframes。它需要内联而不是CSS,以便我们能够使用JavaScript停止和重新启动动画。
CSS样式用于定位多张照片,首先围绕y轴旋转它们(垂直向上翻页),然后径向向外平移:
-webkit-perspective-origin: 0 50%;
-webkit-backface-visibility: hidden;
#rotator a:nth-of-type(1) img{
-webkit-transform: rotateY(-90deg) translateZ(300px);
#rotator a:nth-of-type(2) img{
-webkit-transform: rotateY(-60deg) translateZ(300px);
#rotator a:nth-of-type(3) img{
-webkit-transform: rotateY(-30deg) translateZ(300px);
#rotator a:nth-of-type(4) img{
-webkit-transform: translateZ(300px);
#rotator a:nth-of-type(5) img{
-webkit-transform: rotateY(30deg) translateZ(300px);
#rotator a:nth-of-type(6) img{
-webkit-transform: rotateY(60deg) translateZ(300px);
#rotator a:nth-of-type(n+7){ display: none;}照片设置-81px的值代表向左移动,使前向照片在旋转轴上居中。距离是图像宽度的一半(140px/ 2)加上LHS图像填充(10px)和边框(1px)。
该阶段需要设置立体的动画,舞台从页面的中心开始,因此旋转元素下的锚元素需要向后移动以使动画居中。
我们只开始准备六张照片,左边三张,中间一张,右边两张。最左侧的照片(位置1)从左侧开始,因此仅在第一次旋转后才可见。
当照片旋转时,它会消失(显示:无),并且新照片会附加到左侧,准备从位置1旋转。在7和更高的位置可以有任意数量的照片。只有当它们移动到可见位置时,它们才会出现。
甚至可以在动画进行时使用Ajax加载新照片。
正如我们之前尝试的那样,不是将照片轮旋转整整360度,而是我们实际做的只是旋转30度(足以从一张照片到下一张照片):
from{-webkit-transform: rotateY(0deg);}
to{-webkit-transform: rotateY(30deg);}
-webkit-transform-origin: 0 0;
-webkit-transform-style: preserve-3d;
-webkit-animation-timing-function: cubic-bezier(1, 0.2, 0.2, 1);
-webkit-animation-duration: 1s;
-webkit-animation-play-state: paused;
}要使关键帧在其他浏览器中工作,请复制所有样式,替换-webkit- with-moz-和-ms-,如下面的示例代码块所示。
动画完成后,它会触发一个JavaScript事件,您可以在下一节中阅读该事件。事件处理程序沿着照片移动,以便在动画重置时,而不是回到初始状态,照片都围绕圆圈移动了一步。
为了更清楚地了解正在发生的事情,中心照片已在下面的演示中突出显示。在动画发生时,您将看到突出显示的节点旋转,然后重置回起始位置,但包含不同的照片。
我们在此示例中需要JavaScript来检测动画何时结束,以便协调通过车轮重置移动的照片。没有这个,轮子只会在前两张照片之间交替出现。
document.addEventListener("DOMContentLoaded", function(){
var rotateComplete= function(){
target.style.webkitAnimationName="";
target.insertBefore(arr[arr.length-1], arr[0]);
el.style.webkitAnimationName="rotator";
var target= document.getElementById("rotator");
var arr= target.getElementsByTagName("a");
target.addEventListener("webkitAnimationEnd", rotateComplete, false);
}, false);对于每个WebKit样式和其他引用,存在Firefox(-moz-或Moz),Opera(-o-或O),甚至Internet Explorer(-ms-或ms)的替代品-我们必须忍受的混乱直到标准最终确定。
要在Safari,Chrome,Firefox,Opera和Internet Explorer 10中使用此功能,我们需要包含以下额外的设置:
var rotateComplete= function(){
webkitAnimationName= MozAnimationName= msAnimationName="";
target.insertBefore(arr[arr.length-1], arr[0]);
webkitAnimationName= MozAnimationName= msAnimationName="rotator";
var target= document.getElementById("rotator");
var arr= target.getElementsByTagName("a");
target.addEventListener("webkitAnimationEnd", rotateComplete, false);
target.addEventListener("animationend", rotateComplete, false);
target.addEventListener("MSAnimationEnd", rotateComplete, false);目前尚不清楚为何需要setTimeout。我们不需要它来设置延迟,因为使用CSS完成,但没有setTimeout(甚至0ms)动画无法重新触发。
这只是横向的轮播,在之后的文章【css实现三面立体旋转无限轮播图动画】里会在本篇文章的基础上改进轮播方式,制作不一样的的轮播图动画。
二、css3动画之如何添加多种变换效果(代码示例)
1、本篇文章给大家带来的内容是css3动画之如何添加多种变换效果(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。
2、在之前的文章【css3动画之transform属性与transition属性的简单使用】中介绍了添加一种变换效果实现简单动画变换的方法,但是只有一种变换效果的动画太单调了,如何添加多种变换效果?下面我们就给大家介绍添加多种变换效果的方法。
3、首先我们来看看一个元素多种变换是什么样的?
4、左侧的框开始为小而绿色的方形角,而右侧的框较大,带有红色边框和圆角。将鼠标悬停在任一框上触发动画,使方框1呈现方框2的外观,反之亦然。
5、同样,我们仍然只使用HTML和CSS来实现这一目标。如果没有CSS变换,两个框仍然会改变它们的边框颜色,也可能是边框半径,但它会立即发生,而不是一秒钟动画。
6、其实很简单,要将多个转换应用于单个元素,只需使用空格一个接一个地列出它们。例:
7、<div id="submenu"></div>css代码:
8、-webkit-transition: 1s ease-in-out;
9、-moz-transition: 1s ease-in-out;
10、-o-transition: 1s ease-in-out;
11、-webkit-transform: rotate(360deg) scale(2);
12、-moz-transform: rotate(360deg) scale(2);
13、-o-transform: rotate(360deg) scale(2);
14、-ms-transform: rotate(360deg) scale(2);
15、 transform: rotate(360deg) scale(2);
16、}请注意,IE10现在不使用转换前缀,但转换仍然需要-ms-。
17、这意味着当你将鼠标悬停在方框上时,它将在一秒钟内更改颜色,旋转(rotate)和加倍(scale),如下所示:
18、transform属性控制元素的旋转,缩放,移动,倾斜;
19、transition属性实现元素的过渡效果,让元素从一个状态到另一个状态,正真动起来;
20、考虑到兼容性,需要使用前缀:-webkit-,-moz-,-o-,-ms-。
三、如何通过css样式来实现网站logo发光动画效果
.logo-site,.logo-sites{position:relative;float:left;margin:18px 0 0 10px;width:220px;max-height:50px;overflow:hidden;transition-duration:.5s}
.logo-site img,.logo-sites img{width:220px;max-height:50px}@media screen and(max-width:480px){
.logo-site,.logo-sites{width:140px}}@media screen and(min-width:900px){
.logo-site:before{content:"";position:absolute;left:-665px;top:-460px;width:220px;height:15px;background-color:rgba(255,255,255,.5);-webkit-transform:rotate(-45deg);-moz-transform:rotate(-45deg);-ms-transform:rotate(-45deg);-o-transform:rotate(-45deg);transform:rotate(-45deg);-webkit-animation:searchLights 1s ease-in 1s infinite;-o-animation:searchLights 1s ease-in 1s infinite;animation:searchLights 1s ease-in 1s infinite}}@-webkit-keyframes searchLights{0%{left:-100px;top:0}to{left:120px;top:100px}}@-o-keyframes searchLights{0%{left:-100px;top:0}to{left:120px;top:100px}}@-moz-keyframes searchLights{0%{left:-100px;top:0}to{left:120px;top:100px}}@keyframes searchLights{0%{left:-100px;top:0}to{left:120px;top:100px}}
.site-title{font-size:24px;font-size:2.4rem;font-weight:700;padding:0 0 2px 0}
.site-name{display:none}@media screen and(min-width:900px){
.logo-site img,.logo-sites img{transition-duration:.8s}
把css代码当中的logo-site改成你网站包围logo的css即可(f12键审核元素,即可找到你的logo的css元素)。找到你logo的css名称然后把上面的css代码修改成你的css名称,放入css代码当中即可(防止出错,记得备份!)
以上就是logo添加css扫光效果的方法,当然你也可以运用到其他的地方。
注意,有些模板CSS代码不相同,不能贸然的使用,可能会出现错误,新手不要尝试。
关于css好看的动画代码到此分享完毕,希望能帮助到您。