HTMLCSS:3D旋转动画机器人摄像头

效果演示

创建了一个3D机器人摄像头效果。

HTML

<div class="modelViewPort"><div class="eva"><div class="head"><div class="eyeChamber"><div class="eye"></div><div class="eye"></div></div></div><div class="body"><div class="hand"></div><div class="hand"></div><div class="scannerThing"></div><div class="scannerOrigin"></div></div></div>
</div>
  • modelViewPort类包含.eva类的div元素,它代表模型本身。
  • .eva类又包含了.head和.body两个部分,分别代表模型的头部和身体。
  • 头部包含两个.eye元素,代表眼睛。
  • 身体包含两个.hand元素代表手,一个.scannerThing代表扫描器的光束,以及一个.scannerOrigin代表扫描器的起点。

CSS

.modelViewPort {perspective: 1000px;width: 20rem;aspect-ratio: 1;border-radius: 50%;display: flex;justify-content: center;align-items: center;background: #000;overflow: hidden;
}.eva {--EVA-ROTATION-DURATION: 4s;transform-style: preserve-3d;animation: rotateRight var(--EVA-ROTATION-DURATION) linear infinite alternate;
}.head {position: relative;width: 6rem;height: 4rem;border-radius: 48% 53% 45% 55% / 79% 79% 20% 22%;background: linear-gradient(to right, white 45%, gray);
}.eyeChamber {width: 4.5rem;height: 2.75rem;position: relative;left: 50%;top: 55%;border-radius: 45% 53% 45% 48% / 62% 59% 35% 34%;background-color: #0c203c;box-shadow: 0px 0px 2px 2px white, inset 0px 0px 0px 2px black;transform: translate(-50%, -50%);animation: moveRight var(--EVA-ROTATION-DURATION) linear infinite alternate;
}.eye {width: 1.2rem;height: 1.5rem;position: absolute;border-radius: 50%;
}.eye:first-child {left: 12px;top: 50%;background: repeating-linear-gradient(65deg,#9bdaeb 0px,#9bdaeb 1px,white 2px);box-shadow: inset 0px 0px 5px #04b8d5, 0px 0px 15px 1px #0bdaeb;transform: translate(0, -50%) rotate(-65deg);
}.eye:nth-child(2) {right: 12px;top: 50%;background: repeating-linear-gradient(-65deg,#9bdaeb 0px,#9bdaeb 1px,white 2px);box-shadow: inset 0px 0px 5px #04b8d5, 0px 0px 15px 1px #0bdaeb;transform: translate(0, -50%) rotate(65deg);
}.body {width: 6rem;height: 8rem;position: relative;margin-block-start: 0.25rem;border-radius: 47% 53% 45% 55% / 12% 9% 90% 88%;background: linear-gradient(to right, white 35%, gray);
}.hand {position: absolute;left: -1.5rem;top: 0.75rem;width: 2rem;height: 5.5rem;border-radius: 40%;background: linear-gradient(to left, white 15%, gray);box-shadow: 5px 0px 5px rgba(0, 0, 0, 0.25);transform: rotateY(55deg) rotateZ(10deg);
}.hand:first-child {animation: compensateRotation var(--EVA-ROTATION-DURATION) linear infinite alternate;
}.hand:nth-child(2) {left: 92%;background: linear-gradient(to right, white 15%, gray);transform: rotateY(55deg) rotateZ(-10deg);animation: compensateRotationRight var(--EVA-ROTATION-DURATION) linear infinite alternate;
}.scannerThing {width: 0;height: 0;position: absolute;left: 60%;top: 10%;border-top: 180px solid #9bdaeb;border-left: 250px solid transparent;border-right: 250px solid transparent;transform-origin: top left;mask: linear-gradient(to right, white, transparent 35%);animation: glow 2s cubic-bezier(0.86, 0, 0.07, 1) infinite;
}.scannerOrigin {position: absolute;width: 8px;aspect-ratio: 1;border-radius: 50%;left: 60%;top: 10%;background: #9bdaeb;box-shadow: inset 0px 0px 5px rgba(0, 0, 0, 0.5);animation: moveRight var(--EVA-ROTATION-DURATION) linear infinite;
}@keyframes rotateRight {from {transform: rotateY(0deg);}to {transform: rotateY(25deg);}
}@keyframes moveRight {from {transform: translate(-50%, -50%);}to {transform: translate(-40%, -50%);}
}@keyframes compensateRotation {from {transform: rotateY(55deg) rotateZ(10deg);}to {transform: rotatey(30deg) rotateZ(10deg);}
}@keyframes compensateRotationRight {from {transform: rotateY(55deg) rotateZ(-10deg);}to {transform: rotateY(70deg) rotateZ(-10deg);}
}@keyframes glow {from {opacity: 0;}20% {opacity: 1;}45% {transform: rotate(-25deg);}75% {transform: rotate(5deg);}100% {opacity: 0;}
}
  • modelViewPort类为模型提供了一个视口,设置了透视效果、尺寸、宽高比、边框半径、显示方式、背景颜色和溢出隐藏。
  • .eva类定义了模型的3D变换样式,包括一个自定义属性–EVA-ROTATION-DURATION用于定义动画持续时间,以及一个无限循环的rotateRight动画。
  • .head类定义了头部的位置、尺寸和背景渐变。
  • .eyeChamber类定义了眼睛腔室的位置、尺寸、背景颜色和阴影,以及一个moveRight动画。
  • .eye类定义了眼睛的基本样式。
  • .body类定义了身体的位置、尺寸和背景渐变。
  • .hand类定义了手的位置、尺寸和背景渐变,以及两个手的不同动画。
  • .scannerThing和.scannerOrigin类定义了扫描器的样式和动画。
  • @keyframes定义了所有的动画效果,包括rotateRight、moveRight、compensateRotation、compensateRotationRight和glow。

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

docker占用磁盘过多问题

我在windows系统上用docker&#xff0c;安装在C盘环境下&#xff0c;我发现C盘占用了大量的空间&#xff0c;查找后发现是docker的映像文件占用的&#xff0c;于是开始清理&#xff0c;中间还踩个坑&#xff0c;记录一下&#xff0c;下次需要的时候方便找。 踩坑 我本想移动映…

Flink本地模式安装详解

1. 概述 Apache Flink 支持多种安装和运行模式&#xff0c;主要可以分为以下几种&#xff1a; Local&#xff08;本地&#xff09;模式&#xff1a; 这种模式主要用于学习和测试&#xff0c;所有的 Flink 组件都会在同一个 JVM 进程中运行。这种方式非常适合初学者了解 Flink…

Uniapp 实现app自动检测更新/自动更新功能

实现步骤 配置 manifest.json 在 manifest.json 中设置应用的基本信息&#xff0c;包括 versionName 和 versionCode。 一般默认0.0.1&#xff0c;1. 服务器端接口开发 提供一个 API 接口&#xff0c;返回应用的最新版本信息&#xff0c;版本号、下载链接。客户端检测更新 使…

java访问华为网管软件iMaster NCE的北向接口

最近做的一个项目&#xff0c;需要读取华为一个叫iMaster NCE的网管软件的北向接口。这个iMaster NCE&#xff08;以下简称NCE&#xff09;用于管理项目的整个网络&#xff0c;尤其是光网络。业主要求我们访问该软件提供的对外接口&#xff0c;读取一些网络信息&#xff0c;比如…

docker基础篇(尚硅谷)

学习链接 docker1️⃣基础篇&#xff08;零基小白&#xff09; - 语雀文档 (即本篇) Docker与微服务实战&#xff08;基础篇&#xff09; Docker与微服务实战&#xff08;高级篇&#xff09;- 【上】 Docker与微服务实战&#xff08;高级篇&#xff09;- 【下】 文章目录 学习…

华为通过FTP进行文件操作示例

小知学网络-CSDN博客 目录 通过FTP进行文件操作简介 配置注意事项 组网需求 配置思路 操作步骤 配置文件 组网图形 图1 通过FTP进行文件操作组网图 通过FTP进行文件操作简介配置注意事项组网需求配置思路操作步骤配置文件相关信息 通过FTP进行文件操作简介 配置设备作…

嵌入式开发教程之Linux下IO流

一、文件的概念和类型 文件基础&#xff1a; 概念&#xff1a;一组相关数据的有序集合&#xff0c;文件名、路径。通过文件名指定访问什么文件。 文件类型&#xff1a; 常规文件 r&#xff0c;分为&#xff1a;普通文件&#xff0c;文本文件&#xff08;可见字符&#xff09…

Rust 力扣 - 48. 旋转图像

文章目录 题目描述题解思路题解代码题目链接 题目描述 题解思路 我们可以将原矩阵进行水平翻转&#xff0c;然后在沿主对角线进行翻转&#xff0c;就能完成原矩阵沿顺时针方向旋转90o的变换 题解代码 impl Solution {pub fn rotate(matrix: &mut Vec<Vec<i32>&…

MySQL 8.0在windows环境安装及配置

文章目录 一、下载二、安装三、配置环境变量 一、下载 1、先彻底卸载之前的MySQL&#xff0c;并清理其 残留文件 。 2、登录网址https://www.mysql.com/ 3、点击网址左下角“中文”按钮&#xff0c;切换到中文界面 4、点击网页上方的“下载”按钮&#xff0c;然后点击网页…

Sleep_Monitor 2.7.9.2 | 您的个人睡眠助手,帮助您睡得更好

晚上入睡困难吗&#xff1f;Sleep Monitor 是您的睡眠专家&#xff01;这款应用程序可以追踪并记录您的睡眠周期&#xff0c;让您早晨醒来时精神焕发&#xff0c;准备好迎接新的一天。Sleep Monitor 是一个功能丰富的程序&#xff0c;让睡眠变得更加愉快。通过追踪您的打鼾、梦…

基于SSM+微信小程序的汽车维修管理系统(汽车5)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1、项目介绍 基于SSM微信小程序的汽车维修管理系统实现了三个角色&#xff1a;管理员、员工、用户。 1、管理员实现了首页、管理员管理员、员工管理、用户管理、车辆信息管理、配件管理等 2、员工实…

『Linux学习笔记』如何在 Ubuntu 22.04 上安装和配置 VNC

『Linux学习笔记』如何在 Ubuntu 22.04 上安装和配置 VNC 文章目录 一. 『Linux学习笔记』如何在 Ubuntu 22.04 上安装和配置 VNC1. 介绍 二. 参考文献 一. 『Linux学习笔记』如何在 Ubuntu 22.04 上安装和配置 VNC 如何在 Ubuntu 22.04 上安装和配置 VNChttps://hub.docker.c…

jvm学习笔记-轻量级锁内存模型

一&#xff0c;轻量级锁 LockRecord的那个第一个成员变量是拷贝对应锁定了的java对象资源的MarkWord&#xff0c;Lock Record有一个Ptr指针刚开始指向自己&#xff0c;后面这个指针存储在锁定资源的java对象的markword中&#xff0c;后续可以通过java对象的MarkWord快速定位到…

在Windows 10上安装Tesseract并用pytesseract运行OCR任务

诸神缄默不语-个人CSDN博文目录 文章目录 1. Tesseract安装2. pytesseract的安装与使用3. 手动安装其他语种并在pytesseract中调用4. 本文撰写过程中参考的其他网络资料 1. Tesseract安装 Tesseract官方GitHub项目链接&#xff1a;https://github.com/tesseract-ocr/tesseract…

golang的多表联合orm

项目截图 1.数据库连接配置 DbConfigUtil.go package configimport ( "fmt" _ "github.com/go-sql-driver/mysql" "gorm.io/driver/mysql" "gorm.io/gorm" "gorm.io/gorm/logger" "gorm.io/gorm/schema" )var Go…

ONLYOFFICE 8.2版本桌面编辑器评测

目录 ONLYOFFICE 8.2版本桌面编辑器评测一、引言二、ONLYOFFICE 桌面编辑器概述2.1 功能特点2.2 系统支持2.3 数据表&#xff1a;ONLYOFFICE 桌面编辑器功能概述 三、ONLYOFFICE 协作空间3.1 协作功能3.2 部署和集成3.3 数据表&#xff1a;ONLYOFFICE 协作空间功能概述 四、ONL…

图片懒加载(自定义指令)

----------------------------------------------------------- 图片懒加载自定义指令使用mock模拟随机图片列表组件如下&#xff08;主要内容&#xff09;&#xff1a;配置自定义指令 图片懒加载 实现思路 使用自定义指令实现通用图片懒加载&#xff08;在图片到达视口内时再…

三层交换技术,eNSP实验讲解

三层交换技术&#xff0c;eNSP实验讲解 一、简要介绍1、概念2、工作原理3、优点4、应用场景5、与路由器的区别 二、eNSP仿真实验1、步骤一&#xff1a;创建连接&#xff0c;明确参数。2、步骤二&#xff1a;设置PC1和PC2参数3、步骤三&#xff1a;配置交换机&#xff0c;通过命…

扫雷(C语言)

目录​​​​​​​ 前言 一、前提知识 二、扫雷游戏编写 2.2 test文件基本逻辑 2.2.1菜单编写 2.2.2game函数的逻辑 2.2.2.1定义两个数组 2.2.2.2两个数组数组的初始化 2.2.2.3打印棋盘 2.2.2.4布置雷 2.2.2.5排查雷 2.2.2.6获取坐标附近雷的数量 2.2.2.7什么时候…

Node.js:模块 包

Node.js&#xff1a;模块 & 包 模块module对象 包npm安装包配置文件镜像源 分类 模块 模块化是指解决一个复杂问题时&#xff0c;自顶向下逐层把系统划分成若干模块的过程。对于整个系统来说&#xff0c;模块是可组合、分解和更换的单元。 简单来说&#xff0c;就是把一个…