gpt4 book ai didi

javascript - Three.js 渲染普通几何体的白色部分

转载 作者:行者123 更新时间:2023-11-28 06:19:09 28 4
gpt4 key购买 nike

我正在尝试转动 this plainGeometry,进入 this (某种面具)。

此代码有效:(总而言之,创建两种 Material ,将平面划分为多个段,并使用 MeshFaceMaterial 决定每个 Material 是哪种 Material )

   Button.onClick(function () {

var obj = editor.selected;
var material = obj.material;
var tex = material.map;
var objHeight = obj.geometry.parameters.height;
var objWidth = obj.geometry.parameters.width;
var texHeight = tex.image.height;
var texWidth = tex.image.width;

var geometry = new THREE.PlaneGeometry(objWidth, objHeight, objWidth, objHeight);

var facesNum = objHeight * objWidth * 2;
var facesX = objWidth * 2;
var facesInX = texWidth * 2;

var materials = [];
materials.push(material);
materials.push(new THREE.MeshBasicMaterial({ }));

for (var i = 0; i < facesNum; i++) {
if ((i % facesX >= objWidth - texWidth) &&
(i % facesX <= (facesInX + objWidth - texWidth - 1)) &&
(i <= (texHeight * objWidth * 2) - 1)) {
geometry.faces[i].materialIndex = 0;
}
else {
geometry.faces[i].materialIndex = 1;
}
}

obj.geometry = geometry;
obj.material = new THREE.MeshFaceMaterial(materials);

editor.signals.materialChanged.dispatch(obj);


});

但是我想知道是否有更简单的方法。有什么建议吗?

最佳答案

另一种方法是在纹理上使用 Alpha channel 。您可以使用 Gimp 或 Photoshop 来完成此操作。

然后,您复制网格并使用 Material 上的 PolygonOffsetFactor 将其稍微推出轴。将背景 Material 应用到第一个网格,将带有 alpha 纹理的前景 Material 应用到第二个网格。看到这个 fiddle alphaTest 。 (您可能需要禁用跨域访问安全性,以便纹理可以在此 fiddle 中加载,如果您使用 --disable-web-security 标志运行它,chrome 将允许这样做)此方法的优点是图像可以是任何形状和位置,并且不需要适合几何面。

如果您使用的几何体很复杂,另一种方法是使用 Three.DecalGeometry 切出网格物体,并使用 Material 上的 PolygonOffsetFactor 对其进行一点移动。参见三.jsdecals example为此。

示例 fiddle 的来源如下:

var renderer;
var pointLight;
var scene;
var plane1;
var plane2;

function addPlane()
{
var material1 = new THREE.MeshPhongMaterial({ color: 0xFFFFFF });
var material2;
var loader = new THREE.TextureLoader();
loader.load('http://i.imgur.com/ETdl4De.png',
function ( texture ) {
var material2 = new THREE.MeshPhongMaterial({
color: 0xFFFFFF,
map: texture,
alphaTest: 0.7,
polygonOffset: true,
polygonOffsetFactor: - 4,
});

var geometry1 = new THREE.PlaneGeometry(12, 12, 12, 12);
var geometry2 = geometry1.clone();
plane1 = new THREE.Mesh(geometry1,material1);
plane2 = new THREE.Mesh(geometry2,material2);
scene.add(plane2);
scene.add(plane1);
}
);

}
(function() {

'use strict';

scene = new THREE.Scene();
var camera = new THREE.PerspectiveCamera(45, window.innerWidth / window.innerHeight, 0.01, 10000);

renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);

addPlane();

camera.position.z = 52;

pointLight = new THREE.DirectionalLight(0xffffff,1);
pointLight.position.x = 11;
pointLight.position.y = 5;
pointLight.position.z = 25;
scene.add(pointLight);

var reqAnimFrame = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.msRequestAnimationFrame;

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

关于javascript - Three.js 渲染普通几何体的白色部分,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35681587/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com