zoukankan      html  css  js  c++  java
  • HTML5 CSS3 专题 :诱人的实例 3D旋转木马效果相冊

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/32964301

    首先说明一下创意的出处:http://www.zhangxinxu.com/study/201209/pictures-3d-slide-view.html(张鑫旭的博客 ),对前台感兴趣的能够没事去看看他的博客,非常给力~

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

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


    1、perspective

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

    当中perspective属性的默认值为none,表示无限的角度来看3D物体,但看上去是平的。还有一个值<length>接受一个长度单位大于0的值。并且其单位不能为百分比值。<length>值越大。角度出现的越远。从而创建一个相当低的强度和非常小的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:

    <!DOCTYPE html>
    <html>
    <head>
        <title></title>
        <meta charset="utf-8"/>
        <link href="css/reset.css" rel="stylesheet" type="text/css"/>
        <script type="text/javascript" src="../../jquery-1.8.3.js"></script>
    
        <script type="text/javascript">
            // 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)")
                });
            });
    
        </script>
    
       
    
    </head>
    <body>
    <div id="stage">
        <ul id="container">
            <li>
                <img src="img/1.jpg"/>
                <span>Do one thing at a time, and do well..</span>
            </li>
            <li>
                <img src="img/2.jpg"/> <span>Do one thing at a time, and do well..</span>
            </li>
            <li>
                <img src="img/3.jpg"/> <span>Keep on going never give up.</span>
            </li>
            <li>
                <img src="img/4.jpg"/> <span>Whatever is worth doing is worth doing well.</span>
            </li>
            <li>
                <img src="img/5.jpg"/> <span>Believe in yourself.</span>
            </li>
            <li>
                <img src="img/6.jpg"/> <span>Action speak louder than words.</span>
            </li>
            <li>
                <img src="img/7.jpg"/> <span>Never put off what you can do today until tomorrow.</span>
            </li>
            <li>
                <img src="img/8.jpg"/> <span>Jack of all trades and master of none.</span>
            </li>
            <li>
                <img src="img/9.jpg"/> <span>Judge not from appearances.</span>
            </li>
        </ul>
    </div>
    </body>
    </html>

    CSS:

            li
            {
                 128px;
                box-shadow: 0 1px 3px rgba(0, 0, 0, .5);
                position: absolute;
                bottom: 0;
            }
    
            li img
            {
                 128px;
                box-shadow: 0 1px 3px rgba(0, 0, 0, .5);
                vertical-align: middle;
            }
    
            li span
            {
                display: block;
                 128px;
                text-align: center;
                color: #333;
                font-size: 8px;
            }
    
            #stage
            {
    
                 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;
                 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角度就可以。


    欢迎各位指点~


    源代码点击下载



  • 相关阅读:
    iis 配置域名访问
    js将base64做UrlEncode转码
    vue-router 刷新当前路由
    iview default-file-list 动态赋值不显示
    vue2.0 axios 登录post请求自动读取Set-Cookie设置
    iis 使用主机名配置需注意
    【LeetCode.1】 求两数之和
    【Docker学习笔记】Docker常用命令学习
    【Docker学习笔记】Docker基本组成与安装
    微信小程序对接七牛云 上传多张图片、预览、删除 (测试可用)
  • 原文地址:https://www.cnblogs.com/yangykaifa/p/6715088.html
Copyright © 2011-2022 走看看