- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试添加一个垂直于我单击的面的框(称为“标记”)。
为此,单击时,我会转换一条射线,如果它击中某些物体,我会获取法线的交点值并将它们传输到“标记”作为其旋转值。在问这个问题之前,我阅读了这个答案( How do I make an object perpendicular to a face with Three.js? )但无法使其工作......
目前,它在需要的地方添加了标记,但方向略有错误,预计在立方体的顶部。
Wrong orientation on cube and uncontroled Y rotation
我不明白两件事: 1. 为什么faceNormalsHelper的方向和intersects[0].face.normal之间存在差异。 2、Y轴旋转是如何控制的?
我的错误是什么?为了帮助您帮助我,我制作了一个 fiddle ( https://jsfiddle.net/jpyncf62/1/ ),这是我用来执行此操作的代码:
function clickDown(e) {
e.preventDefault();
raycaster.setFromCamera(mouse, camera);
var intersects = raycaster.intersectObjects(objects);
if (intersects.length > 0) {
var intersect = intersects[0];
console.log(intersects[0]);
console.log(console.log(intersects[0].object.name));
var markerGeo = new THREE.BoxGeometry(1, 6, 1, 1, 1, 1);
var markerMat = new THREE.MeshLambertMaterial({ color: 0xff0000 });
var marker = new THREE.Mesh(markerGeo, markerMat);
marker.name = "marker";
marker.position.copy(intersect.point);
marker.lookAt(intersect.face.normal);
scene.add(marker);
}
}
谢谢你的帮助!
最佳答案
您正在添加立方体和平面。并给他们位置和旋转。但为了正确地相交它们的法线,您应该应用矩阵。
var container, stats;
var camera, scene, renderer;
var objects = [];
raycaster = new THREE.Raycaster();
mouse = new THREE.Vector2();
init();
animate();
function init() {
container = document.getElementById("webgl-output")
scene = new THREE.Scene();
camera = new THREE.PerspectiveCamera( 45, window.innerWidth / window.innerHeight, 1, 1000 );
camera.position.set(20, 50,50);
camera.lookAt( scene.position );
scene.add ( new THREE.AmbientLight( 0xffffff ) );
light = new THREE.DirectionalLight( 0xffffff );
light.position.set( 0, 1, 0 );
scene.add( light );
var material = new THREE.MeshLambertMaterial( { color: 0x4fc2c9 } );
var cube = new THREE.Mesh( new THREE.BoxGeometry( 10, 10, 10, 1, 1, 1 ), material );
cube.name = "I'm a cube";
objects.push( cube );
scene.add( cube );
cube.position.set( 0, 5, 0 );
cube.rotation.set( 0, 0, Math.PI / 4);
applyMatrixOfMesh(cube); // Apply matrix of cube
// Add helpers after applied matrix
var faceNormalsHelper = new THREE.FaceNormalsHelper( cube, 1 );
cube.add( faceNormalsHelper );
var vertexNormalsHelper = new THREE.VertexNormalsHelper( cube, 1 );
cube.add( vertexNormalsHelper );
var planeGeo = new THREE.PlaneGeometry( 60, 20, 1, 1 );
var planeMat = new THREE.MeshLambertMaterial({ color: 0xffffff });
var plane = new THREE.Mesh( planeGeo, planeMat );
plane.position.set(0, 0, 0);
plane.rotation.x = -0.5 * Math.PI;
plane.name = "plane01";
applyMatrixOfMesh(plane); // Apply matrix of plane
scene.add( plane );
objects.push( plane );
var axes = new THREE.AxisHelper( 20 );
scene.add( axes );
renderer = new THREE.WebGLRenderer( { antialias: true });
renderer.setPixelRatio( window.devicePixelRatio );
renderer.setClearColor( 0xeeeeee );
renderer.setSize( window.innerWidth, window.innerHeight );
container.appendChild( renderer.domElement );
document.addEventListener('mousemove', mouseMoving, false);
document.addEventListener('mousedown', clickDown, false);
}
function mouseMoving(e) {
mouse.x = ( e.clientX / window.innerWidth ) * 2 - 1;
mouse.y = - ( e.clientY / window.innerHeight ) * 2 + 1;
raycaster.setFromCamera( mouse, camera );
var intersects = raycaster.intersectObjects( scene.children );
for ( var i = 0; i < intersects.length; i++ ) {
var posY = intersects[ 0 ].point.y.toFixed(2);
}
}
function clickDown(e) {
e.preventDefault();
raycaster.setFromCamera( mouse, camera );
var intersects = raycaster.intersectObjects( objects );
if( intersects.length > 0 ) {
var intersect = intersects[ 0 ];
console.log( intersects[ 0 ]);
console.log( console.log( intersects[ 0 ].face.normal ) );
var markerGeo = new THREE.BoxGeometry( 1, 1, 6, 1, 1, 1 ); // I changed BoxGeometry
var markerMat = new THREE.MeshLambertMaterial( { color: 0xff0000 } );
var marker = new THREE.Mesh( markerGeo, markerMat );
marker.name = "marker";
marker.lookAt( intersect.face.normal ); // First look At to normal
marker.position.copy( intersect.point ) // After give position to marker
scene.add( marker );
}
}
function applyMatrixOfMesh(mesh) { // You should apply Matrix of cube and plane
mesh.updateMatrix();
mesh.geometry.applyMatrix(mesh.matrix);
mesh.position.set(0, 0, 0);
mesh.rotation.set(0, 0, 0);
mesh.updateMatrix();
}
function animate() {
requestAnimationFrame( animate );
render();
}
function render() {
renderer.render( scene, camera );
}
代码中有一个名为“applyMatrixOfMesh”的函数。您需要将它用于用于相交的每个“THREE.Mesh”。
关于javascript - Three.js:如何添加垂直于面(法线)的对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46336560/
所以昨天我写了 WaveFront .obj 3D 模型加载器,它现在工作正常(虽然不支持所有内容)所以我写了简单的测试来在屏幕上绘制任何 3D 模型,在我为场景添加照明之前一切正常.光出现了,但法线
我的代码(用 C++ 编码)在处理更新模型法线的 for 循环中存在瓶颈。我用来测试的模型有大约 ~2.2k 个顶点(指示),工作正常并且在 60 fps 限制下工作,但法线与指示器(~12k)一样多
我无法将法线和 u,v 对发送到我的着色器。如果我删除法线,一切都会按预期进行。 编辑看起来 v_normal 正在接收用于 v_coord 的值。我仍然不知道。/编辑 这是我的顶点: struct
我正在寻找一种方法来获取矩形的所有顶点,该矩形的中心、法线、长度和高度我都知道。我的数学有点弱所以请帮助我。编辑:飞机在 3D 空间中。 最佳答案 通过从中心点的 x/y 位置减去/加上宽度/高度的一
是否可以从片段着色器内访问表面法线(与片段平面相关的法线)?或者也许这可以在顶点着色器中完成? 当我们沿着着色器管道走下去时,相关几何体的所有知识是否都会丢失,或者是否有一些巧妙的方法可以在片段着色器
我无法使用 VBO 正确渲染法线。下面是我正在使用的代码,顶点是一个包含顶点的数组,法线是一个包含法线的数组: //Create the buffers and such GLuint VBOID;
我已经有了这个不再那么小的基于图 block 的游戏,这是我的第一个真正的 OpenGL 项目。我想将每个图 block 渲染为 3D 对象。因此,首先我创建了一些对象,例如立方体和球体,为它们提供了
我正在尝试添加一个垂直于我单击的面的框(称为“标记”)。 为此,单击时,我会转换一条射线,如果它击中某些物体,我会获取法线的交点值并将它们传输到“标记”作为其旋转值。在问这个问题之前,我阅读了这个答案
这与另一个问题(那里的图像)中描述的问题有关: Opengl shader problems - weird light reflection artifacts 我有一个 .obj 导入器,它创建一
我正在尝试制作一个在 OpenGL 2.1 和 Qt5 中渲染的简单 map 。但我在非常基本的问题上失败了。我在这里展示的是表面法线。 我有 4 个由单个三角形几何体组成的对象。一个简单的几何图形是
我正在开发一个类似 JavaScript/Canvas 3D FPS 的引擎,迫切需要一个法线向量(如果您愿意,也可以是观察向量)来进行近平面和远平面裁剪。我有 x 轴和 y 轴旋转 Angular
我正在编写用于在我的 DirectX 应用程序中存储、加载和渲染静态网格的类。 我知道 Box 模型可以使用 8 个顶点,但通常它使用 24 或 36 个(因为一个“空间中的顶点”实际上是 3 个具有
我无法使 phong 着色看起来正确。我很确定我的 OpenGL 调用或我加载法线的方式有问题,但我想这可能是其他问题,因为 3D 图形和 Assimp 对我来说都还很陌生。尝试加载 .obj/.mt
我是一名优秀的程序员,十分优秀!