本文整理汇总了C++中GeoExtent::isPoint方法的典型用法代码示例。如果您正苦于以下问题:C++ GeoExtent::isPoint方法的具体用法?C++ GeoExtent::isPoint怎么用?C++ GeoExtent::isPoint使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类GeoExtent
的用法示例。
在下文中一共展示了GeoExtent::isPoint方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
bool
GeoPointList::intersects( const GeoExtent& ex ) const
{
if ( ex.isInfinite() )
return true;
//TODO: srs transform
if ( ex.isPoint() ) // do a point-in-polygon test
{
const GeoPoint& point = ex.getSouthwest();
bool result = false;
const GeoPointList& polygon = *this;
for( unsigned int i=0, j=polygon.size()-1; i<polygon.size(); j = i++ )
{
if ((((polygon[i].y() <= point.y()) && (point.y() < polygon[j].y())) ||
((polygon[j].y() <= point.y()) && (point.y() < polygon[i].y()))) &&
(point.x() < (polygon[j].x()-polygon[i].x()) * (point.y()-polygon[i].y())/(polygon[j].y()-polygon[i].y())+polygon[i].x()))
{
result = !result;
}
}
return result;
}
else // check for all points within extent -- not actually correct //TODO
{
GeoExtent e;
for( GeoPointList::const_iterator i = begin(); i != end(); i++ )
{
if ( i == begin() ) e = GeoExtent( *i, *i );
else e.expandToInclude( *i );
}
return e.intersects( ex );
}
}