纯CSS3实现3D旋转书本效果
建站知识 2021-07-03 08:42www.168986.cn长沙网站建设
有一些前沿的电商网站已经开始使用3D模型来展示商品并支持在线定制,而其中图书的展示是最为简单的一种,无需复杂的建模过程,使用图片和CSS3的一些变换即可实现更好的展示效果,简洁而实用。
书本的3D模型是所有商品中最为简单的,因为其本质上就是一个立方体(cube),只是带有封面/封底和左侧封条。 所以要构造一个3D书本展示,问题就被分解为构造一个立方体+旋转+图片背景。
1. 构造一个立方体
要创建一个立方体,我们需要创建一个虚拟的三维视觉空间,这可以通过设置包容器元素的perspective属性获得。
CSS Code复制内容到剪贴板
- .stage {
- width: 200px;
- height: 260px;
- perspective: 1000px;
- perspective-origin: center center;// 缺省值,可忽略
- }
CSS Code复制内容到剪贴板
- <div class="stage">
- <div class="cube">
- <figure class="back"></figure>
- <figure class=""></figure>
- <figure class="bottom"></figure>
- <figure class="left"></figure>
- <figure class="right"></figure>
- <figure class="front"></figure>
- </div>
- </div>
我们需要根据书本的厚度和长宽来确定立方体各个面的坐标位置,在本例中所用书本模型(一本MySQL书)的绝对厚度为18.2px,高度260px,宽度197.6px。
那么根据简单的几何知识,前后面距离立方体中心的距离为18.2/2=9.1px,其中“后”元素需要再翻转一下(即“背”过去)。
CSS Code复制内容到剪贴板
- .front {
- transform: translateZ(9.1px);
- }
- .back {
- transform: rotateY(180deg) translateZ(9.1px);
- }
CSS Code复制内容到剪贴板
- .front {
- transform: translateZ(9.1px);
- }
- .back {
- transform: rotateY(180deg) translateZ(9.1px);
- }
- . {
- 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;
- }
接着我们给前后以及左侧面元素添加背景图(可以使用一张图,然后从不同的位置截取),给其他3个面添加背景颜色,并给“底”面添加阴影效果
CSS Code复制内容到剪贴板
- .front {
- transform: translateZ(9.1px);
- background: url("//wow.techbrood./uploads/160301/mysql.png") rightright;
- background-size: auto 100%;
- }
- .back {
- transform: rotateY(180deg) translateZ(9.1px);
- background: url("//wow.techbrood./uploads/160301/mysql.png") left;
- background-size: auto 100%;
- }
- . {
- 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: #c;
- 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./uploads/160301/mysql.png") center;
- background-size: auto 100%;
- width: 18.2px;
- }
- .rightright {
- transform: rotateY(90deg) translateZ(188.5px);
- background: #ddd;
- background-size: auto 100%;
- width: 18.2px;
- }
3. 添加旋转动画
这个比较简单,使用rotateY方法就可以。
CSS Code复制内容到剪贴板
- @-webkit-keyframes rotate {
- 0% {
- transform: rotateY(0) translateX(-18.2px);
- }
- 100% {
- transform: rotateY(360deg) translateX(-18.2px);
- }
- }
最终的效果图如下
关于CSS3实现3D旋转书本 的全部内容长沙网络推广就给大家介绍这么多,希望对大家有所帮助!
原文
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML