本文整理汇总了C++中ray::dir方法的典型用法代码示例。如果您正苦于以下问题:C++ ray::dir方法的具体用法?C++ ray::dir怎么用?C++ ray::dir使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ray
的用法示例。
在下文中一共展示了ray::dir方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: searchNode
IntersectionData KDTree::searchNode(KDNode *node, const ray &viewRay, double tmin, double tmax, int curAxis) {
assert(tmin <= tmax);
assert(curAxis >= 0 && curAxis < 3);
if(node->is_leaf) {
return closestIntersection(node->objects, viewRay);
}
int nextAxis = (curAxis + 1) % 3;
double tSplit = (node->split_pos - viewRay.orig(curAxis)) / viewRay.dir(curAxis);
KDNode *nearNode, *farNode;
if(viewRay.orig(curAxis) < node->split_pos) {
nearNode = node->left;
farNode = node->right;
} else {
nearNode = node->right;
farNode = node->left;
}
if(tSplit > tmax) {
return searchNode(nearNode, viewRay, tmin, tmax, nextAxis);
} else if (tSplit < tmin) {
if(tSplit > 0)
return searchNode(farNode, viewRay, tmin, tmax, nextAxis);
else if(tSplit < 0)
return searchNode(nearNode, viewRay, tmin, tmax, nextAxis);
else {
if(viewRay.dir(curAxis) < 0)
return searchNode(node->left, viewRay, tmin, tmax, nextAxis);
else
return searchNode(node->right, viewRay, tmin, tmax, nextAxis);
}
} else {
if(tSplit > 0) {
IntersectionData test = searchNode(nearNode, viewRay, tmin, tSplit, nextAxis);
if(test.obj != NULL && test.time < tSplit + EPSILON)
return test;
else
return searchNode(farNode, viewRay, tSplit, tmax, nextAxis);
} else {
return searchNode(nearNode, viewRay, tSplit, tmax, nextAxis);
}
}
}