1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > html5 旋转木马相册 HTML5 CSS3 专题 :诱人的实例 3D旋转木马效果相册

html5 旋转木马相册 HTML5 CSS3 专题 :诱人的实例 3D旋转木马效果相册

时间:2019-03-31 06:42:43

相关推荐

html5 旋转木马相册 HTML5 CSS3 专题 :诱人的实例 3D旋转木马效果相册

首先说明一下创意的出处:/study/09/pictures-3d-slide-view.html(张鑫旭的博客),对前台感兴趣的可以没事去看看他的博客,很给力~

这篇博客的目的是因为上篇HTML5 CSS3专题 诱人的实例 CSS3打造百度贴吧的3D翻牌效果中有个关于CSS 3D效果的比较重要的知识点没讲到,就是perspective和tranlateY

效果图:嘿嘿,我把大学毕业时的一些照片,做成旋转木马,绕着我大文理旋转,不忘母校的培育之恩~

1、perspective

perspective属性包括两个属性:none和具有单位的长度值。

其中perspective属性的默认值为none,表示无限的角度来看3D物体,但看上去是平的。另一个值接受一个长度单位大于0的值。而且其单位不能为百分比值。值越大,角度出现的越远,从而创建一个相当低的强度和非常小的3D空间变化。反之,此值越小,角度出现的越近,从而创建一个高强度的角度和一个大型3D变化。简单一点说:当perspective设置length时,如果越小则表示3D效果越明显,你的眼睛就越靠近3D物体,反之则反之。

2、transform: translateZ(length)

假设设置了perspective:300px时,设置translateZ的值越小则子元素大小越小,当设置值接近300px时,则仿佛此元素在面前,当超过300px以后,则以前到达你视野的后面,该元素就不可见了。

上例的核心:

1、首先所有的图片的容器position:absolute,叠加在一起,然后一次设置rotateY分别为40*i ,i= 0 , 1, 2...9 ;所有图片会相交成一个类似花的形状

2、然后为每个图片的容器设置translateZ,所有图片会从对应的角度向外移动,扩展成一个大圆,即上图效果。

html:

// alert( 64 / Math.tan(20 / 180 * Math.PI));

var transform = function (element, value, key)

{

key = key || "Transform";

["Moz", "O", "Ms", "Webkit", ""].forEach(function (prefix)

{

element.style[prefix + key] = value;

});

return element;

}

$(function ()

{

var deg = -40 , i = 1;

$("#container").click(function ()

{

transform($(this)[0], "rotateY(" + (deg * i++) + "deg)")

});

});

Do one thing at a time, and do well..

Do one thing at a time, and do well..

Keep on going never give up.

Whatever is worth doing is worth doing well.

Believe in yourself.

Action speak louder than words.

Never put off what you can do today until tomorrow.

Jack of all trades and master of none.

Judge not from appearances.

CSS:

li

{

width: 128px;

box-shadow: 0 1px 3px rgba(0, 0, 0, .5);

position: absolute;

bottom: 0;

}

li img

{

width: 128px;

box-shadow: 0 1px 3px rgba(0, 0, 0, .5);

vertical-align: middle;

}

li span

{

display: block;

width: 128px;

text-align: center;

color: #333;

font-size: 8px;

}

#stage

{

width: 900px;

min-height: 100px;

margin-left: auto;

margin-right: auto;

padding: 100px 50px;

-webkit-perspective: 1200px;

position: relative;

}

#container

{

background: url("img/xawl.jpg") no-repeat 0 0;

margin-top: 200px;

width: 128px;

box-shadow: 0 1px 3px rgba(0, 0, 0, .5);

height: 100px;

margin-left: -64px;

-webkit-transition: -webkit-transform 1s;

transition: transform 1s;

-webkit-transform-style: preserve-3d;

position: absolute;

left: 50%;

}

li:nth-child(0)

{

-webkit-transform: rotateY(0deg) translateZ(300px);

}

li:nth-child(1)

{

-webkit-transform: rotateY(40deg) translateZ(300px);

}

li:nth-child(2)

{

-webkit-transform: rotateY(80deg) translateZ(300px);

}

li:nth-child(3)

{

-webkit-transform: rotateY(120deg) translateZ(300px);

}

li:nth-child(4)

{

-webkit-transform: rotateY(160deg) translateZ(300px);

}

li:nth-child(5)

{

-webkit-transform: rotateY(200deg) translateZ(300px);

}

li:nth-child(6)

{

-webkit-transform: rotateY(240deg) translateZ(300px);

}

li:nth-child(7)

{

-webkit-transform: rotateY(280deg) translateZ(300px);

}

li:nth-child(8)

{

-webkit-transform: rotateY(320deg) translateZ(300px);

}

li:nth-child(9)

{

-webkit-transform: rotateY(360deg) translateZ(300px);

}

div#stage作为舞台,设置perspective,每个li分别设置rotateY,以及translateZ;然后我们会div#container设置了-webkit-transform-style: preserve-3d;

transform-style: flat | preserve-3d

其中flat值为默认值,表示所有子元素在2D平面呈现。preserve-3d表示所有子元素在3D空间中呈现。如果对一个元素设置了transform-style的值为preserve-3d,它表示

不执行平展操作,他的所有子元素位于3D空间中。一般情况下,此属性用于3D动画效果的执行元素,即就是它要应用3D动画效果,所以它的子元素都应该在3D空间。

有一点要注意:本例子,其实正在的动画效果,在于鼠标点击,div#container在不端的改变rotateY,所有的图片元素均在div#container中,且已经展现为旋转木马效果,现在要做的就是旋转这个木马,所以只需要每次改变div#container的rotateY 40角度即可。

欢迎各位指点~

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。