3D立体墙照片

handlebars 复制代码
<!DOCTYPE html>
<html lang="en">

<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>Document</title>
    <style>
        html,
        body {
            margin: 0;
            padding: 0;
        }
        
        * {
            box-sizing: border-box;
        }
        
        body {
            background-color: #2f3542;
        }
        
        main {
            display: flex;
            align-items: center;
            justify-content: center;
            height: 100vh;
        }
        
        .cube {
            width: 250px;
            height: 250px;
            transform-style: preserve-3d;
            animation: rotate-cobe 10s ease-in-out infinite;
        }
        
        .cube>div {
            width: 250px;
            height: 250px;
            background-size: cover;
            background-position: center center;
            opacity: 0.8;
            position: absolute;
            box-shadow: inset 0 0 4px 2px rgba(106, 106, 106, 0.4);
        }
        /* 前 */
        
        .cube .img1 {
            background-image: url("https://ns-strategy.cdn.bcebos.com/ns-strategy/upload/fc_big_pic/part-00323-3881.jpg");
            transform: translateZ(125px);
        }
        /* 右 */
        
        .cube .img2 {
            background-image: url("https://img0.baidu.com/it/u=3607416692,1659289502&fm=253&fmt=auto&app=120&f=JPEG?w=1200&h=750");
            transform: rotateY(90deg) translateZ(125px);
        }
        /* 左 */
        
        .cube .img3 {
            background-image: url("https://img2.baidu.com/it/u=667685406,1155663261&fm=253&fmt=auto&app=138&f=JPEG?w=889&h=500");
            transform: rotateY(-90deg) translateZ(125px);
        }
        /* 下 */
        
        .cube .img4 {
            background-image: url("https://img2.baidu.com/it/u=1547725493,4110294476&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=500");
            transform: rotateX(90deg) translateZ(125px);
        }
        /* 上 */
        
        .cube .img5 {
            background-image: url("https://img1.baidu.com/it/u=2345344959,2598464592&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=313");
            transform: rotateX(-90deg) translateZ(125px);
        }
        /* 后 */
        
        .cube .img6 {
            background-image: url("https://img1.baidu.com/it/u=475796613,1666623793&fm=253&fmt=auto&app=120&f=JPEG?w=1140&h=641");
            transform: rotateY(180deg) translateZ(125px);
        }
        
        @keyframes rotate-cobe {
            0% {
                transform: rotateX(0deg) rotateY(0deg);
            }
            20% {
                /* 右边图片 */
                transform: rotateY(-90deg);
            }
            40% {
                /* 上 */
                transform: rotateX(-90deg);
            }
            60% {
                /* 左 */
                transform: rotateY(90deg);
            }
            80% {
                /* 下 */
                transform: rotate(90deg);
            }
            100% {
                transform: rotateX(0deg) rotateY(0deg);
            }
        }
    </style>
</head>

<body>
    <main>
        <div class="cube">
            <div class="img1"></div>
            <div class="img2"></div>
            <div class="img3"></div>
            <div class="img4"></div>
            <div class="img5"></div>
            <div class="img6"></div>
        </div>
    </main>
</body>

</html>
相关推荐
伍哥的传说10 小时前
CSS+JavaScript 禁用浏览器复制功能的几种方法
前端·javascript·css·vue.js·vue·css3·禁用浏览器复制
星图云15 小时前
Mirauge3D 赋能:全自动建模,让城市规划与建筑设计拥有高分辨率实景三维模型
3d
点云SLAM16 小时前
Pytorch中cuda相关操作详见和代码示例
人工智能·pytorch·python·深度学习·3d·cuda·多gpu训练
结城18 小时前
深入掌握CSS Grid布局:每个属性详解与实战示例
前端·css
寒..18 小时前
网络安全第三次作业
前端·css·html
小白阿龙18 小时前
如何实现缓存音频功能(App端详解)
前端·css·html5
smile boy18 小时前
个人财务记录应用
前端·javascript·css·css3·html5
云飞云共享云桌面1 天前
制造工厂高效出图新技术——共享云桌面
运维·服务器·网络·3d·自动化·制造
FogLetter2 天前
从零复刻网易云音乐年度总结H5:技术细节与用户体验的完美结合
前端·css
前端老鹰2 天前
CSS mask-image:给元素 “戴” 上创意面具的隐藏技巧
前端·css