本文整理汇总了C++中QuadTree::SubNode方法的典型用法代码示例。如果您正苦于以下问题:C++ QuadTree::SubNode方法的具体用法?C++ QuadTree::SubNode怎么用?C++ QuadTree::SubNode使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类QuadTree
的用法示例。
在下文中一共展示了QuadTree::SubNode方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
IntersectResult PolygonContainer<TYPE>::QueryPointInPolygon(Node* node)
{
QuadTree* tree = this;
while(tree)
{
if(tree == 0) continue;
QuadObjects objects = tree->GetObjects();
QuadObjectIterator it = objects.begin();
for(;it != objects.end();it++)
{
QuadObject* quad = *it;
TYPE* poly = (TYPE*)quad;
IntersectResult ret = PointInPolygon(node, poly);
if (ret != IR_SEPERATE) return ret;
}
Geometry::TREE_LOCATION location = tree->GetLocation(node->X(), node->Y());
if(location == Geometry::TL_CHILD0)
{
tree = tree->SubNode(0);
}
else if(location == Geometry::TL_CHILD1)
{
tree = tree->SubNode(1);
}
else if(location == Geometry::TL_CHILD2)
{
tree = tree->SubNode(2);
}
else if(location == Geometry::TL_CHILD3)
{
tree = tree->SubNode(3);
}
else
{
break;
}
}
return IR_SEPERATE;
}