如何将纹理与自定义几何关联

时间:2016-10-24 22:11:42

标签: three.js uv-mapping

我是一个非常绿色的新手试图理解纹理和几何形状。我不知道我的代码有什么问题,有人有一个想法......

var loader = new THREE.STLLoader();
loader.load('../Programa/imagens/imagem.stl',function (geometry){
    var geometria = new THREE.Geometry().fromBufferGeometry(geometry);
    geometria.computeBoundingBox();
    var max = geometria.boundingBox.max,
        min = geometria.boundingBox.min;
    var offset = new THREE.Vector2(0 - min.x, 0 - min.y);
    var range = new THREE.Vector2(max.x - min.x, max.y - min.y);
    var faces = geometria.faces;
    geometria.faceVertexUvs[0] = [];
    for(var i = 0; i < faces.length; i++){
        var v1 = geometria.vertices[faces[i].a],
            ...``
        geometria.faceVertexUvs[0].push([
            new THREE.Vector2((v1.x + offset.x)/range.x, (v1.y + offset.y)/range.y),
            ...
            ]);
    }
    geometria.name = "Projeto 1";
    var material = new THREE.MeshPhongMaterial({
        map: THREE.ImageUtils.loadTexture('../Programa/imagens/uvmapping.jpg')
        }); 
    var mesh = new THREE.Mesh(geometria,  material);
    geometria.uvsNeedUpdate = true;
    geometria.colorsNeedUpdate = true;
    mesh.scale.set(0.029, 0.029, 0.029);
    scene.add(geometria);
    });

0 个答案:

没有答案