gpt4 book ai didi

整个 THREE.BufferGeometry 上的 THREE.JS UV 贴图

转载 作者:行者123 更新时间:2023-12-04 09:24:33 28 4
gpt4 key购买 nike

这是一个非常简单的 Three.JS 草图,生成以下渲染:
enter image description here
正如您可能看到的,这个 THREE.BufferGeometry 是一个 8x8 矩阵,通过以这种方式设置 UV:

for(var i = 0; i < points.length; i += 4){ quad_uvs.push(...[0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0]); }

uvs = new Float32Array(quad_uvs);
geometry.setAttribute( 'uv', new THREE.BufferAttribute( uvs, 2 ) );
它将纹理应用于每个 8x8 段,但是我需要在整个几何体上放置纹理。
我如何更新 uv 映射以实现它?
enter image description here

    
var img = "";

var renderer, scene, camera, controls, glsl;

renderer = new THREE.WebGLRenderer({
antialias: true
});
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
renderer.setClearColor(0x000000);
document.body.appendChild(renderer.domElement);

scene = new THREE.Scene();
loader = new THREE.TextureLoader();
loader.crossOrigin = "";

camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 1, 51200);
camera.position.set(-2048, 2048, -2048);
controls = new THREE.OrbitControls(camera, renderer.domElement);
controls.enableDamping = true;
controls.dampingFactor = 0.05;

controls.screenSpacePanning = false;

controls.minDistance = 8;
controls.maxDistance = 5120;

camera.position.set(208.48355078304965, 45.28894677815297, 310.34089790619583);
controls.target.set(0, 0, 0);

var points = [], indices = [], quad_uvs = [];

for(var x = -512; x < 512; x += 128){
for(var z = -512; z < 512; z += 128){


points.push(new THREE.Vector3(x, 0, z));
points.push(new THREE.Vector3(x + 128 , 0, z));
points.push(new THREE.Vector3(x + 128, 0, z + 128));
points.push(new THREE.Vector3(x, 0, z + 128));

}
}

for(var i = 0; i < points.length; i += 4){

indices.push(i, i + 1, i + 2);
indices.push(i + 2, i + 3, i);

}

var geometry = new THREE.BufferGeometry().setFromPoints(points);

for(var i = 0; i < points.length; i += 4){ quad_uvs.push(...[0.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 1.0]); }

uvs = new Float32Array(quad_uvs);
geometry.setAttribute( 'uv', new THREE.BufferAttribute( uvs, 2 ) );

geometry.setIndex( indices );
geometry.computeVertexNormals();

glsl = new THREE.ShaderMaterial( {

uniforms: {

textureA: { type: 't', value: new THREE.TextureLoader().load(img) }

},

vertexShader: document.getElementById( "vertexShader" ).textContent,
fragmentShader: document.getElementById( "fragmentShader" ).textContent

} );

glsl.side = THREE.DoubleSide;


var plane = new THREE.Mesh(geometry, glsl);

scene.add(plane);

animate();

function animate(){

controls.update();
renderer.render(scene, camera);

requestAnimationFrame(animate);

}
body { margin: 0; }
<!DOCTYPE html>
<html>
<head>

<meta charset="utf-8" />

<meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no" />
<script src="https://unpkg.com/three@0.116.0/build/three.min.js"></script>
<script src="https://unpkg.com/three@0.116.0/examples/js/controls/OrbitControls.js"></script>

</head>
<body>

<script id="vertexShader" type="x-shader/x-vertex">

varying vec2 vUv;

void main() {

vUv = uv;

gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);

}

</script>

<script id="fragmentShader" type="x-shader/x-fragment">

varying vec2 vUv;
uniform sampler2D textureA;

void main() {

gl_FragColor = texture2D(textureA, vUv);

}

</script>

</body>
</html>

最佳答案

我已经使用可能的解决方案更新了您的代码。您将看到现在生成的几何体略有不同。最重要的部分是您必须在 [0,1] 范围内生成纹理坐标。跨越整个几何体,而不仅仅是每个四边形。

    
var img = "";

var renderer, scene, camera, controls, glsl;

renderer = new THREE.WebGLRenderer({
antialias: true
});
renderer.setPixelRatio(window.devicePixelRatio);
renderer.setSize(window.innerWidth, window.innerHeight);
renderer.setClearColor(0x000000);
document.body.appendChild(renderer.domElement);

scene = new THREE.Scene();
loader = new THREE.TextureLoader();
loader.crossOrigin = "";

camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 1, 51200);
camera.position.set(-2048, 2048, -2048);
controls = new THREE.OrbitControls(camera, renderer.domElement);
controls.enableDamping = true;
controls.dampingFactor = 0.05;

controls.screenSpacePanning = false;

controls.minDistance = 8;
controls.maxDistance = 5120;

camera.position.set(208.48355078304965, 45.28894677815297, 310.34089790619583);
controls.target.set(0, 0, 0);

var points = [], indices = [], uvs = [];

var step = 128;

for(var x = -512; x < 512; x += step){
for(var z = -512; z < 512; z += step){

points.push(x, 0, z);
points.push(x + step , 0, z);
points.push(x + step, 0, z + step);
points.push(x, 0, z + step);

var u = x + 512;
var v = z + 512;

uvs.push(u / 1024, v / 1024);
uvs.push((u + step) / 1024 , v / 1024);
uvs.push((u + step) / 1024 ,(v + step) / 1024);
uvs.push(u / 1024, (v + step) / 1024);
}
}

var geometry = new THREE.BufferGeometry();
geometry.setAttribute( 'position', new THREE.Float32BufferAttribute( points, 3 ) );
geometry.setAttribute( 'uv', new THREE.Float32BufferAttribute( uvs, 2 ) );

var positionAttribute = geometry.getAttribute( 'position' );

for(var i = 0; i < positionAttribute.count; i += 4){

indices.push(i, i + 1, i + 2);
indices.push(i + 2, i + 3, i);

}

geometry.setIndex( indices );
geometry.computeVertexNormals();

glsl = new THREE.ShaderMaterial( {

uniforms: {

textureA: { type: 't', value: new THREE.TextureLoader().load(img) }

},

vertexShader: document.getElementById( "vertexShader" ).textContent,
fragmentShader: document.getElementById( "fragmentShader" ).textContent

} );

glsl.side = THREE.DoubleSide;


var plane = new THREE.Mesh(geometry, glsl);

scene.add(plane);

animate();

function animate(){

controls.update();
renderer.render(scene, camera);

requestAnimationFrame(animate);

}
body { margin: 0; }
<!DOCTYPE html>
<html>
<head>

<meta charset="utf-8" />

<meta name="viewport" content="initial-scale=1,maximum-scale=1,user-scalable=no" />
<script src="https://unpkg.com/three@0.116.0/build/three.min.js"></script>
<script src="https://unpkg.com/three@0.116.0/examples/js/controls/OrbitControls.js"></script>

</head>
<body>

<script id="vertexShader" type="x-shader/x-vertex">

varying vec2 vUv;

void main() {

vUv = uv;

gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);

}

</script>

<script id="fragmentShader" type="x-shader/x-fragment">

varying vec2 vUv;
uniform sampler2D textureA;

void main() {

gl_FragColor = texture2D(textureA, vUv);

}

</script>

</body>
</html>

关于整个 THREE.BufferGeometry 上的 THREE.JS UV 贴图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63039982/

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