基于javascript html5实现3D翻书特效
来源: 阅读:1369 次 日期:2016-07-20 15:16:38
温馨提示: 小编为您整理了“基于javascript html5实现3D翻书特效”,方便广大网友查阅!

这篇文章主要介绍了基于javascript html5实现翻书特效的实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

这是一款十分炫酷的HTML5 3D书本翻页动画,效果相对比较简单,拖拽鼠标模拟用手翻页,更漂亮的是翻页过程中,呈现出逼真的3D立体效果。书本中的文字和图片也会3D展示,非常酷。

HTML代码

<div class="book p3d">

 <div class="back-cover p3d">

 <div class="page back flip"></div>

 <div class="page front p3d">

  <div class="shadow"></div>

  <div class="dino"></div>

 </div>

 </div>

 <div class="front-cover p3d">

 <div class="page front flip p3d">

  <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam fermentum nisl quis nulla eleifend dignissim. Curabitur varius lobortis tincidunt. Maecenas gravida, nulla quis luctus imperdiet, ipsum nibh consectetur ante, in sodales massa tortor eget neque. Donec porta ligula massa, id sagittis est. Ut nisl tellus, faucibus nec feugiat ut, laoreet iaculis felis. Suspendisse ultrices mauris vel tellus suscipit commodo. Integer vitae tortor erat. Pellentesque non tempor nisi.</p>

 </div>

 <div class="page back"></div>

 </div>

</div>

CSS代码

.book {

 width: 300px;

 height: 300px;

 margin-top: -150px;

 position: absolute;

 left: 50%;

 top: 50%;

 -webkit-transform: rotateX(60deg);

 -moz-transform: rotateX(60deg);

 -ms-transform: rotateX(60deg);

 -o-transform: rotateX(60deg);

 transform: rotateX(60deg);

 -webkit-user-select: none;

 -moz-user-select: none;

 -ms-user-select: none;

 -o-user-select: none;

 user-select: none;

}

.page {

 width: 300px;

 height: 300px;

 padding: 1em;

 position: absolute;

 left: 0;

 top: 0;

 text-indent: 2em;

}

.front {

 background-color: #d93e2b;

}

.back {

 background-color: #fff;

}

.front-cover {

 cursor: move;

 -webkit-transform-origin: 0 50%;

 -moz-transform-origin: 0 50%;

 -ms-transform-origin: 0 50%;

 -o-transform-origin: 0 50%;

 transform-origin: 0 50%;

 -webkit-transform: rotateY(0deg);

 -moz-transform: rotateY(0deg);

 -ms-transform: rotateY(0deg);

 -o-transform: rotateY(0deg);

 transform: rotateY(0deg);

}

.front-cover .back {

 background-image: url(mdn.png);

 background-repeat: no-repeat;

 background-position: 50% 50%;

 -webkit-transform: translateZ(3px);

 -moz-transform: translateZ(3px);

 -ms-transform: translateZ(3px);

 -o-transform: translateZ(3px);

 transform: translateZ(3px);

}

.back-cover .back {

 -webkit-transform: translateZ(-3px);

 -moz-transform: translateZ(-3px);

 -ms-transform: translateZ(-3px);

 -o-transform: translateZ(-3px);

 transform: translateZ(-3px); 

}

.p3d {

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

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

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

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

 transform-style: preserve-3d;

}

.flip {

 -webkit-transform: rotateY(180deg);

 -moz-transform: rotateY(180deg);

 -ms-transform: rotateY(180deg);

 -o-transform: rotateY(180deg);

 transform: rotateY(180deg);

}

.dino,

.shadow {

 width: 196px;

 height: 132px;

 position: absolute;

 left: 60px;

 top: 60px;

 -webkit-transform-origin: 0 100%;

 -moz-transform-origin: 0 100%;

 -ms-transform-origin: 0 100%;

 -o-transform-origin: 0 100%;

 transform-origin: 0 100%;

}

.dino {

 background: url(dino.png) no-repeat;

}

.shadow {

 background: url(shadow.png) no-repeat;

}

JavaScript代码

(function (window, document) {

 var prefixes = ['Webkit', 'Moz', 'ms', 'O', ''],

 book = document.querySelectorAll('.book')[0],

 page = document.querySelectorAll('.front-cover')[0],

 dino = document.querySelectorAll('.dino')[0],

 shadow = document.querySelectorAll('.shadow')[0],

 hold = false,

 centerPoint = window.innerWidth / 2,

 pageSize = 300,

 clamp = function (val, min, max) {

 return Math.max(min, Math.min(val, max));

 };

 page.onmousedown = function () {

 hold = true;

 };

 window.onmouseup = function () {

 if (hold) {

 hold = false;

 }

 };

 window.onresize = function () {

 centerPoint = window.innerWidth / 2;

 };

 window.onmousemove = function (evt) {

 if (!hold) {

 return;

 }

 var angle = clamp((centerPoint - evt.pageX + pageSize) / pageSize * -90, -180, 0),

 i, j;

 for (i = 0, j = prefixes.length; i < j; i++) {

 book.style[prefixes[i] + 'Transform'] = 'rotateX(' + (60 + angle / 8) + 'deg)';

 page.style[prefixes[i] + 'Transform'] = 'rotateY(' + angle + 'deg)';

 dino.style[prefixes[i] + 'Transform'] = 'rotateX(' + (angle / 2) + 'deg)';

 shadow.style[prefixes[i] + 'Transform'] = 'translateZ(1px) skewX(' + (angle / 8) + 'deg)';

 }

 };

})(window, document);

以上就是HTML5 3D书本翻页动画的示例代码,希望对大家学习javascript程序设计有所帮助。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map