标签注释、基础图元--osgearth_annotation

2023-11-08 14:10

本文主要是介绍标签注释、基础图元--osgearth_annotation,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. 功能实现
    带注释的标签,基础图元请添加图片描述

2.代码解析

创建标牌

	//设置样式,style可以获取不同类型的样式进行设置Style pm;pm.getOrCreate<IconSymbol>()->url()->setLiteral( "../data/placemark32.png" );pm.getOrCreate<IconSymbol>()->declutter() = true;pm.getOrCreate<TextSymbol>()->halo() = Color("#5f5f5f");//创建标牌并设置地址与样式labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -74.00, 40.71), "New York"      , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -77.04, 38.85), "Washington, DC", pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS,-118.40, 33.93), "Los Angeles"   , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -71.03, 42.37), "Boston"        , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS,-157.93, 21.35), "Honolulu"      , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, 139.75, 35.68), "Tokyo"         , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -90.25, 29.98), "New Orleans"   , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -80.28, 25.82), "Miami"         , pm));labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS,-117.17, 32.72), "San Diego"     , pm));// 添加一个LOD节点:osg::LOD* lod = new osg::LOD();lod->addChild( new PlaceNode(GeoPoint(geoSRS, 14.68, 50.0), "Prague", pm), 0.0, 2e6);labelGroup->addChild( lod );// absolute altitude:labelGroup->addChild( new PlaceNode(GeoPoint(geoSRS, -87.65, 41.90, 1000, ALTMODE_ABSOLUTE), "Chicago", pm));

代码比较简单,就是创建标牌节点并加入场景

osgearth中的画线

  		Geometry* geom = new Polygon();//输入点集geom->push_back( osg::Vec3d(0,   40, 0) );geom->push_back( osg::Vec3d(-60, 40, 0) );geom->push_back( osg::Vec3d(-60, 60, 0) );geom->push_back( osg::Vec3d(0,   60, 0) );Feature* feature = new Feature(geom, geoSRS);//使用大地坐标系feature->geoInterp() = GEOINTERP_RHUMB_LINE;//画线Style geomStyle;geomStyle.getOrCreate<LineSymbol>()->stroke()->color() = Color::Cyan;//颜色geomStyle.getOrCreate<LineSymbol>()->stroke()->width() = 5.0f;//宽度geomStyle.getOrCreate<LineSymbol>()->tessellationSize()->set(75000, Units::METERS);//还可以设置平滑度等geomStyle.getOrCreate<RenderSymbol>()->depthOffset()->enabled() = true;//是否开启深度测试FeatureNode* fnode = new FeatureNode(feature, geomStyle);annoGroup->addChild( fnode );

点迹线

		Geometry* path = new LineString();path->push_back( osg::Vec3d(-74, 40.714, 0) );   // New Yorkpath->push_back( osg::Vec3d(139.75, 35.68, 0) ); // TokyoFeature* pathFeature = new Feature(path, geoSRS);pathFeature->geoInterp() = GEOINTERP_GREAT_CIRCLE;//球面插值Style pathStyle;pathStyle.getOrCreate<LineSymbol>()->stroke()->color() = Color::White;pathStyle.getOrCreate<LineSymbol>()->stroke()->width() = 1.0f;pathStyle.getOrCreate<LineSymbol>()->stroke()->smooth() = true;pathStyle.getOrCreate<LineSymbol>()->tessellationSize()->set(75000, Units::METERS);//75000米一个点pathStyle.getOrCreate<PointSymbol>()->size() = 8;//点的大小pathStyle.getOrCreate<PointSymbol>()->fill()->color() = Color::Red;pathStyle.getOrCreate<PointSymbol>()->smooth() = true;pathStyle.getOrCreate<AltitudeSymbol>()->clamping() = AltitudeSymbol::CLAMP_TO_TERRAIN;//贴地pathStyle.getOrCreate<AltitudeSymbol>()->technique() = AltitudeSymbol::TECHNIQUE_GPU;pathStyle.getOrCreate<RenderSymbol>()->depthOffset()->enabled() = true;//OE_INFO << "Path extent = " << pathFeature->getExtent().toString() << std::endl;pathNode = new FeatureNode(pathFeature, pathStyle);annoGroup->addChild( pathNode );LabelNode* label = new LabelNode("Great circle path", labelStyle);label->setPosition(GeoPoint(geoSRS,-170, 61.2));labelGroup->addChild(label);

画圆

 		Style circleStyle;circleStyle.getOrCreate<PolygonSymbol>()->fill()->color() = Color(Color::Cyan, 0.5);circleStyle.getOrCreate<AltitudeSymbol>()->clamping() = AltitudeSymbol::CLAMP_TO_TERRAIN;circleStyle.getOrCreate<AltitudeSymbol>()->technique() = AltitudeSymbol::TECHNIQUE_DRAPE;CircleNode* circle = new CircleNode();circle->set(GeoPoint(geoSRS, -90.25, 29.98, 1000., ALTMODE_RELATIVE),Distance(300, Units::KILOMETERS),circleStyle,Angle(-45.0, Units::DEGREES),Angle(45.0, Units::DEGREES),true);annoGroup->addChild( circle );

加载模型

    {Style style;style.getOrCreate<ModelSymbol>()->autoScale() = true;style.getOrCreate<ModelSymbol>()->url()->setLiteral("../data/red_flag.osg.50.scale");ModelNode* modelNode = new ModelNode(mapNode, style);modelNode->setPosition(GeoPoint(geoSRS, -100, 52));annoGroup->addChild(modelNode);}

加载图片

    // an image overlay.{ImageOverlay* imageOverlay = 0L;osg::ref_ptr<osg::Image> image = osgDB::readRefImageFile( "../data/USFLAG.TGA" );if (image.valid()){imageOverlay = new ImageOverlay(mapNode, image.get());imageOverlay->setBounds( Bounds( -100.0, 35.0, -90.0, 40.0) );annoGroup->addChild( imageOverlay );editGroup->addChild( new ImageOverlayEditor(imageOverlay) );}}

椭圆

        Style ellipseStyle;ellipseStyle.getOrCreate<PolygonSymbol>()->fill()->color() = Color(Color::Orange, 0.75);ellipseStyle.getOrCreate<ExtrusionSymbol>()->height() = 250000.0; // meters MSLEllipseNode* ellipse = new EllipseNode();ellipse->set(GeoPoint(geoSRS, -80.28, 25.82, 0.0, ALTMODE_RELATIVE),Distance(250, Units::MILES),Distance(100, Units::MILES),Angle   (0, Units::DEGREES),ellipseStyle,Angle(45.0, Units::DEGREES),Angle(360.0 - 45.0, Units::DEGREES),true);annoGroup->addChild( ellipse );

矩形

        Style rectStyle;rectStyle.getOrCreate<PolygonSymbol>()->fill()->color() = Color(Color::Green, 0.5);rectStyle.getOrCreate<AltitudeSymbol>()->clamping() = AltitudeSymbol::CLAMP_TO_TERRAIN;rectStyle.getOrCreate<AltitudeSymbol>()->technique() = AltitudeSymbol::TECHNIQUE_DRAPE;RectangleNode* rect = new RectangleNode(GeoPoint(geoSRS, -117.172, 32.721),Distance(300, Units::KILOMETERS ),Distance(600, Units::KILOMETERS ),rectStyle);annoGroup->addChild( rect );

线装要素和块状要素贴地的设置是不一样的。

//线装要素使用CLAMP_TO_TERRAIN+TECHNIQUE_GPU的组合
as->clamping()  = osgEarth::AltitudeSymbol::CLAMP_TO_TERRAIN;
as->technique() = osgEarth::AltitudeSymbol::TECHNIQUE_GPU;

面状要素使用

tStyle.getOrCreate<osgEarth::Symbology::AltitudeSymbol>()->clamping() = osgEarth::Symbology::AltitudeSymbol::CLAMP_TO_TERRAIN;
tStyle.getOrCreate<osgEarth::Symbology::AltitudeSymbol>()->technique() = osgEarth::Symbology::AltitudeSymbol

这篇关于标签注释、基础图元--osgearth_annotation的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370392

相关文章

CSS去除a标签的下划线的几种方法

《CSS去除a标签的下划线的几种方法》本文给大家分享在CSS中,去除a标签(超链接)的下划线的几种方法,本文给大家介绍的非常详细,感兴趣的朋友一起看看吧... 在 css 中,去除a标签(超链接)的下划线主要有以下几种方法:使用text-decoration属性通用选择器设置:使用a标签选择器,将tex

Python基础文件操作方法超详细讲解(详解版)

《Python基础文件操作方法超详细讲解(详解版)》文件就是操作系统为用户或应用程序提供的一个读写硬盘的虚拟单位,文件的核心操作就是读和写,:本文主要介绍Python基础文件操作方法超详细讲解的相... 目录一、文件操作1. 文件打开与关闭1.1 打开文件1.2 关闭文件2. 访问模式及说明二、文件读写1.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti

C#基础之委托详解(Delegate)

《C#基础之委托详解(Delegate)》:本文主要介绍C#基础之委托(Delegate),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 委托定义2. 委托实例化3. 多播委托(Multicast Delegates)4. 委托的用途事件处理回调函数LINQ

Python中的输入输出与注释教程

《Python中的输入输出与注释教程》:本文主要介绍Python中的输入输出与注释教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、print 输出功能1. 基础用法2. 多参数输出3. 格式化输出4. 换行控制二、input 输入功能1. 基础用法2. 类

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

HTML5中下拉框<select>标签的属性和样式详解

《HTML5中下拉框<select>标签的属性和样式详解》在HTML5中,下拉框(select标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中选择值的方式,本文将深入探讨select标签的... 在html5中,下拉框(<select>标签)作为表单的重要组成部分,为用户提供了一个从预定义选项中

Rust中的注释使用解读

《Rust中的注释使用解读》本文介绍了Rust中的行注释、块注释和文档注释的使用方法,通过示例展示了如何在实际代码中应用这些注释,以提高代码的可读性和可维护性... 目录Rust 中的注释使用指南1. 行注释示例:行注释2. 块注释示例:块注释3. 文档注释示例:文档注释4. 综合示例总结Rust 中的注释