Ubuntu上配置vtk开发环境——基于visual studio code 与 gcc
环境说明
vtk版本7.1.1
visual studio 1.16.1
Ubuntu 16.04 + 自带的gcc
编译过程与windows下类似还好,运行自己的代码开始面对cmake与make的各种命令以及文件的编译关系一脸懵逼,特别是一堆头文件的依赖和库依赖不知道从哪加起,瞬间发现visual studio写c++的代码简直是神器。
貌似Linux下比较智能的可以用eclipse(我喜欢的idea开发c++只有收费版),懒得折腾得太多,就选择了个轻量级的visual studio code搭建环境试试。
建议开始前稍微熟悉下cmake+gcc的编译模式,相关命令多基于百度Google,有问题之处欢迎交流。
vtk 环境编译
编译前需要先安装opengl的运行库
sudo apt-get install freeglut3-dev
基于cmake-gui编译,我编译选项中主要修改为:
BUILD_SHARED_LIBS 选中 编译可分享的库文件
CMAKE_BUILD_TYPE release 如果有调试的需要还需选中debug
CMAKE_INSTALL_PREFIX (默认位在/usr/local目录下,make install 命令会将编译出的静态链接库放入此目录下)
VTK_USE_CXX11_FEATURES 使用c++11标准
VTK_RENDERING_BACKEND 使用opengl的版本,我的显卡支持opengl,不支持默认的opengl2 !!!! 设置为opengl2可以编译成功但运行时会出错
还可以考虑是否需要编译python java等接口,是否需要编译示例代码等
cmake 编译出结果后,在输出目录调用make命令编译(台式机core i3处理器 半个多小时)
编译完成后 make install (不确定没有install会不会出问题)
基于命令行编译使用vtk运行示例代码
复制目录下的代码文件和cmake文件到项目文件夹 vtk-7.1.1/Examples/Tutorial/Step1/Cxx
运行命令:
cmake ./
make
在编译自己的代码时,对CMakeLists.txt文件内容需要略作修改:
PROJECT (myVolumeRendering)
# 1. 如果提示找不到VTK则设置vtk的编译输出路径
SET(ENV{VTK_DIR} /home/hadoop/vtk-7.1.1/_bin)
find_package(VTK REQUIRED)
include(${VTK_USE_FILE})
# 2. 此处设置为自己的cpp文件,直接添加即可
SET(SRC_FILES
myVolumeRender.cpp
MyVtkTool.cpp)
add_executable(myVolumeRendering ${SRC_FILES})
target_link_libraries(myVolumeRendering ${VTK_LIBRARIES})
配置visual studio code编译运行示例代码
复制目录下的代码文件和cmake文件到项目文件夹 vtk-7.1.1/Examples/Tutorial/Step1/Cxx
重点在于设置tasks.json文件(调用cmake与make命令编译源代码)与launch.json文件(生成的可执行文件运行或调试)
task 文件设置
用vs code打开项目文件夹,ctrl+shift+p, 输入选择 tasks:configure task runner,选择c++ 或者other会在.vscode文件夹下新建一个tasks.json文件。 貌似需要新建build文件夹。
粘贴以下内容:
{
// See https://go.microsoft.com/fwlink/?LinkId=733558
// for the documentation about the tasks.json format
"version": "2.0.0",
"options": {
"cwd": "${workspaceRoot}/build"
},
"tasks": [
{
"taskName": "cmake",
"command": "cmake",
"args": ["-G",
"Unix Makefiles",
"-DCMAKE_BUILD_TYPE=relese",
".."]
},
{
"taskName": "make",
"command": "make",
"args": [],
"group": {
"kind": "build",
"isDefault": true
}
}
]
}
launch.json文件设置
f5运行,会提示生成默认的launch.json文件,复制以下内容
{
"version": "0.2.0",
"configurations": [
{
"name": "(gdb) Launch",
"type": "cppdbg",
"request": "launch",
"program": "${workspaceRoot}/helloa",//此处设置可执行文件名
"args": [],//可以设置调试参数等
"stopAtEntry": false,
"cwd": "${workspaceRoot}",
"environment": [],
"externalConsole": true,
"MIMode": "gdb",
"setupCommands": [
{
"description": "Enable pretty-printing for gdb",
"text": "-enable-pretty-printing",
"ignoreFailures": true
}
]
}
]
}
cmakelists.txt文件设置
添加vtk的路径(不修改默认的INSTALL_PREFIX路径时不确定),此处设置为cmake的output路径
SET(ENV{VTK_DIR} /home/hadoop/vtk-7.1.1/_bin)
编译运行
- ctrl+shift+p 输入run task命令,运行cmake
- 可以同上运行make task(或者直接ctrl+shift+b)
- F5运行或调试
添加头文件路径 如果不需要代码补全等功能,此步可以省略。
包含头文件的位置会出现绿色波浪线提示找不到头文件,需要指定头文件的路径。点击头文件,然后点击左方出现的黄灯,选择某个设置选项会在.vscode目录下新建c_cpp_properties.json文件,在includePath与browse{path}下添加vtk的包含目录。
在运行cmake task后,build/CMakeFiles/you_execute_name.dir/DependInfo.cmake文件里有相关的包含目录,用带正则表达式的查找替换选项将 "$ 替换为 ", 即可添加后方的逗号。
{
"name": "Linux",
"includePath": [//作用不详,不确定去掉的影响……
"/usr/include/c++/5",
"/usr/include/x86_64-linux-gnu/c++/5",
"/usr/local/include",
"/usr/include",
"/usr/include/x86_64-linux-gnu",
"${workspaceRoot}",
"/home/hadoop/vtk-7.1.1/_bin/Common/Core",
"/home/hadoop/vtk-7.1.1/Common/Core",
//……
"/home/hadoop/vtk-7.1.1/Utilities/EncodeString"
],
"defines": [],
"intelliSenseMode": "clang-x64",
"browse": { //用于代码补全
"path": [
"/usr/include/c++/5",
"/usr/include/x86_64-linux-gnu/c++/5",
"/usr/local/include",
"/usr/include",
"/usr/include/x86_64-linux-gnu",
"${workspaceRoot}",
"/home/hadoop/vtk-7.1.1/_bin/Common/Core",
"/home/hadoop/vtk-7.1.1/Common/Core",
//……
],
"limitSymbolsToIncludedHeaders": true,
"databaseFilename": ""
}
},
Ubuntu上配置vtk开发环境——基于visual studio code 与 gcc的更多相关文章
- Windows10内嵌Ubuntu子系统配置python开发环境
Windows10内嵌Ubuntu子系统配置python开发环境 安装pycharm. 到intellij idea网站下载Linux环境下载免费的pycharm,通过ubuntu子系统内部的/mnt ...
- 学习时用的软件最新 开发环境为Visual Studio 2010,数据库为SQLServer2005,使用.net 4.0开发。 超市管理系统
一.源码特点 1.采用典型的三层架构进行开发.模板分离,支持生成静态 伪静态..购物车.登陆验证.div+css.js等技术二.功能介绍 1.本源码是一个超市在线购物商城源码,该网上商城是给超市便利店 ...
- 基于Visual Studio Code搭建Golang开发调试环境【非转载】
由于对Docker+kubernetes的使用及持续关注,要理解这个平台的原理,势必需要对golang有一定的理解,基于此开始利用业余时间学习go,基础语法看完之后,搭建开发环境肯定是第一步,虽然能g ...
- Salesforce 开发新工具 - Visual Studio Code
最近尝试使用Visual Studio Code来做Salesforce的开发工具,体验上比Sublime好用不少,介绍下详细步骤 第一步:下载对应版本的Visual Studio Code 下载地址 ...
- 30个极大提高开发效率的Visual Studio Code插件
译者按: 看完这篇文章,我打算从 Sublime Text 转到 Visual Studio Code 了! 原文: Immensely upgrade your development enviro ...
- ionic2——开发利器之Visual Studio Code 常用插件整理
1.VsCode官方插件地址: http://code.visualstudio.com/docs 2.使用方法,可以在官网中搜索需要的插件或者在VsCode的“”扩展“”中搜索需要的插件 添加方法使 ...
- 摆脱命令行,Ubuntu下配置Android开发环境
作者:宋志辉 微博:weibo.com/askzhihui/ 安装所需工具 一.新立得 新立得(Synaptic)是Debian和Ubuntu Linux操作系统的包管理工具apt的图形化前端. 它结 ...
- 如何在一台新电脑上配置JAVA开发环境
对于JAVA新手来说,刚开始要学JAVA,而自己的电脑上毫无与JAVA开发有关的环境,应该如何进行配置呢? (安卓新手也需要JAVA开发环境) 第一步,下载.安装java JRE JRE (Java ...
- Mac OS 上配置java开发环境
在开始本学期的java课程前,我需要先为自己的电脑配置好Java的开发环境.由于电脑是mac操作系统,所以教材上的教程对我并不管用,于是乎开始动手自己查阅网上资料来解决. 1.安装JDK 1.访问Or ...
随机推荐
- Tomcat Lifecycle
org.apache.catalina.Lifecycle 接口统一管理生命周期,所有生命周期组件都要实现Lifecycle接口. 该接口定义了13个String类型的常量,用于LifecycleEv ...
- Unity_如何判断应用设备内存小于1G(内容可定制为根据机器配置进行不同LOD)
直接上脚本,需要用的时候在需要的地方调用就好. 如: //获取设别的最大内存,作为判断LOD等级和决定1G以下设备不能进游戏 #if UNITY_ANDROID && !UNITY_E ...
- shell 实战 -- 基于一个服务启动,关闭,状态检查的脚本
功能说明: check:检查服务状态,在开启,关闭,状态检查时都会用到这个函数,所以封装起来放到最前面 start:开启服务 stop:关闭服务 fstop:强制关闭 status:检查服务状态 ru ...
- HBase分布式搭建常见错误
[root@node001 bin]# hbase shell SLF4J: Class path contains multiple SLF4J bindings. SLF4J: Found bin ...
- 【fiddler】fiddler基础
一.浏览器设置 一般情况下,fiddler会自动修改IE浏览器的设置,捕捉到IE浏览器的搜有通讯.其他浏览器需要手动设置 如chrome 打开chrome->设置->高级->系统-& ...
- shell脚本编写mind
首先我们要缩小这个问题的范围 如果在面试中被问到这样的问题,说说shell脚本编写思路 如:你是在公司主要负责zabbix监控的 对答如下:shell脚本这个说法挺广的,您看我这么跟您说吧,我在平时工 ...
- pytorch版yolov3训练自己数据集
目录 1. 环境搭建 2. 数据集构建 3. 训练模型 4. 测试模型 5. 评估模型 6. 可视化 7. 高级进阶-网络结构更改 1. 环境搭建 将github库download下来. git cl ...
- RedisTemplate的key默认序列化器问题
原文:https://blog.csdn.net/skymouse2002/article/details/80736577 redis的客户端换成了spring-boot-starter-data- ...
- Docker那些事儿之初识Docker
公司内部一直在使用Docker进行服务的部署和应用的升级,从开始使用Docker一直到线上的部署以及一些基础服务的开发本人都有参与,而且自己的网站也是在Docker的基础之上进行构建的,想想也需要总结 ...
- webpack 配置react脚手架(六):api
1 访问网址 https://cnodejs.org/api 可以调取api 2.//该body-parser 可以将请求的body数据,转变成 json 格式数据://express-session ...