- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个程序,该程序在鼠标单击时用地面上的 block 填充世界(坐标基于我计算的鼠标单击坐标)。创建新 block 时,它不应与预先创建的 block 相交。我用 THREE.Raycaster 实现了这个检查。基本上,我从 block 的中心向其顶点的所有方向转换光线。
var ln = preview.geometry.vertices.length;
//for each vertices we throw a ray
for(var i = 0; i < ln; i++){
var pr_vertex = preview.geometry.vertices[i].clone();
var gl_vertex = pr_vertex.applyMatrix4(preview.matrix);
var dr_vector = gl_vertex.sub(preview.position);
var ray = new THREE.Raycaster(preview.position, dr_vector.clone().normalize());
var intersects = ray.intersectObjects(objmanager.getAllObject(), true);
//if there is intersection
if(intersects.length > 0 && intersects[0].distance < dr_vector.length()){
//hide preview material
preview.material.opacity = 0;
//exit checking
break;
}
}
预览是对象的名称。此代码已经完美运行。问题是,Raycaster.intersectObjects 仅在光线与测试对象的正面 相交时才起作用。我在运行代码时已经对其进行了测试,如果光线从被测对象外部开始,它们相交得很好。但是当光线从测试 block 的内部开始时,它没有捕捉到与测试 block 表面的交点。我认为发生这种情况是因为 intersectObjects 仅适用于测试对象的前表面。这是真的吗?
凭直觉,我尝试使用 THREE.DoubleSide(制作双面物体)来解决这个问题。但是它产生了一个错误,因为着色器无法初始化。
Could not initialise shader
VALIDATE_STATUS: false, gl error [0] three.js:25254
buildProgram three.js:25254
initMaterial three.js:23760
setProgram three.js:23830
renderBuffer three.js:22371
renderObjects three.js:23061
render three.js:22935
animLoop
我正在使用 THREE.MeshLambertMaterial。当我使用 MeshBasicMaterial 时,Raycaster.intersectObjects 根本不起作用。
所以我现在遇到了障碍。有什么办法可以解决这个问题吗?否则,我将不得不手动测试每个对象的各个面的碰撞(我担心这会严重影响性能)。
提前谢谢你。
===============
编辑:忘了说了,我用的是最新的three.js版本,应该是r63左右
最佳答案
如果你设置:
object.material.side = THREE.DoubleSided
你应该在两个表面上都被击中。
关于javascript - Three.js Raycaster.intersectObjects 只检测正面交点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20534042/
我创建了一个函数来计算两条线段的交点。 不幸的是,如果其中一个段是垂直的,下面的代码将不起作用 public static Point intersection(Segment s1, Seg
我有一个由中心 (x,y,z)、半径和方向矢量定义的圆,该矢量指定圆的朝向。我需要测试这样的圆是否与轴对齐的边界框相交。为了澄清,通过相交,我的意思是如果圆圈描述的区域内的任何点在边界框内,那么就构成
虽然我认为这是一个基本问题,但我似乎无法找到如何在 R 中计算: 2 个或多个正态分布(拟合在直方图上)的交点(我需要 x 值),例如具有以下参数: d=data.frame(mod=c(1,2),m
我看过几个关于找到两个 OBB 之间的交点的线程。我仍然不明白如何找到最小穿透轴。我需要找到最小穿透轴,我相信它在 David Eberly 的论文中也被称为最后一个分离轴,以确定我应该使用表格的哪一
我想使用 intersection()通过 key 或filter()在 Spark 。 但是我真的不知道怎么用intersection()按键。 所以我尝试使用filter() ,但它不起作用。 示
我正在画一个circle在canvas上。我想知道,给定 circle 的半径和原点 x/y ,在什么时候 circle与 canvas 相交(如果有的话)边缘。 这肯定是一个几何问题,但这部分似乎太
我正在尝试计算任意数量平面的最顶部交点,但没有任何乐趣!我正在使用 actionscript,但只需要找到一个我可以实现的算法。 问题: 考虑 3 个垂直轴。 用户为每个三角形/平面输入 3 个点,使
我是一名优秀的程序员,十分优秀!