我的测量有距离测量、面积测量、高度测量。
测量的结果显示都为一个PlaceNode,可以实时的显示测量的结果。
使用方式为:
pPlaceNode = new osgEarth::Annotation::PlaceNode(
MapNode, osgEarth::GeoPoint::GeoPoint(), "", textStyle);
pPlaceNode->setDynamic(true);
pPlaceNode->setText("测量结果");
pPlaceNode->setPosition(osgEarth::GeoPoint::GeoPoint(SRS, pos("经纬度")));
- 长度的计算方式使用OSGEarth提供的方式
osgEarth::GeoMath::distance()
; - 高度的测量直接两个点的高度差即可;
面积的测量,比较麻烦,考虑到需要计算球面的面积,因而需要实现计算方式。附上一个从网上找到的计算方式,由于忘记了原网站,请见谅!
网上内容,非原创算法 for (int i = 0; i < iCount; i++) { if (i == 0) { //换算成弧度; dLowX = osg::DegreesToRadians(po