three实现三维古塔景色场景代码

代码语言:html

所属分类:三维

代码描述:three实现三维黄塔景色场景代码,可更改时间,有鸟、有树木、有山

代码标签: three 三维 古塔 景色 场景 代码

下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>古塔风景</title>
    <style>
        * { margin: 0; padding: 0; box-sizing: border-box; }
        body { overflow: hidden; }
        canvas { display: block; }
        
        #info {
            position: absolute;
            bottom: 20px;
            left: 50%;
            transform: translateX(-50%);
            background: rgba(0,0,0,0.6);
            color: white;
            padding: 15px 30px;
            border-radius: 30px;
            font-family: 'Microsoft YaHei', sans-serif;
            font-size: 14px;
            backdrop-filter: blur(10px);
            border: 1px solid rgba(255,255,255,0.1);
        }
        
        #title {
            position: absolute;
            top: 30px;
            left: 50%;
            transform: translateX(-50%);
            color: white;
            font-family: 'Microsoft YaHei', sans-serif;
            font-size: 28px;
            text-shadow: 2px 2px 10px rgba(0,0,0,0.5);
            letter-spacing: 5px;
        }
        
        #time-control {
            position: absolute;
            top: 30px;
            right: 30px;
            background: rgba(0,0,0,0.6);
            padding: 15px 20px;
            border-radius: 15px;
            color: white;
            font-family: 'Microsoft YaHei', sans-serif;
            backdrop-filter: blur(10px);
        }
        
        #time-control label {
            display: block;
            margin-bottom: 8px;
            font-size: 14px;
        }
        
        #time-slider {
            width: 150px;
            cursor: pointer;
        }
        
        #loading {
            position: fixed;
            top: 0; left: 0;
            width: 100%; height: 100%;
            background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
            display: flex;
            justify-content: center;
            align-items: center;
            z-index: 1000;
            transition: opacity 1s;
        }
        
        #loading span {
            color: white;
            font-size: 24px;
            font-family: 'Microsoft YaHei', sans-serif;
        }
        
        .dot {
            animation: blink 1.4s infinite;
        }
        .dot:nth-child(2) { animation-delay: 0.2s; }
        .dot:nth-child(3) { animation-delay: 0.4s; }
        
        @keyframes blink {
            0%, 20% { opacity: 0; }
            50% { opacity: 1; }
            100% { opacity: 0; }
        }
    </style>
</head>
<body>
    <div id="loading">
        <span>正在生成美景<span class="dot">.</span><span class="dot">.</span><span class="dot">.</span></span>
    </div>
    
    <div id="title">🏯 山间古塔</div>
    
    <div id="time-control">
        <label>☀️ 时间: <span id="time-display">正午</span></label>
        <input type="range" id="time-slider" min="0" max="100" value="50">
    </div>
    
    <div id="info">🖱️ 拖拽旋转视角 | 滚轮缩放 | 右键平移</div>

    <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/three@0.128.0/examples/js/controls/OrbitControls.js"></script>
    <script>
        let scene, camera, renderer, controls;
        let sun, sunLight, sky;
        let timeOfDay = 0.5;
        let clouds = [];
        let waterMesh;
        let birds = [];
        
        function init() {
            // 场景
            scene = new THREE.Scene();
            
            // 相机
            camera = new THREE.Perspec.........完整代码请登录后点击上方下载按钮下载查看

网友评论0