本文整理汇总了C++中Point::IsOnEdge方法的典型用法代码示例。如果您正苦于以下问题:C++ Point::IsOnEdge方法的具体用法?C++ Point::IsOnEdge怎么用?C++ Point::IsOnEdge使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Point
的用法示例。
在下文中一共展示了Point::IsOnEdge方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: FindEdgeIndex
void Tree::FindEdgeIndex(Point point, const vector<Node>& nodes, int* parent_node_index_pointer, int * child_node_index_pointer)const{
for (set<int>::iterator it = branches_.begin(); it != branches_.end(); ++it){
int branch_index = *it;
DirectionalEdge d_edge = GetBranchEdge(branch_index, nodes);
if (point.IsOnEdge(d_edge)){
*child_node_index_pointer = branch_index;
*parent_node_index_pointer = nodes.at(branch_index).parent_;
return;
}
}
assert(1);//Should not be here
}
示例2: FindAndInsertNewNode
Node Tree::FindAndInsertNewNode(Point new_node_point, vector<Node>& nodes){
for (set<int>::const_iterator it = indexes_.begin(); it != indexes_.end(); it++){
int node_index = *it;
Node node = nodes.at(node_index);
Point point = node.point_;
if (point == new_node_point){
return node;
}
}
for (set<int>::const_iterator it = branches_.begin(); it != branches_.end(); it++){
int node_index = *it;
int parent_node_index = nodes.at(node_index).parent_;
DirectionalEdge d_edge = GetBranchEdge(node_index, nodes);
if (new_node_point.IsOnEdge(d_edge)){
/*if (new_node_point == d_edge.get_start_point()){
return nodes.at(node_index);
}else if (new_node_point == d_edge.get_end_point()){
return nodes.at(parent_node_index);
}else{
}*/
return InsertNewNode(parent_node_index, node_index, new_node_point, nodes);
}
}
}