Web 3D 正方体贴图

在网页上做一个正方体,然后在各个面贴不同的图;

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <title>three.js canvas - geometry - cube</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, minimum-scale=1.0, maximum-scale=1.0">
    <style>
        body {
            font-family: Monospace;
            background-color: #f0f0f0;
            margin: 0px;
            overflow: hidden;
        }
    </style>
</head>
<body>

<script src="js/three.min.js"></script>
<script src="js/OrbitControls.js"></script>
<script src="js/Projector.js"></script>
<script src="js/CanvasRenderer.js"></script>

<script>

    var container;

    var camera, scene, renderer;

    var cube, plane;

    var controls;

    init();
    animate();

    function init() {

        container = document.createElement('div');
        document.body.appendChild(container);
        var info = document.createElement('div');
        info.style.position = 'absolute';
        info.style.top = '10px';
        info.style.width = '100%';
        info.style.textAlign = 'center';
        info.innerHTML = '鼠标拖动旋转正方体';
        container.appendChild(info);

        camera = new THREE.PerspectiveCamera(70, window.innerWidth / window.innerHeight, 1, 10000);
        camera.position.y = 0;
        camera.position.z = 800;
        camera.position.x = 0;
        controls = new THREE.OrbitControls(camera);

        scene = new THREE.Scene();
        scene.background = new THREE.Color(0x9F9F5F);


        // Cube

        var geometry = new THREE.BoxGeometry(250, 250, 250);
        var materialsbg = [];

        for (var i = 0; i < geometry.faces.length / 2; i += 1) {
            var material = new THREE.MeshBasicMaterial({
                map: THREE.ImageUtils.loadTexture('./css/images/' + (i + 1) + '.png',
                )
            });
            materialsbg[i] = material

        }

        cube = new THREE.Mesh(geometry, materialsbg);
        scene.add(cube);

        renderer = new THREE.CanvasRenderer();
        renderer.setPixelRatio(window.devicePixelRatio);
        renderer.setSize(window.innerWidth, window.innerHeight);
        container.appendChild(renderer.domElement);

    }

    function animate() {

        requestAnimationFrame(animate);
        controls.update();
        renderer.render(scene, camera);

    }

</script>

</body>
</html>

var info = document.createElement('div');

这个是放文字的div;

贴图首先是定义一个box,

var geometry = new THREE.BoxGeometry(250, 250, 250);

一个数组用来存放纹理图片,

var materialsbg = [];

逐个获取图片转换为Material,存入数组;

var material = new THREE.MeshBasicMaterial({

map: THREE.ImageUtils.loadTexture('....'

)

});

创建正方体的时候使用Mesh类,第一个参数是BoxGeometry类型,第二个参数是纹理图片数组;

cube = new THREE.Mesh(geometry, materialsbg);

相关推荐
云水一下2 小时前
从零开始!VMware安装Fedora Workstation 44桌面系统完整教程
前端
小码哥_常3 小时前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd3 小时前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码14 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen4 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦4 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen4 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
千寻girling5 小时前
《 Git 详细教程 》
前端·后端·面试
之歆6 小时前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css
yqcoder6 小时前
CSS Position 全解析:5 种定位模式详解
前端·css