环境说明

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)

编译运行

  1. ctrl+shift+p 输入run task命令,运行cmake
  2. 可以同上运行make task(或者直接ctrl+shift+b)
  3. 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的更多相关文章

  1. Windows10内嵌Ubuntu子系统配置python开发环境

    Windows10内嵌Ubuntu子系统配置python开发环境 安装pycharm. 到intellij idea网站下载Linux环境下载免费的pycharm,通过ubuntu子系统内部的/mnt ...

  2. 学习时用的软件最新 开发环境为Visual Studio 2010,数据库为SQLServer2005,使用.net 4.0开发。 超市管理系统

    一.源码特点 1.采用典型的三层架构进行开发.模板分离,支持生成静态 伪静态..购物车.登陆验证.div+css.js等技术二.功能介绍 1.本源码是一个超市在线购物商城源码,该网上商城是给超市便利店 ...

  3. 基于Visual Studio Code搭建Golang开发调试环境【非转载】

    由于对Docker+kubernetes的使用及持续关注,要理解这个平台的原理,势必需要对golang有一定的理解,基于此开始利用业余时间学习go,基础语法看完之后,搭建开发环境肯定是第一步,虽然能g ...

  4. Salesforce 开发新工具 - Visual Studio Code

    最近尝试使用Visual Studio Code来做Salesforce的开发工具,体验上比Sublime好用不少,介绍下详细步骤 第一步:下载对应版本的Visual Studio Code 下载地址 ...

  5. 30个极大提高开发效率的Visual Studio Code插件

    译者按: 看完这篇文章,我打算从 Sublime Text 转到 Visual Studio Code 了! 原文: Immensely upgrade your development enviro ...

  6. ionic2——开发利器之Visual Studio Code 常用插件整理

    1.VsCode官方插件地址: http://code.visualstudio.com/docs 2.使用方法,可以在官网中搜索需要的插件或者在VsCode的“”扩展“”中搜索需要的插件 添加方法使 ...

  7. 摆脱命令行,Ubuntu下配置Android开发环境

    作者:宋志辉 微博:weibo.com/askzhihui/ 安装所需工具 一.新立得 新立得(Synaptic)是Debian和Ubuntu Linux操作系统的包管理工具apt的图形化前端. 它结 ...

  8. 如何在一台新电脑上配置JAVA开发环境

    对于JAVA新手来说,刚开始要学JAVA,而自己的电脑上毫无与JAVA开发有关的环境,应该如何进行配置呢? (安卓新手也需要JAVA开发环境) 第一步,下载.安装java JRE JRE (Java ...

  9. Mac OS 上配置java开发环境

    在开始本学期的java课程前,我需要先为自己的电脑配置好Java的开发环境.由于电脑是mac操作系统,所以教材上的教程对我并不管用,于是乎开始动手自己查阅网上资料来解决. 1.安装JDK 1.访问Or ...

随机推荐

  1. 题解-CTS2019氪金手游

    Problem \(\mathtt {loj-3124}\) 题意概要:给定 \(n\) 个点,\(w_i\) 分别有 \(p_{i,1},p_{i,2},p_{i,3}\) 的概率取 \(1,2,3 ...

  2. Python中的单例模式的几种实现方式和优化以及pyc文件解释(转)

    原文:https://www.cnblogs.com/huchong/p/8244279.html 另一篇关于.pyc文件是什么?  原文: http://blog.sina.com.cn//s/bl ...

  3. VS.NET(C#)--2.3良构的XHTML

    良构的XHTML 1.关闭所有标签 2.禁止标签嵌套 3.区分大小写 4.引号  所有属性值都要置于引号中 5.唯一的根元素<html></html> 6.保留字符 XML中五 ...

  4. 怎么将visual studio项目打包生成dll文件

    1.打开电脑再打开visual studio软件,在软件里面新建一个项目,文件---->新建---->项目,打开新建项目窗口. 2.选择C#类工程,并为项目命名. 3.将类库文件class ...

  5. linux Ubuntu14.04 make编译文件报错:No rule to make target `/usr/lib/libpython2.7.so', needed by `python/_pywraps2.so'. Stop.

    错误过程:当“make”编译文件时报错No rule to make target `/usr/lib/libpython2.7.so', needed by `python/_pywraps2.so ...

  6. iOS - error:unrecognized selector sent to class 导入第三方SDK .a后不识别,运行崩溃

    今天将app统计的.a静态库包含到一个app应用中,调试时报下面的错误: *** Terminating app due to uncaught exception 'NSInvalidArgumen ...

  7. 【转载】IIS一个网站如何绑定多个主机域名

    在IIS Web服务器的网站配置的过程中,有时候需要一个网站配置对应多个域名记录,例如不带www的主域名以及带www的域名解析记录对应同一个网站文件,此时最简单的配置方法就是将一个网站绑定多个主机域名 ...

  8. vue实现一个评论列表

    <!DOCTYPE html> <html> <head> <title>简易评论列表</title> <meta charset=& ...

  9. (三)react-native开发系列之开发环境集成

    先上图,由于是虚拟机中的ios虚拟器,所以有点卡 关于react-native的开发集成,主要包括以下几个方面 1.路由及页面跳转 2.数据请求的封装 3.状态的管理 4.公共方法和全局变量的封装 5 ...

  10. 无法写入配置文件...需要在IIS中手动创建此虚拟目录,才可以打开此项目

    无妄之灾   之前闲着没事写了一个webapi项目,今天下了班闲来无事就像拿出来改改,没想到打开的时候就提示出现错误. 没错就是这货,其实也不是第一次遇见这个问题了,但是之前一直没有找到解决方案,在网 ...