HTML5如何在网页中实现3D效果

HTML5如何在网页中实现3D效果,第1张

CSS3除了为开发者提供二维变形之外,还将动画从二维平面推动到了三维立体状态,能够实现真正的三维特效。

三维变形和二维变形一样,均使用的是transform属性。想要触发三维变形有两种方式:一种方式是通过语法告知浏览器“请采用三维方式进行变形处理”,另一种方式是直接使用CSS3三维变形的语法。

触发方法1:告知浏览器变形方式

-webkit-transform-style:preserve-3d

Tips:IE不支持三维变形,在移动端,绝大多数的浏览器均为WebKit内核,因此,在此句代码之前需要书写-webkit-的前缀内核。

Tips:不要为body元素设置-webkit- transform-style: preserve 3d,否则会对position:fixed定位的元素造成布局影响。在开发当中,如果当前元素属于body的子级元素,又希望应用三维变形,则在body和当前元素之间多嵌套一层结构,并为这层元素应用三维变形即可。

触发方法2:直接使用CSS3变形语法

<!DOCTYPE html>

<head>

    <meta charset="UTF-8">

    <title>言成科技/title>

    <style>

        .box1 {

            width: 150px

            height: 150px

            border: 2px solid blue

        }

        .box1 div {

            height: 150px

            background: rgba(0, 0, 0, 0.5)

            -webkit-transform: translate3d(30px, 60px, 20px) rotateX(30deg)

            transform: translate3d(30px, 60px, 20px) rotateX(30deg)

        }

    </style>

</head>

<body>

    <div class="box1">

        <div></div>

    </div>

</body>

</html>

具体三维变形的具体属性详见《CSS3-3D相关知识详解—视角以及变形方向》

3D效果制作

需求

制作一个立方体,并进行旋转

代码实例

<!DOCTYPE HTML>

<html>

<head>

 <meta charset="utf-8" />

 <title>言成科技</title>

 <link rel="stylesheet" type="text/css" href="https://css.h5course.cn/reset-1.0.0.css" />

 <style>

  .main-bac { -webkit-perspective:1500 } /*设定透视距离*/

  .main{

   width:200px 

   height:200px 

   margin: 0 auto

   position:relative

   -webkit-transform-style:preserve-3d

   -webkit-transition:-webkit-transform 2s ease 0s/*过渡时间*/

  }

  /*基本样式*/

  .main p{

   position: absolute 

   margin: 0 

   padding: 0 

   width: 200px 

   height: 200px  

   text-align: center 

   line-height: 200px 

   font-size: 26px 

   opacity:0.5

  }

  /*将第一个元素Z轴向前移动100px,形成第一个面(正面)*/

  .main p:nth-of-type(1) {

   background-color:red

   -webkit-transform:translateZ(100px)

  }

  /*将第一个元素Z轴向前移动100px,绕x轴旋转90度形成上面的面*/

  .main p:nth-of-type(2) {

   background-color:orange 

   -webkit-transform:rotateX(90deg) translateZ(100px)

  }

  /*将第一个元素Z轴向前移动100px,绕x轴旋转-90度形成下边的面*/

  .main p:nth-of-type(3) {

   background-color:yellow

   -webkit-transform:rotateX(-90deg) translateZ(100px)

  }

  /*将第一个元素Z轴向前移动100px,绕y轴旋转90度形成右侧的面*/

  .main p:nth-of-type(4) {

   background-color:green

   -webkit-transform:rotateY(90deg) translateZ(100px)

  }

  /*将第一个元素Z轴向前移动100px,绕y轴旋转-90度形成左侧的面*/

  .main p:nth-of-type(5) {

   background-color:#b435bf

   -webkit-transform:rotateY(-90deg) translateZ(100px)

  }

  /*将第一个元素Z轴向前移动100px,绕y轴旋转180度形成后面(背面)*/

  .main p:nth-of-type(6) {

   background-color:blue

   -webkit-transform:rotateY(180deg) translateZ(100px)

  }

  /*鼠标移入时绕Y轴旋转180度,绕Z轴旋转180度*/

  .main:hover {-webkit-transform:rotateY(180deg) rotateZ(180deg) }   

 </style>

</head>

<body>

 <div class="main-bac">

  <div class="main">

   <p>言成科技</p>

   <p>3D立方体</p>

   <p>HTML5学堂</p>

   <p>3D立方体</p>

   <p>码匠</p>

   <p>JavaScript</p>

  </div>              

 </div>

</body>

</html>

代码解析

当鼠标移入的时候,立方体逐渐的发生旋转(非突变),围绕X轴旋转45度的同时,围绕Y轴旋转45度。

当鼠标移出立方体时,立方体恢复到初始状态。在最开始状态时,并没有采用无限远的视角,设置一定的视角,让刚开始时直视立方体时,不会觉得是一个平面。

3D效果制作-目标效果图

以上资料来源:《HTML5布局之路》

计算立方体的公式如下:

立方体的体积公式为V=a·a·a=a³

立方体的表面积公式S=a*a*6

其中V为立方体的体积,S为立方体的表面积,a为立方体的边长。

定义:

立方体,也称正方体,是由6个正方形面组成的正多面体,故又称正六面体。

特征:

1.

立方体有12条棱,每条棱的长度相等

2.

立方体有8个顶点

3.

立方体有6个面,面积相等

4.

正方体的棱长扩大n倍,棱长总和扩大n倍,表面积扩大n²倍,体积扩大n³倍。

现实生活中的立方体:

1.

食盐和糖的结晶体都是立方状。

2.

骰子最常见的形状就是立方体。

3.

1967年世界博览会的「立方体房间」

参考资料

新东方中考网:http://zhongkao.xdf.cn/201408/10126041.html

<!DOCTYPE HTML>

<html>

 

<head>

    <meta charset=UTF-8>

    <title>YuGiOh</title>

    <style type="text/css">

        *{

            margin:0

            padding:0  

        }

        #div {

    position: absolute

    top: 50px

    left: 300px

    width: 300px

    height: 300px

    line-height: 300px

    text-align: center

    border: 1px solid black

    border-radius: 90px

}

    </style>

    <script type="text/javascript">

        var deg = 0

        var rotateHTML5 = function(limit) {

            deg += limit

            deg = deg > 360 ? 1 : deg

            div.style['transform'] = div.style['-webkit-transform'] = 'rotate(' + deg + 'deg)'

        }

        var rotateIE = function(obj) {

            var d = !! obj.d ? obj.d : 1

            var r = d * Math.PI / 180

            costheta = Math.cos(r)

            sintheta = Math.sin(r)

            obj.style.filter = "progid:DXImageTransform.Microsoft.Matrix()"

            var item = obj.filters.item(0)

            var width = obj.clientWidth

            var height = obj.clientHeight

            item.DX = -width / 2 * costheta + height / 2 * sintheta + width / 2

            item.DY = -width / 2 * sintheta - height / 2 * costheta + height / 2

            item.M11 = costheta

            item.M12 = -sintheta

            item.M21 = sintheta

            item.M22 = costheta

            obj.timer = setTimeout(function() {

                var dx = d + 1

                dx = dx > 360 ? 1 : dx

                obj.d = dx

                rotateIE(obj)

            }, 30)

        }

        var start = function() {

            if (!/.*MSIE.*/i.test(navigator.userAgent)) {

                if ( !! div.interval) {

                    clearInterval(div.interval)

                    div.interval = null

                } else {

                    div.interval = setInterval(function() {

                        rotateHTML5(1)

                    }, 30)

                }

            } else {

                if ( !! div.timer) {

                    clearTimeout(div.timer)

                    div.timer = null

                } else {

                    rotateIE(div)

                }

            }

        }

    </script>

</head>

 

<body>

    <button onclick="start()">rotate</button>

    <div id="div">ROTATE</div>

</body>

 

</html>


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/6162643.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-16
下一篇2023-03-16

发表评论

登录后才能评论

评论列表(0条)

    保存