使用JSONloader加载纹理

问题描述 投票:0回答:1

我是新手,我想我错过了一些东西。有人可以检查一下吗?HTML页面:http://xalien95.altervista.org/pkmnxy_engine/alisopoli.html型号和纹理:http://xalien95.altervista.org/pkmnxy_engine/alisopoli/我可以看到模型(颜色怪异),但不能看到纹理(它是具有多种材质的网格)。预先感谢!

编辑:我尝试了所有材料类型:

  • THREE.MeshBasicMaterial
  • THREE.MeshDepthMaterial
  • THREE.MeshLambertMaterial
  • THREE.MeshNormalMaterial
  • THREE.MeshPhongMaterial

但是没有人工作,所以我想我错过了一些东西(或者材料途径不同)。这是脚本:

var camera, scene, renderer, mesh, loader;

        init();
        animate();

        function init() {

            camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 10000 );
            camera.position.z = 1000;

            scene = new THREE.Scene();

            loader = new THREE.JSONLoader();

            loader.load( "./alisopoli/alisopoli.js", function( geometry, materials ) {
                var faceMaterial = new THREE.MeshPhongMaterial( materials );
                mesh = new THREE.Mesh( geometry, faceMaterial );
                mesh.scale.set( 100, 100, 100 );
                mesh.position.y = -150;
                mesh.position.x = 0;
                mesh.rotation.x = 60;
                scene.add( mesh );
            } );


            var ambientLight = new THREE.AmbientLight(0x555555);
            scene.add(ambientLight);

            //var directionalLight = new THREE.DirectionalLight(0xffffff);
            //directionalLight.position.set(1, 1, 1).normalize();
            //scene.add(directionalLight);

            renderer = new THREE.WebGLRenderer();
            renderer.setSize( window.innerWidth, window.innerHeight );

            document.body.appendChild( renderer.domElement );

        }

        function animate() {

            requestAnimationFrame( animate );

            //mesh.rotation.y += 0.005;

            renderer.render( scene, camera );
        }

提前感谢!

json three.js textures
1个回答
0
投票

怪异的颜色是因为在加载过程中为每个网格分配了“ MeshNormalMaterial”。您应该检查three.js json加载器示例,或者以某种方式获取正确的材料,而不是将MeshNormalMaterials分配给子网格

© www.soinside.com 2019 - 2024. All rights reserved.