VS2017 + Win10 下的 OpenCPN 5.0.0 编译过程小结

2023-12-20 19:32

本文主要是介绍VS2017 + Win10 下的 OpenCPN 5.0.0 编译过程小结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本文介绍了OpenCPN 5.0.0版本的编译过程,官方网站给出了一个流程,但是亲测后发现还是有一些小坑,官方给出的命令行操作由于网络(可能需要科学上网)不一定畅通,导致难以下载成功,在此把本人成功配置并编译的过程分享出来,让需要的人少走弯路。

目标

基于VS2017(对应VC15)编译最新版OpenCPN的 debugrealease版本。

参考资料
  1. OpenCPN Github
  2. OpenCPN Manuals - Compiling on Windows
  3. OpenCPN Manuals - Compile 2015 VS Community Workflow
下载汇总
  1. Visual Studio Community 2017 (version 15.9)
  2. Git
  3. CMake
  4. POedit
  5. NSIS
  6. 7-Zip
  7. OpenCPN 预编译Windows依赖 - OpenCPN_buildwin-4.99a.7z
  8. 界面库源码 - wxWidgets 3.1.2.zip
  9. 编译 Debug 版本的 batch 复制命令 - copyfiles.bat.doc
  10. 资源汇总
  • 资源汇总-OpenCPN源码含所有submodule(1/2)
  • 资源汇总-其他必需的安装包及库文件(2/2)。

有些资源下载的很慢,如果实在下载不到,可以用我提供的,源码文件太大超过 440M 只能分成两个资源,每个只要2分,赚个辛苦钱我也好下点资源,谢谢支持。


编译流程
  1. 安装VS2017,这一步就不展开了,OpenCPN 官网提到如下要求,注意勾选即可。

Install and select the workload Desktop development with C++ and include component Windows XP support for C++.
Also include the appropriate Windows x SDK component. Generally install the most current version, Windows 10 preferred.

  1. 必须】安装 GitCMake, 对应官网都有安装包,找最新的版本下载来安装就好了。
  2. 必须】安装并 POedit, 配置系统环境变量,在PATH中添加

C:\Program Files (x86)\Poedit\GettextTools\bin

  1. 非必须】安装NSIS, OpenCPN提供的网址里的 download 指向错误,在 sourceforge上找到了下载链接,见下载汇总,这个主要用于制作安装包的,如果只是用调试版,暂时用不上这个。
  2. 不重要】安装 7-Zip, 我是把 32 位和 64 位的都安装了,这个主要是解压下载汇总中的预编译依赖压缩包用的,有其他常用的解压工具的话也不是很需要这个。
  3. 下载 wxWidgets 3.1.2源码并编译。
  • 【注意】虽然wxWidgets官网提供了 Win下预编译好的库,但是只有 release版本,我们这里直接从源码编译debugrelease版本的库,下载官方的最新源码压缩包,这里一定注意,下载这个Zip文件。在这里插入图片描述利用git clone和或下载下面的source code中都没有submodule,虽然利用gitgit submodule update命令理论上可以下载到这些子模块,但是亲测由于网络原因几乎无法成功下载,所以还是老实的去上面这里下载。下载Zip完成后,注意有些教程可能说到进入\wxWidgets-3.1.2\build\msw然后找到wx_vc15.sln的工程打开后生成库,我在这里走了弯路,经过测试,这么做会报错,并且不好解决,还是严格按照官网的配置流程来,打开x86 Native Tools Command Prompt for VS 2017后输入如下命令:

cd xx/wxWidgets-3.1.2/build/msw//改到自己的路径
nmake /f makefile.vc BUILD=release SHARED=1 CXXFLAGS=/D_USING_V141_SDK71_ CFLAGS=/D_USING_V141_SDK71_ LDFLAGS=/SUBSYSTEM:WINDOWS,5.01
nmake /f makefile.vc BUILD=debug SHARED=1 CXXFLAGS=/D_USING_V141_SDK71_ CFLAGS=/D_USING_V141_SDK71_ LDFLAGS=/SUBSYSTEM:WINDOWS,5.01

  • 【提示】用Win+S弹出的搜索框中输入x86 Native后就会很容易找到x86 Native Tools Command Prompt for VS 2017
  • 随着一阵哗哗的输出,release版本的编译完了,按一下回车,继续debug的编译。编译完了后在\wxWidgets-3.1.2\lib\vcdll就能看到debugrelease版本的编译好的库。
  • 重要】编译结束后,设置系统环境变量 wxWIDGETS_ROOT_DIR路径为 wxWidgets源码的顶级目录。 在这里插入图片描述
  1. 下载 OpenCPN源码, 在你想放置OpenCPN源码的文件夹下,右键选择Git Bash Here, 复制下面的命令后回车就可以直接从github克隆到本地了:

git clone https://github.com/OpenCPN/OpenCPN

  1. 下载 预编译Windows依赖 - OpenCPN_buildwin-4.99a.7z,然后解压到\xx\OpenCPN\buildwin也就是复制到你 cloneOpenCPN源码目录中的 buildwin目录下。
  2. OpenCPN编译之Release版本的编译
  • 首先配置工程,打开x86 Native Tools Command Prompt for VS 2017进入\xx\OpenCPN\路径后输入如下命令:

cd xx\OpenCPN\//还是一样,换成你自己的路径
mkdir build
cd build
cmake -G "Visual Studio 15 2017" -T v141_xp ..

  • 完成后build中就生成了OpenCPN.sln工程文件,官网的编译命令如下:

cmake --build .
cmake --build . --config release
cmake --build . --config release --target package

  • 如果不采用命令行编译,也可以直接打开OpenCPN.sln工程进行编译,因为这里大概率会报错,用VS编译比较方便定位错误,我建议直接打开VS工程编译。打开 \build\OpenCPN.sln工程文件我们来跑一跑OpenCPN看看能不能运行起来。在这里插入图片描述
  • 打开工程后,把opencpn右键设置为启动项目,我这里先选择的是Release(Win32)然后点击运行吧。不出所料,果然出现了一个错误,我们定位到报错行:

xx\OpenCPN\src\options.cpp(8867): error C2001: 常量中有换行符

在这里插入图片描述

  • 看起来是中文字符的问题,查了查资料发现改起来好像比较麻烦,这个字体应该表示繁体中文,我们先把它随便改成英文试一试,例如“正体字”改成“zhengti”(很随意的不要纠结),继续点击运行,看看还有没有错误没有解决。
  • 刚才字体的问题暂时解决了,但是出现了新的问题:在这里插入图片描述
  • 这个就比较常见了,点击运行的时候提示缺少一些dll,一般是没有加入系统环境变量或者复制到对应的DebugRelease文件夹下,提示缺少一些wx相关的dll,那么大概率就是我们之前的编译好的界面库没有加入系统环境变量,虽然我们之前设置了 wxWIDGETS_ROOT_DIR这一变量,但是我们的dll文件在wxWidgets-3.1.2\lib\vc_dll\路径下,所以我们把这个路径加入系统环境变量PATH中。
  • 仔细检查官网步骤,其实还有一步配置:下载 Copyfiles.bat.doc(见下载汇总)并删去后缀名 .doc移动到\xx\OpenCPN\下面后执行copyfiles.bat(这步不做可能还是会缺几个dll)。
  • 做完上面两步,重启一下VS2017,再打开OpenCPN.sln,直接执行,果然成功了。在这里插入图片描述
  1. OpenCPN编译之Debug版本的编译
  • OpenCPN.sln工程中的项目改成Debug(Win32)运行一下,一切都运行正常,那么试一下加断点吧:在这里插入图片描述
  • 也没有出现什么问题,至此DebugRelease版本的OpenCPN都编译并测试完成了。
小结
  1. 其实,官网文档已经够用了,我这里大多也只是翻译了一遍,只要严格按照官网提供的步骤,一步一步进行是肯定能够编译成功的。
  2. 唯一出现的一点小问题就是最后缺少dll的问题,这个小问题凭借我们一般编译项目的经验就可以解决。
  3. 目前遗留的小问题是中文字符的问题,也是个麻烦事,暂时没去解决。
  4. 特别需要注意的是,如果对某一模块有指定版本,那么官网都给出了具体的版本号,比如界面库是3.1.2,在不熟练的情况下,第一次编译最好严格按照官网说明的版本进行,可能会少走弯路。
  5. 最后我把中间需要用到的安装包和库都放在一起(除了VS2017GitCMake),如果实在下不到,可以采用我提供的这些文件,不过,自己试一试走一遍流程,可能印象会更深刻。

这篇关于VS2017 + Win10 下的 OpenCPN 5.0.0 编译过程小结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Spring Boot 整合 Apache Flink 的详细过程

《SpringBoot整合ApacheFlink的详细过程》ApacheFlink是一个高性能的分布式流处理框架,而SpringBoot提供了快速构建企业级应用的能力,下面给大家介绍Spri... 目录Spring Boot 整合 Apache Flink 教程一、背景与目标二、环境准备三、创建项目 & 添

pytest+allure环境搭建+自动化实践过程

《pytest+allure环境搭建+自动化实践过程》:本文主要介绍pytest+allure环境搭建+自动化实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、pytest下载安装1.1、安装pytest1.2、检测是否安装成功二、allure下载安装2.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

Redis指南及6.2.x版本安装过程

《Redis指南及6.2.x版本安装过程》Redis是完全开源免费的,遵守BSD协议,是一个高性能(NOSQL)的key-value数据库,Redis是一个开源的使用ANSIC语言编写、支持网络、... 目录概述Redis特点Redis应用场景缓存缓存分布式会话分布式锁社交网络最新列表Redis各版本介绍旧