纯CSS3实现3D旋转书本效果
网站建设 2023-01-28 21:38www.1681989.com免费网站
有一些前沿的电商网站已经开始使用3D模型来展示商品并支持在线定制,而其中图书的展示是最为简单的一种,无需复杂的建模过程,使用图片和CSS3的一些变换即可实现更好的展示效果,简洁而实用。
书本的3D模型是所有商品中最为简单的,因为其本质上就是一个立方体(cube),只是带有封面/封底和左侧封条。 所以要构造一个3D书本展示,问题就被分解为构造一个立方体+旋转+图片背景。
1. 构造一个立方体
要创建一个立方体,我们需要创建一个虚拟的三维视觉空间,这可以通过设置包容器元素的perspective属性获得。
CSS Code复制内容到剪贴板
- .stage {
- width: 200px;
- height: 260px;
- perspective: 1000px;
- perspective-orig: 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旋转书本 的全部内容长沙网络推广就给大家介绍这么多,希望对大家有所帮助!
原文
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销