本文整理汇总了C++中LineString::isClosed方法的典型用法代码示例。如果您正苦于以下问题:C++ LineString::isClosed方法的具体用法?C++ LineString::isClosed怎么用?C++ LineString::isClosed使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类LineString
的用法示例。
在下文中一共展示了LineString::isClosed方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
mapnik::geometry::polygon<double> geowave_featureset::create_polygon(Polygon polygon)
{
mapnik::geometry::polygon<double> polygon_out;
// handle exterior ring
{
LineString geom = polygon.getExteriorRing();
mapnik::geometry::linear_ring<double> linear_ring;
for (int point_idx = geom.getNumPoints()-1; point_idx >= 0; --point_idx)
{
Coordinate coord = geom.getPointN(point_idx).getCoordinate();
linear_ring.add_coord(coord.x(), coord.y());
}
if (geom.isClosed())
{
Coordinate coord = geom.getPointN(geom.getNumPoints()-1).getCoordinate();
linear_ring.add_coord(coord.x(), coord.y());
}
polygon_out.set_exterior_ring(std::move(linear_ring));
}
// handle interior rings
{
for (int ring_idx = 0; ring_idx < polygon.getNumInteriorRing(); ++ring_idx)
{
LineString geom = polygon.getInteriorRingN(ring_idx);
mapnik::geometry::linear_ring<double> linear_ring;
for (int point_idx = geom.getNumPoints()-1; point_idx >= 0; --point_idx)
{
Coordinate coord = geom.getPointN(point_idx).getCoordinate();
linear_ring.add_coord(coord.x(), coord.y());
}
if (geom.isClosed())
{
Coordinate coord = geom.getPointN(geom.getNumPoints()-1).getCoordinate();
linear_ring.add_coord(coord.x(), coord.y());
}
polygon_out.add_hole(std::move(linear_ring));
}
}
return polygon_out;
}
示例2: isClosed
bool MultiLineString::isClosed() const {
if (isEmpty()) {
return false;
}
for (size_t i = 0, n = geometries->size(); i < n; ++i) {
LineString *ls = dynamic_cast<LineString*>((*geometries)[i]);
if ( ! ls->isClosed() ) {
return false;
}
}
return true;
}