本文整理汇总了C++中polygon::get_n方法的典型用法代码示例。如果您正苦于以下问题:C++ polygon::get_n方法的具体用法?C++ polygon::get_n怎么用?C++ polygon::get_n使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类polygon
的用法示例。
在下文中一共展示了polygon::get_n方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: earQ
bool earQ(int i, int j, int k, const polygon& p)
{
triangle t(p.vec_points[i], p.vec_points[k], p.vec_points[k]);
if (cw(p.vec_points[i], p.vec_points[j], p.vec_points[k]))
return false;
for (int m = 0; m < p.get_n(); m++) {
if ((m != i) && (m != j) && (m != k))
if (t.contains(p.vec_points[m]))
return false;
}
return true;
}
示例2: t
///////////////////////////////////////////////////////////////////////////
// triangulation implementation
///////////////////////////////////////////////////////////////////////////
triangulation::triangulation(const polygon& p) {
int n = p.get_n();
vector<int> vleft(n), // left neighbor indices
vright(n); // rigth neighbor indices
for (int j = 0; j < n; j++) {
vleft[j] = ((j-1) + n) % n;
vright[j] = ((j+1) + n) % n;
}
int i = n - 1;
while ((int)vec_triangles.size() < (n-2)) {
i = vright[i];
if (earQ(vleft[i], i, vright[i], p)) {
triangle t(p.vec_points[vleft[i]], p.vec_points[i], p.vec_points[vright[i]]);
vec_triangles.push_back(t);
vleft[vright[i]] = vleft[i];
vright[vleft[i]] = vright[i];
}
}
}