css实现3d照片墙

效果图 

vue2写法: 

<template><div class="container"><div class="box"><div class="circle circle1"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle2"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle3"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle4"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle5"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle6"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle7"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle8"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle9"><img src="../../../assets/images/main/logo.png" alt="" /></div><div class="circle circle10"><img src="../../../assets/images/main/logo.png" alt="" /></div></div></div>
</template><script></script><style lang="less" scoped>
* {margin: 0;padding: 0;box-sizing: border-box;
}/* 设置可视窗口的宽高 */
body {width: 100vw;height: 100vh;position: relative;background-color: pink;
}.container {position: absolute;width: 1000px;height: 500px;top: 15%;left: 50%;transform: translateX(-50%);z-index: 1;display: flex;justify-content: center;align-items: center;perspective: 1000px;
}.box {width: 150px;height: 150px;position: relative;transform-style: preserve-3d;animation: run 10s linear infinite;
}.circle {position: absolute;top: 0;left: 0;width: 150px;height: 150px;
}/*设置图像大小、边框、圆角、位置*/
.circle img {width: 200px;height: 150px;border: 1px solid #ccc;border-radius: 10px;box-sizing: border-box;
}.circle1 {transform: translateZ(500px);
}.circle2 {transform: rotateY(36deg) translateZ(500px);
}.circle3 {transform: rotateY(72deg) translateZ(500px);
}.circle4 {transform: rotateY(108deg) translateZ(500px);
}.circle5 {transform: rotateY(144deg) translateZ(500px);
}.circle6 {transform: rotateY(180deg) translateZ(500px);
}.circle7 {transform: rotateY(216deg) translateZ(500px);
}.circle8 {transform: rotateY(252deg) translateZ(500px);
}.circle9 {transform: rotateY(288deg) translateZ(500px);
}.circle10 {transform: rotateY(324deg) translateZ(500px);
}@keyframes run {0% {transform: rotateY(0);}100% {transform: rotateY(360deg);}
}
</style>

html写法:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>动画2</title>
</head><body><style>* {margin: 0;padding: 0;box-sizing: border-box;}/* 设置可视窗口的宽高 */body {width: 100vw;height: 100vh;position: relative;background-color: pink;}.container {position: absolute;width: 1000px;height: 500px;top: 15%;left: 50%;transform: translateX(-50%);z-index: 1;display: flex;justify-content: center;align-items: center;perspective: 1000px;}.box {width: 150px;height: 150px;position: relative;transform-style: preserve-3d;animation: run 10s linear infinite;}.circle {position: absolute;top: 0;left: 0;width: 150px;height: 150px;}/*设置图像大小、边框、圆角、位置*/.circle img {width: 200px;height: 150px;border: 1px solid #ccc;border-radius: 10px;box-sizing: border-box;}.circle1 {transform: translateZ(500px);}.circle2 {transform: rotateY(36deg) translateZ(500px);}.circle3 {transform: rotateY(72deg) translateZ(500px);}.circle4 {transform: rotateY(108deg) translateZ(500px);}.circle5 {transform: rotateY(144deg) translateZ(500px);}.circle6 {transform: rotateY(180deg) translateZ(500px);}.circle7 {transform: rotateY(216deg) translateZ(500px);}.circle8 {transform: rotateY(252deg) translateZ(500px);}.circle9 {transform: rotateY(288deg) translateZ(500px);}.circle10 {transform: rotateY(324deg) translateZ(500px);}@keyframes run {0% {transform: rotateY(0);}100% {transform: rotateY(360deg);}}</style><body><div class="container"><div class="box"><div class="circle circle1"><img src="./img/QQ图片20221114190101.jpg" alt=""></div><div class="circle circle2"><img src="./img/QQ图片20221114190057.jpg" alt=""></div><div class="circle circle3"><img src="./img/QQ图片20221114190053.jpg" alt=""></div><div class="circle circle4"><img src="./img/QQ图片20221114190048.jpg" alt=""></div><div class="circle circle5"><img src="./img/QQ图片20221114190044.jpg" alt=""></div><div class="circle circle6"><img src="./img/QQ图片20221114190038.jpg" alt=""></div><div class="circle circle7"><img src="./img/QQ图片20221114190014.jpg" alt=""></div><div class="circle circle8"><img src="./img/QQ图片20221114190008.jpg" alt=""></div><div class="circle circle9"><img src="./img/QQ图片20221114190002.jpg" alt=""></div><div class="circle circle10"><img src="./img/QQ图片20221114185953.jpg" alt=""></div></div></div></body>
</html>

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

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

相关文章

实战教程:如何利用Optimizer优化你的Windows系统?

前言 你是否厌倦了系统臃肿、隐私泄露的烦恼&#xff1f;小江湖今天就要带你走进一个全新的世界&#xff0c;一个能够让你重获自由与安心的神奇之地——Optimizer&#xff0c;一款专为Windows用户打造的深度优化神器&#xff1b;有了它你仅需轻轻一点&#xff0c;再也不用为系…

p13 数组

数组的创建 数组是一组相同类型元素的集合。数组的创建方式&#xff1a; type_t arr_name [const_n]; //type_t 是指数组的元素类型 //const_n 是一个常量表达式&#xff0c;用来指定数组的大小 int main() {//创建一个数字组-存放整型-10个int arr[10]{1,2,3}//不完全初始…

TensorFlow系列:第四讲:MobileNetV2实战

一. 加载数据集 编写工具类&#xff0c;实现数据集的加载 import keras""" 加载数据集工具类 """class DatasetLoader:def __init__(self, path_url, image_size(224, 224), batch_size32, class_modecategorical):self.path_url path_urlself…

物联网系统中市电电量计量方案(一)

为什么要进行电量计量&#xff1f; 节约资源&#xff1a;电量计量可以帮助人们控制用电量&#xff0c;从而达到节约资源的目的。在当前严峻的资源供应形势下&#xff0c;节约能源是我们应该重视的问题。合理计费&#xff1a;电表可以帮助公共事业单位进行合理计费&#xff0c;…

3.相机标定原理及代码实现(opencv)

1.相机标定原理 相机参数的确定过程就叫做相机标定。 1.1 四大坐标系及关系 &#xff08;1&#xff09;像素坐标系&#xff08;单位&#xff1a;像素&#xff08;pixel&#xff09;&#xff09; 像素坐标系是指相机拍到的图片的坐标系&#xff0c;以图片的左上角为坐标原点&a…

为校园后勤注入智慧:收件登记功能驱动全新体验

在智慧校园的后勤管理体系中&#xff0c;收件登记服务是一项旨在提升快递接收体验的创新举措&#xff0c;它无缝融合了现代科技与日常校园生活&#xff0c;为师生带来便捷与安心。 为应对日益增长的快递需求&#xff0c;师生可事先通过校园网平台或特制的移动应用预报快递信息&…

光学传感器图像处理流程(二)

光学传感器图像处理流程&#xff08;二&#xff09; 2.4. 图像增强2.4.1. 彩色合成2.4.2 直方图变换2.4.3. 密度分割2.4.4. 图像间运算2.4.5. 邻域增强2.4.6. 主成分分析2.4.7. 图像融合 2.5. 裁剪与镶嵌2.5.1. 图像裁剪2.5.2. 图像镶嵌 2.6. 遥感信息提取2.6.1. 目视解译2.6.2…

数字化时代的供应链管理综合解决方案

目录 引言背景与意义供应链管理综合解决方案的目标 &#x1f4c4;供应链管理系统主要功能系统优势 &#x1f4c4;物流管理系统主要功能系统优势 &#x1f4c4;订单管理系统主要功能应用场景 &#x1f4c4;仓储管理系统系统亮点主要功能系统优势 &#x1f4c4;商城管理系统主要功…

【python】QWidget父子关系,控件显示优先级原理剖析与应用实战演练

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

又是三道简单的web题(2)

一、cookie 1.打开后是如下页面&#xff0c;抓包&#xff0c;关注cookie 2.发现cookie中有一个文件 3.直接访问这个文件&#xff0c;得到flag 二、employeeswork 打开后页面如下&#xff1a; 点击后出现一串php代码 审一下这个代码&#xff0c;需要添加参数work并且赋值work…

Linux笔记之使用系统调用sendfile高速拷贝文件

Linux笔记之使用系统调用sendfile高速拷贝文件 code review! 文章目录 Linux笔记之使用系统调用sendfile高速拷贝文件sendfile 性能优势sendfile 系统调用优点&#xff1a;缺点&#xff1a; cp 命令优点&#xff1a;缺点&#xff1a; 实际测试&#xff1a;拷贝5.8个G的文件&a…

合合信息大模型加速器亮相WAIC大会:文档解析与文本识别新突破

合合信息大模型加速器亮相WAIC大会&#xff1a;文档解析与文本识别新突破 文章目录 合合信息大模型加速器亮相WAIC大会&#xff1a;文档解析与文本识别新突破前言合合信息TextIn平台&#xff1a;智能文档处理的领军者文档解析引擎&#xff1a;百页文档秒级处理大模型的发展背景…

【漏洞复现】Crocus系统——Download——文件读取

声明&#xff1a;本文档或演示材料仅供教育和教学目的使用&#xff0c;任何个人或组织使用本文档中的信息进行非法活动&#xff0c;均与本文档的作者或发布者无关。 文章目录 漏洞描述漏洞复现测试工具 漏洞描述 Crocus系统旨在利用人工智能、高清视频、大数据和自动驾驶技术&…

工程化-vue3+ts:代码检测工具 ESLint

一、理解ESLint ESLint是一个开源的JavaScript代码检查工具&#xff0c;用于帮助开发人员规范和统一编码风格。它可以检查代码中的潜在错误、不一致的编码习惯以及一些常见的代码问题。 ESLint使用基于规则的插件体系&#xff0c;可以根据项目的需求和个人的偏好配置不同的规…

数据库数据恢复—SQL Server数据库由于存放空间不足报错的数据恢复案例

SQL Server数据库数据恢复环境&#xff1a; 某品牌服务器存储中有两组raid5磁盘阵列。操作系统层面跑着SQL Server数据库&#xff0c;SQL Server数据库存放在D盘分区中。 SQL Server数据库故障&#xff1a; 存放SQL Server数据库的D盘分区容量不足&#xff0c;管理员在E盘中生…

MacOS如何切换shell类型

切换 shell 类型 如果你想在不同的 shell 之间切换&#xff0c;以探索它们的不同之处&#xff0c;或者因为你知道自己需要其中的一个或另一个&#xff0c;可以使用如下命令&#xff1a; 切换到 bash chsh -s $(which bash)切换到 zsh chsh -s $(which zsh)$()语法的作用是运…

FastGPT:给 GPT 插上知识库的翅膀!0基础搭建本地私有知识库,有手就行

写在前面 上一篇&#xff0c;我们部署了接口管理和分发神器-OneAPI&#xff0c;将所有大模型一键封装成OpenAI协议。见&#xff1a;[OneAPI)。 基于此&#xff0c;本篇继续带领大家搭建一个基于本地知识库检索的问答系统。 有同学说 Coze 不也可以实现同样功能么&#xff1f…

51单片机:电脑通过串口控制LED亮灭(附溢出率和波特率详解)

一、功能实现 1.电脑通过串口发送数据&#xff1a;0F 2.点亮4个LED 二、注意事项 1.发送和接受数据的文本模式 2.串口要对应 3.注意串口的波特率要和程序中的波特率保持一致 4.有无校验位和停止位 三、如何使用串口波特率计算器 1.以本程序为例 2.生成代码如下 void Uar…

[论文笔记]涨点近5%! 以内容中心的检索增强生成可扩展的级联框架:Pistis-RAG

引言 今天带来一篇较新RAG的论文笔记&#xff1a;Pistis-RAG: A Scalable Cascading Framework Towards Content-Centric Retrieval-Augmented Generation。 在希腊神话中&#xff0c;Pistis象征着诚信、信任和可靠性。受到这些原则的启发&#xff0c;Pistis-RAG是一个可扩展…