- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 boost::geometry 多边形类来计算交叉点及其面积。我有自己的 3d piont 类,我用它定义了一个多边形。但是,当我尝试使用 area() 或 intersection() 时,我遇到了很多编译错误。
我知道我缺少一些定义,或者一些额外的 REGISTER 宏,但我不知道是哪个。
我使用的是 boost 1.54,VC++ 2010 express。
下面是一个无法编译的简单程序。我如何编译它?
#include <boost/geometry.hpp>
#include <boost/geometry/geometry.hpp>
#include <boost/geometry/geometries/polygon.hpp>
#include <boost/geometry/geometries/register/point.hpp>
#include <boost/geometry/geometries/register/ring.hpp>
struct MyPoint
{
double x, y, z;
};
typedef boost::geometry::model::polygon<MyPoint> Polygon;
BOOST_GEOMETRY_REGISTER_POINT_3D(MyPoint, double, boost::geometry::cs::cartesian, x, y, z);
BOOST_GEOMETRY_REGISTER_RING(Polygon::ring_type);
inline void addPoint(Polygon& poly, double x, double y, double z)
{
MyPoint p;
p.x = x; p.y = y; p.z = z;
boost::geometry::append(poly, p);
}
int main()
{
Polygon poly1;
addPoint(poly1, 2, 0, 0);
addPoint(poly1, 2, 2, 0);
addPoint(poly1, 0, 2, 0);
addPoint(poly1, 0, 0, 0);
addPoint(poly1, 2, 0, 0);
Polygon poly2;
addPoint(poly2, 3, 0, 0);
addPoint(poly2, 3, 3, 0);
addPoint(poly2, 0, 3, 0);
addPoint(poly2, 0, 0, 0);
addPoint(poly2, 3, 0, 0);
Polygon intersectionPoly;
boost::geometry::intersection(poly1, poly2, intersectionPoly);
std::cout << "Intersection polygon area is " << boost::geometry::area(intersectionPoly) << '\n';
}
编译错误:
1>------ Build started: Project: TestPolygon, Configuration: Debug Win32 ------
1> main.cpp
1>c:\dev\externals\boost_1_54_0\boost\range\iterator.hpp(63): error C2039: 'type' : is not a member of 'boost::mpl::eval_if_c<C,F1,F2>'
1> with
1> [
1> C=false,
1> F1=boost::range_const_iterator<boost::geometry::model::polygon<MyPoint>>,
1> F2=boost::range_mutable_iterator<Polygon>
1> ]
1> c:\dev\externals\boost_1_54_0\boost\range\value_type.hpp(30) : see reference to class template instantiation 'boost::range_iterator<C>' being compiled
1> with
1> [
1> C=Polygon
1> ]
1> c:\dev\externals\boost_1_54_0\boost\geometry\algorithms\intersection.hpp(97) : see reference to class template instantiation 'boost::range_value<T>' being compiled
1> with
1> [
1> T=Polygon
1> ]
1> c:\dev\externals\boost_1_54_0\boost\geometry\algorithms\intersection.hpp(201) : see reference to function template instantiation 'bool boost::geometry::dispatch::intersection<Geometry1,Geometry2>::apply<GeometryOut,boost::geometry::strategy_intersection<Tag,Geometry1,Geometry2,IntersectionPoint>>(const Geometry1 &,const Geometry2 &,GeometryOut &,const Strategy &)' being compiled
1> with
1> [
1> Geometry1=Polygon,
1> Geometry2=Polygon,
1> GeometryOut=Polygon,
1> Tag=boost::geometry::cartesian_tag,
1> IntersectionPoint=MyPoint,
1> Strategy=boost::geometry::strategy_intersection<boost::geometry::cartesian_tag,Polygon,Polygon,MyPoint>
1> ]
1> c:\test\main.cpp(45) : see reference to function template instantiation 'bool boost::geometry::intersection<Polygon,Polygon,Polygon>(const Geometry1 &,const Geometry2 &,GeometryOut &)' being compiled
1> with
1> [
1> Geometry1=Polygon,
1> Geometry2=Polygon,
1> GeometryOut=Polygon
1> ]
1>c:\dev\externals\boost_1_54_0\boost\range\value_type.hpp(30): error C3203: 'type' : unspecialized class template can't be used as a template argument for template parameter 'Iterator', expected a real type
1>c:\dev\externals\boost_1_54_0\boost\range\value_type.hpp(30): error C2955: 'boost::type' : use of class template requires template argument list
1> c:\dev\externals\boost_1_54_0\boost\type.hpp(14) : see declaration of 'boost::type'
1>c:\dev\externals\boost_1_54_0\boost\range\value_type.hpp(31): error C2955: 'boost::iterator_value' : use of class template requires template argument list
1> c:\dev\externals\boost_1_54_0\boost\iterator\iterator_traits.hpp(29) : see declaration of 'boost::iterator_value'
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(21): error C2039: 'const_reference' : is not a member of 'boost::geometry::model::polygon<Point>'
1> with
1> [
1> Point=MyPoint
1> ]
1> c:\dev\externals\boost_1_54_0\boost\geometry\algorithms\intersection.hpp(103) : see reference to class template instantiation 'std::back_insert_iterator<_Container>' being compiled
1> with
1> [
1> _Container=Polygon
1> ]
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(21): error C2146: syntax error : missing ';' before identifier 'const_reference'
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(21): error C4430: missing type specifier - int assumed. Note: C++ does not support default-int
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(21): error C2602: 'std::back_insert_iterator<_Container>::const_reference' is not a member of a base class of 'std::back_insert_iterator<_Container>'
1> with
1> [
1> _Container=Polygon
1> ]
1> d:\program files\microsoft visual studio 10.0\vc\include\iterator(21) : see declaration of 'std::back_insert_iterator<_Container>::const_reference'
1> with
1> [
1> _Container=Polygon
1> ]
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(21): error C2868: 'std::back_insert_iterator<_Container>::const_reference' : illegal syntax for using-declaration; expected qualified-name
1> with
1> [
1> _Container=Polygon
1> ]
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(22): error C2039: 'value_type' : is not a member of 'boost::geometry::model::polygon<Point>'
1> with
1> [
1> Point=MyPoint
1> ]
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(29): error C2182: '_Val' : illegal use of type 'void'
1>d:\program files\microsoft visual studio 10.0\vc\include\iterator(35): error C2182: '_Val' : illegal use of type 'void'
1>c:\dev\externals\boost_1_54_0\boost\geometry\algorithms\intersection.hpp(103): error C2064: term does not evaluate to a function taking 4 arguments
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========
最佳答案
有很多问题:
MultiPolygon
概念),而不是单个多边形(这就是为什么您会遇到关于缺少 range_value<Polygon>
特征等的编译错误)area
算法只适用于二维坐标系。因此,它不会使用 assert_dimension<Ring, 2>()
进行编译。 .我通过这样做“修复”了它
struct MyPoint { double x, y/*, z*/; };
BOOST_GEOMETRY_REGISTER_POINT_2D(MyPoint, double, boost::geometry::cs::cartesian, x, y/*, z*/)
最后,多边形本身的格式不正确。您需要确保它们是指定的正确多边形,或者使用 correct
算法来解决这个问题。
这是一个固定/清理过的样本: Live on Coliru
#include <boost/geometry/geometry.hpp>
#include <boost/geometry/geometries/register/point.hpp>
#include <boost/geometry/geometries/register/ring.hpp>
struct MyPoint
{
double x, y/*, z*/;
};
BOOST_GEOMETRY_REGISTER_POINT_2D(MyPoint, double, boost::geometry::cs::cartesian, x, y/*, z*/)
typedef boost::geometry::model::polygon<MyPoint> Polygon;
BOOST_GEOMETRY_REGISTER_RING(Polygon::ring_type)
int main()
{
using boost::geometry::append;
using boost::geometry::correct;
using boost::geometry::dsv;
Polygon poly1;
Polygon poly2;
append(poly1, MyPoint {2, 0});
append(poly1, MyPoint {2, 2});
append(poly1, MyPoint {0, 2});
append(poly1, MyPoint {0, 0});
append(poly1, MyPoint {2, 0});
append(poly2, MyPoint {3, 0});
append(poly2, MyPoint {3, 3});
append(poly2, MyPoint {0, 3});
append(poly2, MyPoint {0, 0});
append(poly2, MyPoint {3, 0});
correct(poly1);
correct(poly2);
std::vector<Polygon> polys;
if (boost::geometry::intersection(poly1, poly2, polys))
{
for (Polygon const& inter : polys)
std::cout << "Intersection polygon area is " << boost::geometry::area(inter) << " with " << dsv(inter) << "\n";
}
}
作为奖励,它打印出实际的交叉多边形:
Intersection polygon area is 4 with (((0, 0), (0, 2), (2, 2), (2, 0), (0, 0)))
关于c++ - 编译 boost::geometry 多边形,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19350299/
我正在尝试使用 SQLyog IDE 在 mySql 中执行复制表到不同的主机/数据库,并且在复制具有 2 个几何字段的表时遇到以下错误: Cannot get geometry object fro
我正在通过来自空间表的SQL查询创建一个新表: CREATE TABLE SomeShapes AS SELECT ash.id, ash.Geometry FROM AllShapes ash WH
考虑以下场景:给定 n 个 Polygon2D 节点,它们的行为类似于“阴影”(黑色,alpha 值减半),如何使用 merge_polygons_2d() 方法将所有这些节点组合成一个 Polygo
我最近升级到 MySQL 5.7,并试图从 5.6 master 运行复制。但是,复制失败并出现以下错误: Error 'Cannot get geometry object from data yo
我在 SQLite 数据库中存储了几何数据,列的数据类型是 BLOB。 我使用以下方法将 BLOB 数据转换为清晰的 map 几何图形 SharpMap.Converters.WellKnownBin
我有两个问题: 1.) 我刚刚找到了 boost 1.53 Polygon 实现(在 http://www.boost.org/doc/libs/1_53_0/libs/polygon 上)并且想测试
我正在尝试将一些 Geometry 加载和处理卸载到 web worker 中。要将其发送回主线程,需要对 Geometry 实例进行序列化,而且 Geometry.prototype.toJSON(
对于可定制的激光切割抽屉项目,我希望能够以编程方式在任意两个相交的垂直“2D”对象(具有宽度)之间创建连接。为此,我需要: 以某种标准格式加载和保存 2D 对象。 挤出二维对象,并对二维对象进行标
我试图找到多边形内部的线串部分。我尝试了 intersection 函数,但它似乎只是找到实际的交点,而不是与多边形重叠的线串部分。有没有办法得到这个对象? 这是一个演示情况: #include #
我正在尝试使用 NHibernate.Spatial.MySQL(版本 4.0.4.4001)创建一个简单的演示解决方案。解决方案可以在这里找到:https://github.com/andrerav
我有一些数据库使用 MySQL 中的 POINT 字段来存储几何数据。所有数据都以相同的方式添加: GeomFromText( 'POINT( lat lng )' ) 除了一个数据库外,所有数据库的
我有一个专栏让我对 MySQL Server 5.7.11 感到头疼。 它是 POINT 类型,我可以毫无问题地将其更改为 GEOMETRY 类型。 当我现在尝试将其从 GEOMETRY 更改为 PO
据我了解,您可以使用以下方法访问网格每个顶点的 uv 坐标(“纹素”): geometry.faceVertexUvs[ materialIndex ][ faceIndex ][ vertexInd
我很快就会遇到一个有趣的问题,我已经开始考虑算法了。我越想越害怕,因为我认为它会扩展得非常可怕 (O(n^4)),除非我能变聪明。我很难理解这个。这是问题的简化描述。 我有 N 个多边形(其中 N 可
给定二维平面中的 2 个点,这两个点内有多少个格点? 例如,对于 A (3, 3) 和 B (-1, -1),输出为 5。点是: (-1, -1), (0, 0), (1, 1), (2 , 2) 和
我有两个三角形,可以是任何大小。问题是,如何将坐标从一个三角形转移到另一个三角形?我知道坐标系中的两个三角形位置,是的,它们都在一个系统中。 基本上,我在triangle1中有点,我需要将它转移到tr
我有一些 线路 他们的交集描述了一个多边形,如下所示: 我知道线条的顺序,以及它们的方程。 为了找到内角,我找到了每条线的方向。但是我很困惑,因为减去两条线的方向会给出两个不同的角度,即使我是按照多边
线(x1,y1),(x2,y2)和(x3,y3),(x4,y4)是垂直的。我有点坐标 (x1, y1), (x2, y2), (x3, y3) 和线的长度 (x3, y3), (x4, y4)。我需要
在 N (~ 500) 维中,我希望找出最大的球体或矩形,使球体/矩形不包含现有的点。整个点集以轴对齐的矩形框为界(值的下限和上限)。 是否有任何已知的多项式时间方法/代码可以用来解决我的问题? 两个
我有以下代码: #include using namespace irr; using namespace core; using namespace scene; using namespace
我是一名优秀的程序员,十分优秀!