首页 web前端 html教程 CSS3动画之3D旋转书本效果

CSS3动画之3D旋转书本效果

Jun 01, 2016 am 09:53 AM
css 动画 旋转

有一些前沿的电商网站已经开始使用3D模型来展示商品并支持在线定制,而其中图书的展示是最为简单的一种,无需复杂的建模过程,使用图片和CSS3的一些变换即可实现更好的展示效果,简洁而实用。 
书本的3D模型是所有商品中最为简单的,因为其本质上就是一个立方体(cube),只是带有封面/封底和左侧封条。 所以要构造一个3D书本展示,问题就被分解为构造一个立方体+旋转+图片背景。 

1. 构造一个立方体 

要创建一个立方体,首先我们需要创建一个虚拟的三维视觉空间,这可以通过设置包容器元素的perspective属性获得。

CSS3动画之3D旋转书本效果

<code class="language-css">.stage {    
width: 200px;    
height: 260px;    
perspective: 1000px;    
perspective-origin: center center;// 缺省值,可忽略    
}  </code>
登录后复制

上述代码把元素放在距离观察点1000px的地方(Z轴向),并且在X/Y轴向上居中。 

<code class="language-html"><div class="stage">    
<div class="cube">    
<figure class="back"></figure>    
<figure class="top"></figure>    
<figure class="bottom"></figure>    
<figure class="left"></figure>    
<figure class="right"></figure>    
<figure class="front"></figure>    
</div>    
</div>   </code>
登录后复制

接着,我们在包容器元素里面添加一个立方体元素,6个边(上下左右和前后),之所以使用figure,是因为需要支持贴图。 
我们需要根据书本的厚度和长宽来确定立方体各个面的坐标位置,在本例中所用书本模型(一本MySQL书)的绝对厚度为18.2px,高度260px,宽度197.6px。 
那么根据简单的几何知识,前后面距离立方体中心的距离为18.2/2=9.1px,其中“后”元素需要再翻转一下(即“背”过去)。 

<code class="language-css">.front {    
transform: translateZ(9.1px);    
}    
.back {    
transform: rotateY(180deg) translateZ(9.1px);    
}   </code>
登录后复制

用类似的计算方法,我们可以把其他4条边放置(平移+旋转变换)到各自的位置,从而拼装成一个虚拟的立方体。 

<code class="language-css">.front {    
transform: translateZ(9.1px);    
}    
.back {    
transform: rotateY(180deg) translateZ(9.1px);    
}    
.top {    
transform: rotateX(90deg) rotateZ(90deg) translateZ(98.8px) translateY(-89.7px);    
width: 18.2px;    
height: 197.6px;    
}    
.bottombottom {    
transform: rotateX(-90deg) rotateZ(90deg) translateZ(161.2px) translateY(-89.7px);    
}    
.left {    
transform: rotateY(-90deg) translateZ(9.1px);    
width: 18.2px;    
}    
.rightright {    
transform: rotateY(90deg) translateZ(188.5px);    
width: 18.2px;    
}  </code>
登录后复制

 

2. 添加封面 

接着我们给前后以及左侧面元素添加背景图(可以使用一张图,然后从不同的位置截取),给其他3个面添加背景颜色,并给“底”面添加阴影效果:

<code class="language-css">.front {    
transform: translateZ(9.1px);    
background: url("//wow.techbrood.com/uploads/160301/mysql.png") top rightright;    
background-size: auto 100%;    
}    
.back {    
transform: rotateY(180deg) translateZ(9.1px);    
background: url("//wow.techbrood.com/uploads/160301/mysql.png") top left;    
background-size: auto 100%;    
}    
.top {    
transform: rotateX(90deg) rotateZ(90deg) translateZ(98.8px) translateY(-89.7px);    
background: #fafafa;    
width: 18.2px;    
height: 197.6px;    
}    
.bottombottom {    
transform: rotateX(-90deg) rotateZ(90deg) translateZ(161.2px) translateY(-89.7px);    
background: #ccc;    
width: 18.2px;    
height: 197.6px;    
-webkit-filter: drop-shadow(0 0 26px rgba(0, 0, 0, 0.75));    
}    
.left {    
transform: rotateY(-90deg) translateZ(9.1px);    
background: url("//wow.techbrood.com/uploads/160301/mysql.png") top center;    
background-size: auto 100%;    
width: 18.2px;    
}    
.rightright {    
transform: rotateY(90deg) translateZ(188.5px);    
background: #ddd;    
background-size: auto 100%;    
width: 18.2px;    
}  </code>
登录后复制

这样我们就实现了一个逼真的3D书本视觉模型。 

 

3. 添加旋转动画 

这个比较简单,使用rotateY方法就可以。 

<code class="language-css">@-webkit-keyframes rotate {    
0% {    
transform: rotateY(0) translateX(-18.2px);    
}    
100% {    
transform: rotateY(360deg) translateX(-18.2px);    
}    
} </code>
登录后复制

最终的效果图如下:

CSS3动画之3D旋转书本效果

以上是本文全部类容,如果需要了解更多CSS3动画请阅读css3 教程中的css3 动画章节

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Bootstrap列表如何移除默认样式? Bootstrap列表如何移除默认样式? Apr 07, 2025 am 10:18 AM

Bootstrap 列表的默认样式可以通过 CSS 覆盖来移除。使用更具体的 CSS 规则和选择器,遵循 "就近原则" 和 "权重原则",覆盖 Bootstrap 默认的样式。为避免样式冲突,可使用更具针对性的选择器。如果遇到覆盖不成功的情况,可调整自定义 CSS 的权重。同时注意性能优化,避免过度使用 !important,撰写简洁高效的 CSS 代码。

bootstrap怎么布局 bootstrap怎么布局 Apr 07, 2025 pm 02:24 PM

使用 Bootstrap 布局网站,需要使用网格系统,将页面划分为容器、行和列。首先添加容器,然后在其中添加行,并在行内添加列,最后在列中添加内容。Bootstrap 的响应式布局功能根据断点(xs、sm、md、lg、xl)自动调整布局,通过使用响应式类可以实现不同屏幕尺寸下的不同布局。

怎么建立bootstrap框架 怎么建立bootstrap框架 Apr 07, 2025 pm 12:57 PM

要建立 Bootstrap 框架,请按照以下步骤操作:通过 CDN 或安装本地副本安装 Bootstrap。创建一个 HTML 文档,将 Bootstrap CSS 链接到 &lt;head&gt; 部分。添加 Bootstrap JavaScript 文件到 &lt;body&gt; 部分。使用 Bootstrap 组件并自定义样式表以满足您的需要。

bootstrap怎么插入图片 bootstrap怎么插入图片 Apr 07, 2025 pm 03:30 PM

在 Bootstrap 中插入图片有以下几种方法:直接插入图片,使用 HTML 的 img 标签。使用 Bootstrap 图像组件,可以提供响应式图片和更多样式。设置图片大小,使用 img-fluid 类可以使图片自适应。设置边框,使用 img-bordered 类。设置圆角,使用 img-rounded 类。设置阴影,使用 shadow 类。调整图片大小和位置,使用 CSS 样式。使用背景图片,使用 background-image CSS 属性。

Bootstrap图片居中是否支持图片缩放 Bootstrap图片居中是否支持图片缩放 Apr 07, 2025 am 07:42 AM

如何在 Bootstrap 中实现图片居中和缩放:使用 d-flex justify-content-center 水平居中图片。使用 align-items-center 和固定的父元素高度垂直居中图片。使用 width 和 height 属性控制图片大小,或使用 max-width 和 max-height 限制最大尺寸。使用 img-fluid 类或响应式设计机制,例如媒体查询,实现响应式缩放。优化图片尺寸,使用 object-fit 属性控制缩放方式,遵循最佳实践,以确保性能和可维护性。

bootstrap导航栏怎么设置 bootstrap导航栏怎么设置 Apr 07, 2025 pm 01:51 PM

Bootstrap 提供了设置导航栏的简单指南:引入 Bootstrap 库创建导航栏容器添加品牌标识创建导航链接添加其他元素(可选)调整样式(可选)

Bootstrap图片居中的兼容性如何 Bootstrap图片居中的兼容性如何 Apr 07, 2025 am 07:51 AM

Bootstrap 图片居中面临兼容性问题,解决方案如下:使用 mx-auto 针对 display: block 的图片水平居中。垂直居中使用 Flexbox 或 Grid 布局,确保父元素垂直居中对齐子元素。对于 IE 浏览器兼容性,使用 Autoprefixer 等工具自动添加浏览器前缀。优化图片大小、格式和加载顺序,提升页面性能。

如何查看Bootstrap的网格系统 如何查看Bootstrap的网格系统 Apr 07, 2025 am 09:48 AM

Bootstrap的网格系统是一种用于快速构建响应式布局的规则,包含三个主要类:container(容器)、row(行)和col(列)。默认情况下提供12列网格,每一列的宽度可以通过col-md-等辅助类进行调整,从而实现针对不同屏幕尺寸的布局优化。通过使用偏移类和嵌套网格,可以扩展布局的灵活性。在使用网格系统时,确保每个元素的嵌套结构正确, 并考虑性能优化,以提升页面加载速度。只有深入理解和实践,才能熟练掌握Bootstrap网格系统。

See all articles