本文整理汇总了C++中ConstWayPtr::isValidPolygon方法的典型用法代码示例。如果您正苦于以下问题:C++ ConstWayPtr::isValidPolygon方法的具体用法?C++ ConstWayPtr::isValidPolygon怎么用?C++ ConstWayPtr::isValidPolygon使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类ConstWayPtr
的用法示例。
在下文中一共展示了ConstWayPtr::isValidPolygon方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: if
geos::geom::GeometryTypeId ElementConverter::getGeometryType(const ConstElementPtr& e,
bool throwError, const bool statsFlag)
{
ElementType t = e->getElementType();
switch (t.getEnum())
{
case ElementType::Node:
return GEOS_POINT;
case ElementType::Way:
{
ConstWayPtr w = dynamic_pointer_cast<const Way>(e);
assert(w);
if(statsFlag)
{
if (w->isValidPolygon() && OsmSchema::getInstance().isAreaForStats(w->getTags(), ElementType::Way))
return GEOS_POLYGON;
else
return GEOS_LINESTRING;
} else {
if (w->isValidPolygon() && OsmSchema::getInstance().isArea(w->getTags(), ElementType::Way))
return GEOS_POLYGON;
else
return GEOS_LINESTRING;
}
break;
}
case ElementType::Relation:
{
ConstRelationPtr r = dynamic_pointer_cast<const Relation>(e);
assert(r);
if(statsFlag)
{
if (r->isMultiPolygon() || OsmSchema::getInstance().isAreaForStats(r->getTags(), ElementType::Relation))
return GEOS_MULTIPOLYGON;
else if (OsmSchema::getInstance().isLinear(*r))
return GEOS_MULTILINESTRING;
} else {
if (r->isMultiPolygon() || OsmSchema::getInstance().isArea(r->getTags(), ElementType::Relation))
return GEOS_MULTIPOLYGON;
else if (OsmSchema::getInstance().isLinear(*r))
{
return GEOS_MULTILINESTRING;
}
else if (r->getMembers().size() == 0 ||
OsmSchema::getInstance().isCollection(*r))
{
// an empty geometry, pass back a collection
return GEOS_GEOMETRYCOLLECTION;
}
}
break;
}
default:
LOG_ERROR("Element was not a node, way, or relation");
break;
}
if (throwError)
{
throw IllegalArgumentException("Unknown geometry type.");
}
else
{
return GeometryTypeId(-1);
}
}