html5实现3d的简单介绍

html5 3d效果由什么实现

我写了个正方体的模板,你可以按照你想要的把每个面旋转不同角度就行了

目前创新互联已为上千多家的企业提供了网站建设、域名、雅安服务器托管、网站托管维护、企业网站设计、岚皋网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

style type="text/css"

html{

font-size:62.5%;

}

img{

width:300px;

height:300px;

}

#stage{

margin-top:200px;

margin-left:auto;

margin-right:auto;

width:300px;

height:300px;

perspective:1200px;

font-size:5em;

font-weight:bold;

color:#cc00ff;

}

.cube{

position:relative;

transform:rotateX(-45deg) rotateY(45deg);

transform-style:preserve-3d;

transition: all .6s;

}

.side{

color:blue;

text-align:center;

width:300px;

height:300px;

line-height:300px;

position:absolute;

background:#cc66ff;

opacity:0.5;

border:1px solid rgba(117,4,24,0.5);

  }

 .front{

transform:translateZ(150px);

 }

 .back{

transform:rotateY(180deg) translateZ(150px);

 }

 .left{

transform:rotateY(-90deg) translateZ(150px);

 }

 .right{

transform:rotateY(90deg) translateZ(150px);

 }

 .top{

transform:rotateX(90deg) translateZ(150px);

 }

 .bottom{

transform:rotatex(-90deg) translateZ(150px);

 }

#stage:hover .cube{

transform:rotateX(-45deg) rotateY(225deg);

transition:transform .6s;

}

/style

/head

body

div id="stage"

div class="cube"

div class="side front"img src="6.gif" alt="" //div

div class="side back"img src="2.jpg" alt="" //div

div class="side left"img src="3.jpg" alt="" //div

div class="side right"img src="4.jpg" alt="" //div

div class="side top"img src="5.jpg" alt="" //div

div class="side bottom"img src="1.jpg" alt="" //div

/div

/div

/body

如何用HTML5的Canvas制作3D动画效果

你可以先去【绘学霸】网站找“动画制作技术”板块的【免费】视频教程-【点击进入】完整入门到精通视频教程列表: ;tagid=310zdhhr-11y04r-565437477017667964

想要系统的学习可以考虑报一个网络直播课,推荐CGWANG的网络课。老师讲得细,上完还可以回看,还有同类型录播课可以免费学(赠送终身VIP)。

自制能力相对较弱的话,建议还是去好点的培训机构,实力和规模在国内排名前几的大机构,推荐行业龙头:王氏教育。

王氏教育全国直营校区面授课程试听【复制后面链接在浏览器也可打开】:

在“动画制作技术”领域的培训机构里,【王氏教育】是国内的老大,且没有加盟分校,都是总部直营的连锁校区。跟很多其它同类型大机构不一样的是:王氏教育每个校区都是实体面授,老师是手把手教,而且有专门的班主任从早盯到晚,爆肝式的学习模式,提升会很快,特别适合基础差的学生。

大家可以先把【绘学霸】APP下载到自己手机,方便碎片时间学习——绘学霸APP下载:

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

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="" /

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

p3D立方体/p

pHTML5学堂/p

p3D立方体/p

p码匠/p

pJavaScript/p

/div              

/div

/body

/html

代码解析

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

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

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

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

html5怎么实现3d效果

我写了个正方体的模板,你可以按照你想要的把每个面旋转不同角度就行了

style type="text/css"

html{

font-size:62.5%;

}

img{

width:300px;

height:300px;

}

#stage{

margin-top:200px;

margin-left:auto;

margin-right:auto;

width:300px;

height:300px;

perspective:1200px;

font-size:5em;

font-weight:bold;

color:#cc00ff;

}

.cube{

position:relative;

transform:rotateX(-45deg) rotateY(45deg);

transform-style:preserve-3d;

transition: all .6s;

}

.side{

color:blue;

text-align:center;

width:300px;

height:300px;

line-height:300px;

position:absolute;

background:#cc66ff;

opacity:0.5;

border:1px solid rgba(117,4,24,0.5);

  }

 .front{

transform:translateZ(150px);

 }

 .back{

transform:rotateY(180deg) translateZ(150px);

 }

 .left{

transform:rotateY(-90deg) translateZ(150px);

 }

 .right{

transform:rotateY(90deg) translateZ(150px);

 }

 .top{

transform:rotateX(90deg) translateZ(150px);

 }

 .bottom{

transform:rotatex(-90deg) translateZ(150px);

 }

#stage:hover .cube{

transform:rotateX(-45deg) rotateY(225deg);

transition:transform .6s;

}

/style

/head

body

div id="stage"

div class="cube"

div class="side front"img src="6.gif" alt="" //div

div class="side back"img src="2.jpg" alt="" //div

div class="side left"img src="3.jpg" alt="" //div

div class="side right"img src="4.jpg" alt="" //div

div class="side top"img src="5.jpg" alt="" //div

div class="side bottom"img src="1.jpg" alt="" //div

/div

/div

/body

html5怎样引入三维模型,创建360度旋转浏览?

html5中引入3d模型的方法是借助第三方PlayCanvas插件来完成的。

比如可以用以下方法实现图片的360度旋转:

代码示例:

var render, loop, t, dt, //定义变量

DEG2RAD = Math.PI / 180, //角度转弧度

cvs = document.querySelector('canvas'), //创建canvas

ctx = cvs.getContext('2d'),//绘制2d图形上下文

teddy = new Image(), //创建图像

heart = new Image(), //创建图像中心

angle = 0,//初始化角度为0

reqAnimFrame =

window.requestAnimationFrame ||

window.webkitRequestAnimationFrame ||

window.mozRequestAnimationFrame ||

window.msRequestAnimationFrame ||

window.oRequestAnimationFrame;

//创建动画帧

cvs.width = 400;

cvs.height = 200;

teddy.src = 'xxx.jpg';

heart.src = 'yyy.jpg';

//开始渲染

render = function (timestamp) {

dt = timestamp - t;

t = timestamp;

// cavas设置为白色

ctx.fillStyle = "rgb(255,255,255)";

ctx.fillRect(0, 0, cvs.width, cvs.height);

// 绘制中心

ctx.drawImage(heart, -20, -120);

// 绘制teddy

ctx.save();

ctx.translate(cvs.width/2, cvs.height/2); // 移动鼠标到画布中心

ctx.rotate(DEG2RAD * angle); // 旋转画布

ctx.drawImage(teddy, -teddy.width/2, -teddy.height/2); // 绘制中心图片

angle += dt / 16.67 * 6; // increment angle ~ 360 deg/sec

ctx.restore();

};

loop = function (timestamp) {

reqAnimFrame(loop);

render(timestamp);

};

t = Date.now();

loop(t);


名称栏目:html5实现3d的简单介绍
标题路径:http://csdahua.cn/article/dsceeci.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流