javascript - Three.js 纹理未应用于网格

标签 javascript three.js

我正在尝试使用以下内容将纹理应用到我的球体网格。

var loader =  new THREE.TextureLoader();
var balltex = loader.load("pic1.jpg");
var ballmat = new THREE.MeshBasicMaterial({ map:balltex }); 
var ballgeo = new THREE.SphereGeometry( 0.3, 20, 20 );
var ball = new THREE.Mesh( ballgeo , ballmat );
scene.add(ball);    

现在我只是得到一个黑色球体而不是纹理球体。我不知道代码有什么问题。
请帮助我。

最佳答案

如果没有完整的示例,很难确定,但我的第一个猜测是最简单的情况:渲染网格时纹理尚未完成加载。

如果这是问题所在,请确保在调用渲染循环之前加载纹理。有很多方法可以做到这一点,在没有看到代码的情况下很难说哪种方法最好,但最直接的处理方法是将函数传递给加载器的 load() 方法并调用渲染器从中。一个简单但完整的示例重新编写您发布的代码:

var scene, camera, light, renderer, balltex;

load();

function load() {
        var loader;

        loader = new THREE.TextureLoader(new THREE.LoadingManager());
        loader.load('pic1.jpg', function(obj) {
                balltex = obj;
                init();
                animate();
        });
}

function init() {
        var height = 500, width = 500, bg = '#000000';

        scene = new THREE.Scene();

        camera = new THREE.PerspectiveCamera(45, height/width, 1, 10000);
        camera.position.set(1.5, 1.5, 1.5);
        camera.lookAt(new THREE.Vector3(0, 0, 0));
        scene.add(camera);

        light = new THREE.AmbientLight(0xffffff);
        scene.add(light);

        var ballmat = new THREE.MeshBasicMaterial({
                map:    balltex
        }); 
        var ballgeo = new THREE.SphereGeometry( 0.3, 20, 20 );
        var ball = new THREE.Mesh( ballgeo , ballmat );
        scene.add(ball);

        renderer = new THREE.WebGLRenderer({ antialias: true } );
        renderer.setClearColor(bg);
        renderer.setSize(width, height);

        var d = document.createElement('div');
        document.body.appendChild(d);
        d.appendChild(renderer.domElement);

        var c = document.getElementsByTagName('canvas')[0];
        c.style.width = width + 'px';
        c.style.height = height + 'px'
}

function animate() {
        requestAnimationFrame(animate);
        render();
}

function render() {
        renderer.render(scene, camera);
}

关于javascript - Three.js 纹理未应用于网格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37801661/

相关文章:

javascript - 使用 OrbitControls 时如何在 Three.js 中禁用右键单击鼠标移动相机旋转?

javascript - 有什么方法可以从通用的 HTML 片段创建文档片段吗?

javascript - 测试微服务功能时模拟数据库

javascript onmouseout 应用于由 child 触发的 div

three.js - UV 在默认的three.js planeGeometry 上从哪个角开始?

javascript - Threejs如何使用WireframeHelper删除线框

javascript - 在 javascript(react) Web 应用程序中上传视频时的视频压缩

javascript - ReactJS引导表单无需刷新页面

javascript - 具有自定义几何形状的网格的 Three.js 纹理

javascript - THREE.js 跟踪模型(对象)