osg qt5.15 osg3.6.3 osgEarth3.1 编译爬山

Demo演示:Qt5.15.2+OSG3.6.3+OsgEarth3.1的QtCreator下的msvc2019x64版本

 

osgQt编译

步骤一:下载解压

步骤二:CMake配置

步骤三:CMake配置添加osg环境

步骤四:CMake配置添加Qt环境

步骤五:CMake修改CMakeLists文件内容:


还是出现错误:


检查,并未发现错误


继续深入

有一个路径填错了:


过了,继续配置:


填入其他Qt路径:

步骤六:配置通过

步骤七:生成成功

步骤八:打开工程,进行编译


编译各种问,尝试过多次后放弃,看其他博客是可以的。


(后面的复杂,博主直接修改源码开始移植过去,直接加入工程方式,过程比较艰难,如果能编译好osgQt是最好的,改源码问题较多,需要的可联系博主获取,但是不免费,尊重劳动成果,禁止白嫖)

模块化

配置文件

OsgEarthWidget.pri

INCLUDEPATH += $$PWD
DEPENDPATH += $$PWDQT += openglFORMS += \$$PWD/OsgWidget.uiHEADERS += \$$PWD/OsgViewerWidget.h \$$PWD/OsgWidget.h \$$PWD/define.h \$$PWD/osgQt/include/osgQOpenGL/Export.hSOURCES += \$$PWD/OsgViewerWidget.cpp \$$PWD/OsgWidget.cpp \$$PWD/define.cpp# osg
INCLUDEPATH += $$PWD/osg3.6.3-vs2019/include
DEPENDPATH += $$PWD/osg3.6.3-vs2019/includeLIBS += -L$$PWD/osg3.6.3-vs2019/lib
LIBS += -lOpenThreads \-losg \-losgAnimation \-losgDB \-losgFX \-losgGA \-losgManipulator \-losgParticle \-losgPresentation \-losgShadow \-losgText \-losgUI \-losgUtil \-losgViewer \-losgVolume \-losgWidget \
#        -losgQt \-losgSim \-losgTerrain# osgQt
INCLUDEPATH += $$PWD/osgQt/include
DEPENDPATH += $$PWD/osgQt/includeHEADERS += \$$PWD/osgQt/include/osgQOpenGL/CullVisitorEx \$$PWD/osgQt/include/osgQOpenGL/GraphicsWindowEx \$$PWD/osgQt/include/osgQOpenGL/OSGRenderer \$$PWD/osgQt/include/osgQOpenGL/RenderStageEx \$$PWD/osgQt/include/osgQOpenGL/StateEx \$$PWD/osgQt/include/osgQOpenGL/osgQOpenGLWidget \$$PWD/osgQt/include/osgQOpenGL/osgQOpenGLWindowSOURCES += \$$PWD/osgQt/include/osgQOpenGL/CullVisitorEx.cpp \$$PWD/osgQt/include/osgQOpenGL/GraphicsWindowEx.cpp \$$PWD/osgQt/include/osgQOpenGL/OSGRenderer.cpp \$$PWD/osgQt/include/osgQOpenGL/RenderStageEx.cpp \$$PWD/osgQt/include/osgQOpenGL/StateEx.cpp \$$PWD/osgQt/include/osgQOpenGL/osgQOpenGLWidget.cpp \$$PWD/osgQt/include/osgQOpenGL/osgQOpenGLWindow.cpp# osgEarth
INCLUDEPATH += $$PWD/osgearth3.1-vs2019/includeLIBS += -L$$PWD/osgearth3.1-vs2019/lib
LIBS += -losgEarth

Demo源码

osg::ref_ptr<osg::Node> OsgWidget::getEarthSphiere()
{osg::ref_ptr<osg::Group> pGroup = new osg::Group;osgEarth::initialize();const char* styles_css =R"(p {altitude-clamping: terrain-drape;render-backface-culling: false;}p1: p{ fill: #ff3f3f9f; }p2: p{ fill: #3fff3f9f; }p3: p{ fill: #3f3fff9f; }p4: p{ fill: #ff3fff9f; }p5: p{ fill: #ffff3f9f; })";const char* script_source =R"(function getStyleClass(){// Exclude any countries beginning with the letter A:if ( feature.properties.name.charAt(0) === 'A' )return null;// If it starts with the letter C, return an inline style:if ( feature.properties.name.charAt(0) == 'C' )return '{ _fill: #ffc838; stroke: #8f8838; extrusion-height: 250000; }';// Otherwise, return a named style based on some calculations:var pop = parseFloat(feature.properties.pop);if      ( pop <= 14045470 )  return "p1";else if ( pop <= 43410900 )  return "p2";else if ( pop <= 97228750 )  return "p3";else if ( pop <= 258833000 ) return "p4";else                         return "p5";})";osg::ref_ptr<Map> map = new Map();GDALImageLayer* basemap = new GDALImageLayer();basemap->setURL("world.tif");map->addLayer(basemap);// Next we add a layer to provide the feature data.OGRFeatureSource* features = new OGRFeatureSource();features->setName("vector-data");features->setURL("world.shp");map->addLayer(features);Style style;LineSymbol* ls = style.getOrCreateSymbol<LineSymbol>();ls->stroke()->color() = Color::Yellow;ls->stroke()->width() = 2.0f;ls->tessellationSize()->set(100, Units::KILOMETERS);FeatureModelLayer* layer = new FeatureModelLayer();layer->setFeatureSource(features);StyleSheet* styleSheet = new StyleSheet();styleSheet->addStyle(style);layer->setStyleSheet(styleSheet);map->addLayer(layer);LayerVector layers;map->getLayers(layers);for (LayerVector::const_iterator i = layers.begin(); i != layers.end(); ++i){Layer* layer = i->get();if (layer->getStatus().isError() &&layer->getEnabled()){OE_WARN << layer->getName() << " : " << layer->getStatus().toString() << std::endl;}}MapNode* mapNode = new MapNode(map.get());_pViewer->setCameraManipulator(new EarthManipulator());pGroup->addChild(mapNode);return pGroup.get();
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/487987.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

v-rep插件

v-rep官网插件汉化教程 官网教程 插件是什么 插件本质上就是遵循一定规范的API编写出来的程序&#xff0c;在v-rep中最终需要编译为动态库。 linux下是libsimXXXX.so&#xff1b; 其中XXXX是插件的名称。 请至少使用4个字符&#xff0c;并且不要使用下划线&#xff0c;因为…

Vue学习之计算属性

模板中的表达式虽然方便&#xff0c;但也只能用来做简单的操作。如果在模板中写太多逻辑&#xff0c;会让模板变得臃肿&#xff0c;难以维护。比如说&#xff0c;我们有这样一个包含嵌套数组的对象&#xff1a; const author reactive({name: John Doe,books: [Vue 2 - Advan…

“IT行业职业发展的黄金之路:哪些证书能为你增光添彩?“

文章目录 每日一句正能量前言1、浙大计算机程序设计能力考试证书&#xff08;PAT&#xff09;2、全国计算机等级考试证书(NCRE)3、计算机技术与软件专业资格考试证书&#xff08;软考&#xff09;4、通信专业技术人员职业水平证书5、全国计算机应用水平考试证书&#xff08;NIT…

vivado VHDL Support

介绍 本章介绍AMD Vivado™合成和 注意支持的任何例外情况。VHDL紧凑地描述了复杂的逻辑&#xff0c;并允许您&#xff1a; •描述系统的结构&#xff1a;如何将系统分解为子系统&#xff0c;以及如何这些子系统是相互连接的。 •使用熟悉的语言形式指定系统的功能。 •在…

个人博客系列-前端部署-创建框架(4)

项目环境介绍 Vue3 Vite TypeScript 服务器&#xff1a;阿里云contos node版本&#xff1a;v18.18.2 npm版本&#xff1a;v10.2.4 执行下面一行命令&#xff0c;创建vue3框架 npm create vuelatest修改端口&#xff1a;9528&#xff0c; 此步骤可以忽略&#xff08;使用默…

前端学习——JS学习

文章目录 1. 定义变量&#xff0c;关键字 var、let、const2. 定义变量&#xff0c;数据类型3. 数组变量的操作4. 对象的操作5. JSON 字符串 1. 定义变量&#xff0c;关键字 var、let、const 这里主要是对var、let做比较 /** 1. var存在变量提升、let不存在变量提升 **/ cons…

MFC 配置Halcon

1.新建一个MFC 工程&#xff0c;Halcon 为64位&#xff0c;所以先将工程改为x64 > VC 目录设置包含目录和库目录 包含目录 库目录 c/c ->常规 链接器 ->常规 > 链接器输入 在窗口中添加头文件 #include "HalconCpp.h" #include "Halcon.h"…

robots.txt 文件规则

robots.txt 是一种用于网站根目录的文本文件&#xff0c;其主要目的在于指示网络爬虫&#xff08;web crawlers&#xff09;和其他网页机器人&#xff08;bots&#xff09;哪些页面可以抓取&#xff0c;以及哪些页面不应该被抓取。可以看作是网站和搜索引擎机器人之间的一个协议…

强大的文本绘图——PlantUML

PlantUML是一款开源工具&#xff0c;它允许用户通过简单的文本描述来创建UML图&#xff08;统一建模语言图&#xff09;。这种方法可以快速地绘制类图、用例图、序列图、状态图、活动图、组件图和部署图等UML图表。PlantUML使用一种领域特定语言&#xff08;DSL&#xff09;&am…

Unet 高阶分割网络实战、多类别分割、迁移学习(deeplab、resnet101等等)

1、前言 Unet 图像分割之前介绍了不少&#xff0c;具体可以参考 图像分割专栏 为了实现多类别的自适应分割&#xff0c;前段时间利用numpy的unique函数实现了一个项目。通过numpy函数将mask的灰度值提取出来&#xff0c;保存在txt文本里&#xff0c;这样txt里面就会有类似0 1…

RisingWave最佳实践-利用Dynamic filters 和 Temporal filters 实现监控告警

心得的体会 刚过了年刚开工&#xff0c;闲暇之余调研了分布式SQL流处理数据库–RisingWave&#xff0c;本人是Flink&#xff08;包括FlinkSQL和Flink DataStream API&#xff09;的资深用户&#xff0c;但接触到RisingWave令我眼前一亮&#xff0c;并且拿我们生产上的监控告警…

快速排序法的名字由来,排序步骤是什么,最坏情况下的排序次数如何计算得来的呢?

问题描述&#xff1a; 快速排序法的名字由来&#xff0c;排序步骤是什么&#xff0c;最坏情况下的排序次数如何计算得来的呢&#xff1f; 问题解答&#xff1a; 快速排序法的名字来源于其排序速度快的特点。它是由英国计算机科学家 Tony Hoare 于1960年提出的&#xff0c;最…