css 3D立体动画效果怎么转这个骰子才能看到5

css 3D立体动画效果怎么转这个骰子才能看到5

 

<!DOCTYPE html>
<html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>3D效果认知:使用transform实现3D立方体</title><style>* {margin: 0 auto;padding: 0;}body {background: #fffdfd;}h1 {text-align: center;color: #c16f6f;}pre {background-size: 800px 400px;padding: 20px;/* 文字大小 */font-size: 18px;}.wrap {background-image: url('xyz.png');background-repeat: no-repeat;background-size: 400px 200px;margin-top: 100px;perspective: 800px;perspective-origin: 50% 100px;}.cube {/* animation: move 10s linear infinite; */margin: 0 auto;position: relative;width: 200px;height: 200px;color: #fff;line-height: 200px;font-size: 10rem;text-align: center;transform-style: preserve-3d;-webkit-user-select: none;-moz-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;}.cube div {position: absolute;width: 200px;height: 200px;background-color: #d82929;opacity: 0.9;color: #e1e6d4;text-shadow:2px 2px 2px #ddd,4px 4px 2px #bbb,6px 6px 2px #999,8px 8px 2px #777,10px 10px 2px #555,12px 12px 2px #333,14px 14px 2px #111;}.front {-webkit-transform: translateZ(100px);-moz-transform: translateZ(100px);-o-transform: translateZ(100px);-ms-transform: translateZ(100px);transform: translateZ(100px);}.back {-webkit-transform: translateZ(-100px) rotateY(180deg);-moz-transform: translateZ(-100px) rotateY(180deg);-o-transform: translateZ(-100px) rotateY(180deg);-ms-transform: translateZ(-100px) rotateY(180deg);transform: translateZ(-100px) rotateY(180deg);}.left {-webkit-transform: translateX(-100px) rotateY(90deg);-moz-transform: translateX(-100px) rotateY(90deg);-o-transform: translateX(-100px) rotateY(90deg);-ms-transform: translateX(-100px) rotateY(90deg);transform: translateX(-100px) rotateY(90deg);}.right {-webkit-transform: translateX(100px) rotateY(-90deg);-moz-transform: translateX(100px) rotateY(-90deg);-o-transform: translateX(100px) rotateY(-90deg);-ms-transform: translateX(100px) rotateY(-90deg);transform: translateX(100px) rotateY(-90deg);}.top {-webkit-transform: translateY(-100px) rotateX(90deg);-moz-transform: translateY(-100px) rotateX(90deg);-o-transform: translateY(-100px) rotateX(90deg);-ms-transform: translateY(-100px) rotateX(90deg);transform: translateY(-100px) rotateX(90deg);}.bottom {-webkit-transform: translateY(100px) rotateX(-90deg);-moz-transform: translateY(100px) rotateX(-90deg);-o-transform: translateY(100px) rotateX(-90deg);-ms-transform: translateY(100px) rotateX(-90deg);transform: translateY(100px) rotateX(-90deg);}/* ---------------------------------------------------------- */@keyframes move {from {transform: rotateY(0deg) rotateZ(0deg);}to {transform: rotateY(360deg) rotateZ(360deg);}}/* -------------------------------------------------------- */pre+div+div {width: 400px;height: 400px;display: flex;justify-content: center;align-items: center;top: 100px;left: 1000px;position: absolute;}main {width: 200px;height: 200px;display: flex;transform-style: preserve-3d;animation: move 5s linear infinite;}main div {position: absolute;width: 200px;height: 200px;background-color: #edeff0;box-shadow: 0 0 10px #dfc3c3;display: flex;justify-content: center;align-items: center;flex-wrap: wrap;}main div span {width: 50px;height: 50px;background-color: #f70a0a;border-radius: 50%;box-shadow: inset 0 4px 10px #fc6114, inset 0 4px 10px #51372cea;}main div:first-child {transform: translateZ(100px);}main div:nth-child(2) {transform: rotateY(90deg) translateZ(100px);flex-direction: column;justify-content: space-around;}main div:nth-child(3) {transform: rotateY(270deg) translateZ(100px);padding: 20px;box-sizing: border-box;}main div:nth-child(3) span:nth-child(1) {align-self: flex-start;}main div:nth-child(3) span:nth-child(3) {align-self: flex-end;}nav {width: 100%;height: 50px;display: flex;justify-content: space-around;}main div:nth-child(4) {transform: rotateY(180deg) translateZ(100px);}main div:nth-child(5) {transform: rotateX(90deg) translateZ(100px);}main div:nth-child(6) {transform: rotateX(270deg) translateZ(100px);}</style>
</head><body><h1>3D效果</h1><pre>transform 属性的值translate(x,y)、translateX(x)、translateY(y)、translateZ(z)、translate3d(x,y,z) 定义位置的移动距离scale(x,y)、scaleX(x)、scaleY(y)、scaleZ(z)、scale3d(x,yz) 定义元素的缩放比例rotate(angle)、rotateX(angle)、rotateY(angle)、rotateZ(angle)、rotate3d(x,y,z,angle) 定义元素的旋转度skew(x-angle,y-angle)、skewX(angle)、skewY(angle) 定义元素的倾斜度                     perspective 属性该属性用于激活一个3D空间,其子元素都会获得透明效果,一般 perspective 属性用于父元素。取值为 none 或 不设置,则为不激活3D空间取值越小,3D效果越明显,建议取值为元素的宽度transform-origin 属性用来改变元素原点的位置,取值:center 默认值 等价于( center center / 50% 50%)top/right/bottom/lefttransform-origin : x y z
</pre><div class="wrap"><div class="cube"><div class="front">前</div><div class="back">后</div><div class="left">左</div><div class="right">右</div><div class="top">上</div><div class="bottom">下</div></div></div><!------------------------------------------------------ --><div><main><div><span></span></div><div><span></span><span></span></div><div><span></span><span></span><span></span></div><div><nav><span></span><span></span></nav><nav><span></span><span></span></nav></div><div><nav><span></span><span></span></nav><nav><span></span></nav><nav><span></span><span></span></nav></div><div><nav><span></span><span></span></nav><nav><span></span><span></span></nav><nav><span></span><span></span></nav></div></main></div><script>var mouseDown = false;var mousePoint = { x: 0, y: 0 };var cubeRotate = { x: 0, y: 0 };window.onload = function () {document.onmousedown = function (e) {mouseDown = true;mousePoint.x = e.pageX;mousePoint.y = e.pageY;}document.onmousemove = function (e) {if (mouseDown) {let x = e.pageX - mousePoint.x;let y = e.pageY - mousePoint.y;cubeRotate.x += x / 30;cubeRotate.y += y / 30;document.querySelector('.cube').style = `transition:linear;transform:rotateX(${cubeRotate.x}deg) rotateY(${cubeRotate.y}deg)`;}}document.onmouseup = function (e) {mouseDown = false;}}</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/416806.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C#winform上位机开发学习笔记3-串口助手的信息保存功能添加

1.功能描述 下次开启串口助手时会存留上次的发送框信息&#xff0c;以及选择的串口号&#xff08;备份串口号与发送栏内容&#xff09; 原理&#xff1a;将文本信息保存在,ini文件中&#xff0c;下次打开软件时读取文件信息刷新对应控件文本 注意&#xff1a;在窗口关闭事件…

流量控制与熔断利器:Sentinel介绍

这是《百图解码支付系统设计与实现》专栏系列文章中的第&#xff08;19&#xff09;篇&#xff0c;也是流量控制系列的第&#xff08;6&#xff09;篇。点击上方关注&#xff0c;深入了解支付系统的方方面面。 本篇聊聊流量控制与熔断利器Sentinel&#xff0c;背后的原理&…

AWS 专题学习 P5 (Classic SA、S3)

文章目录 Classic Solutions Architecture无状态 Web 应用程序&#xff1a;WhatIsTheTime.com背景 & 目标架构演进Well-Architected 5 pillars 有状态的 Web 应用程序&#xff1a;MyClothes.com背景 & 目标架构演进总结 有状态的 Web 应用程序&#xff1a;MyWordPress.…

【51单片机】动态数码管

0、前言 参考&#xff1a; 普中51单片机开发攻略–A2.pdf 1、数码管介绍 上一章我们主要是介绍一位数码管的内部结构及控制原理。下面我们再来介 绍下多位数码管及动态显示原理的相关知识。 1.1 多位数码管简介 2、74HC245 和 74HC138 芯片介绍 2.1 74HC245 芯片简介 2.2 7…

数据结构排序二叉树(下)

哎,调了几天深度学习模型,今天来更新排序二叉树 文章目录 前言 一、排序二叉树的结构定义 二、在排序二叉树添加数据 三、定义创建排序二叉树函数 四、查找一棵二叉排序树中的结点x的所在层数 五、删除二叉排序树中T关键字x的节点 六、查找二叉排序树中的所有小于key的关…

数字化变革时代|打破瓶颈 海格里斯HEGERLS四向穿梭车系统技术的新突破

数字化转型是国内外市场环境的必然趋势, 从各大中小企业的创新驱动力来说&#xff0c;物联网、云计算、人工智能、大数据等等&#xff0c;都是创新的技术革命&#xff0c;也是当前大环境下所追寻的数字化变革。面对数字化制造时代的到来&#xff0c;河北沃克不失时机地布局了自…

【人工智能平台】ubuntu22.04.3部署cube-studio

简介&#xff1a;本次安装是在虚拟机上进行&#xff0c;需要给虚拟机至少分配16GB&#xff0c;分配8GB时系统会卡死。 一、环境&#xff1a; 主机环境&#xff1a;win11&#xff08;全程科学&#xff09;vm虚拟机 虚拟机&#xff1a;ubuntu22.04.3桌面版&#xff08;新装&…

Unity vs Godot :哪个游戏引擎更适合你?

Unity vs Godot &#xff1a;哪个游戏引擎更适合你&#xff1f; 游戏引擎的选择对开发过程和最终产品质量有着重大影响。近年来&#xff0c;Godot和Unity这两款引擎受到广泛关注。本文将从多个维度对两者进行比较&#xff0c;以期为开发者提供正确的选择建议。 Godot和Unity都有…

Spring的@Async使用防坑

很多人会直接只用Async来执行异步操作。但是这里面有一个问题&#xff0c;如果都是用spring的默认实现&#xff0c;是有坑的。 当我们开启 EnableAsync注解 就可以使用Async注解来执行异步操作了。 我们现在通过EnableAsync注解去打开spring异步世界的坑。 走JDK的动态代理&a…

力扣 | 11. 盛最多水的容器

双指针解法–对撞指针 暴力解法public int maxArea1(int[] height) {int n height.length;int ans 0;for (int i 0; i < n; i) {for (int j i 1; j < n; j) {int area Math.min(height[i], height[j]) * (j - i);ans Math.max(ans, area);}}return ans;}双指针解法…

探索curl的高级应用:HTTP请求的大师级技巧

探索curl的高级应用&#xff1a;HTTP请求的大师级技巧 引言高级用法概览1. HTTP请求与响应处理2. 身份验证与安全3. 进阶技巧4. Cookie管理与会话保持5. 脚本自动化 HTTP请求与响应处理1. 自定义请求头2. 发送数据3. 处理响应 身份验证与安全1. 基本认证2. 摘要认证3. HTTPS安全…

MyBatis框架基础到进阶

1、为什么要学习MyBatis 如果没有MyBatis框架&#xff0c;我们依靠JDBC和连接池已经能够很好的和数据库进行交互了&#xff0c;而学习MyBatis框架最核心的原因是为了减少SQL语句对代码的侵入性。 因为在过往不管是使用连接池还是JDBC Templete&#xff0c;所有的SQL语句都写在代…