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);

相关推荐
聊聊MES那点事2 小时前
报表控件Stimulsoft Reports.NET使用教程:发票报告设计
前端·javascript·html·报表工具
予你@。2 小时前
Vue2 使用 html2canvas 将 HTML 生成图片并上传到服务器
前端·html
星晨雪海2 小时前
优惠券秒杀的核心业务逻辑
java·前端·数据库
Bigger2 小时前
第五章:我是如何剖析 Claude Code 的 MCP 服务与插件生态系统的
前端·ai编程·claude
许彰午2 小时前
# 政务表单动态建表?运行时DDL引擎,前端拖完字段后端直接建
java·前端·后端·架构·政务
San30.2 小时前
前端渲染:从 CSR、SSR 到同构与手写 Vite+React SSR 实践
前端·react.js·前端框架
三声三视2 小时前
React 19 正式发布!17 个新特性深度解析与迁移指南(2026 实战版)
前端·javascript·reactjs·react
滴滴答答哒2 小时前
c#将平铺列表转换为树形结构(支持孤儿节点作为独立根节点)
java·前端·c#
雨季mo浅忆2 小时前
第四项目梳理
前端·面试·vue2