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

相关推荐
JustNow_Man4 分钟前
“失败后自动拉起修复 Agent”的闭环流水线
前端·人工智能·chrome·python
Dxy12393102167 分钟前
HTML中如何写键盘事件
前端·html·计算机外设
霍格沃兹测试学院-小舟畅学8 分钟前
接口自动化测试的下一个十年:从脚本到Skills,让AI学会“如何测”
java·前端·人工智能
huangfuyk11 分钟前
前端使用Cursor编辑器方面遇到的问题及注意细节
前端·编辑器·ai编程·cursor
ZC跨境爬虫14 分钟前
跟着 MDN 学CSS day_31:(精通链接样式,从伪类到导航菜单)
前端·javascript·css·ui·交互
发现你走远了23 分钟前
前端多环境自动化部署实战:GitHub Actions + Azure Blob + Cloudflare
前端·自动化·github
香香爱编程24 分钟前
vue3自定义顶部弹窗
前端·javascript·vue.js
weelinking34 分钟前
【产品】10_搭建前端框架——把你的原型变成真实页面
java·大数据·前端·数据库·人工智能·python·前端框架
蜡台35 分钟前
Vue Echart 的 **高阶组件化** 封装思路
前端·javascript·vue.js·echarts
xuankuxiaoyao35 分钟前
vue.js 路由第二篇
前端·javascript·vue.js