本文整理汇总了C++中BBox::intersect方法的典型用法代码示例。如果您正苦于以下问题:C++ BBox::intersect方法的具体用法?C++ BBox::intersect怎么用?C++ BBox::intersect使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类BBox
的用法示例。
在下文中一共展示了BBox::intersect方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: intersectBBox
int Triangle::intersectBBox(const BBox &box) const {
if (box.vertexInside(v[id1]) ||
box.vertexInside(v[id2]) ||
box.vertexInside(v[id3])) {
return 1;
}
if (box.triangleOutsideSlash(v[id1], v[id2], v[id3])) {
return -1;
}
// edge test.
vec3 e1 = v[id2] - v[id1];
float t1 = length(e1);
vec3 d1 = normalize(e1);
Intersection ret = box.intersect(Ray(v[id1], d1, CONST_NEAR, CONST_FAR));
if (ret.t < t1) {
return 1;
}
vec3 e2 = v[id3] - v[id1];
float t2 = length(e2);
vec3 d2 = normalize(e2);
ret = box.intersect(Ray(v[id1], d2, CONST_NEAR, CONST_FAR));
if (ret.t < t2) {
return 1;
}
vec3 e3 = v[id3] - v[id2];
float t3 = length(e3);
vec3 d3 = normalize(e3);
ret = box.intersect(Ray(v[id2], d3, CONST_NEAR, CONST_FAR));
if (ret.t < t3) {
return 1;
}
vector<Ray> diags = box.getDiagonals();
for (const auto &diag : diags) {
ret = intersect(diag);
if (ret.t < CONST_FAR) {
return 1;
}
}
return -1;
}