收藏 分享(赏)

VTK培训的教程.doc

上传人:精品资料 文档编号:9530360 上传时间:2019-08-13 格式:DOC 页数:77 大小:1,008KB
下载 相关 举报
VTK培训的教程.doc_第1页
第1页 / 共77页
VTK培训的教程.doc_第2页
第2页 / 共77页
VTK培训的教程.doc_第3页
第3页 / 共77页
VTK培训的教程.doc_第4页
第4页 / 共77页
VTK培训的教程.doc_第5页
第5页 / 共77页
点击查看更多>>
资源描述

1、VTK 编程简介(转载) .3VTK 数据类型 .7VTK 教程之一 可视化管线 9VTK 教程之二 可视化管线的执行 .12VTK 教程之三 数据集 14VTK 教程之四 单元和点集 16VTK 教程之五 数据集的类型和数据集的属性数据 21VTK 教程之六 构建数据集的例子程序 25VTK 教程之七 可视化基础算法 -概述 27VTK 教程之八 可视化基础算法 -颜色映射 .28VTK 教程之九 可视化基础算法 -二维轮廓线(等值线)提取 32VTK 教程之十 可视化基础算法 -三维轮廓面(等值面)提取 .39VTK 教程之十一 可视化基础算法 -方向线 .42VTK 教程之十二 可视化基

2、础算法 -几何体变形 .45VTK 教程之十三 可视化基础算法 -位移图 .48VTK 教程之十四 可视化基础算法 -用隐函数构建几何体 .52VTK 培训教程之十五 可视化基础算法 -用隐函数提取数据集中的数据 .61VTK 培训教程之十六 可视化基础算法 -用隐函数可视化随机或离散运动的物体 .64VTK(Visualization Toolkit)安装和配置没有找到 vc6.0 或 vc8.0 下的安装版,若是用 vc7.0 话有现成的安装版本,只能自己动手编译了一下 安装版的配置环境(VC6,Windows) 1. 必须要下载的东西,VC6 已经装好为前提:vtk-5.0.4-win3

3、2.exe 安装程序 http:/vtk.org 的 Downloadvtk-5.0.4.zip 源程序vtkdata-5.0.4.zip 数据 2. 安装 vtk-5.0.4-win32.exe 在 D:Program FilesVTK 5.0, 解压 vtk-5.0.4.zip 到 D:Program FilesVTK 5.0vtk-5.0.4, vtkdata-5.0.4.zip 到 D:Program FilesVTK 5.0vtkdata-5.0.4 3. 用 cmake 编译到 D:Program FilesVTK 5.0bin 下,(这一步花了我不少时间,每次cmake 编译到一

4、定量就死掉,不知道什么原因,编译了不下 10 次终于成功) 4. 参数设置,几个关键参数要注意; vtk_use_guisupport,打开它,才能选 vtk_use_mfc,再 configure; vtk_data_root: 目的是告诉 cmake,vtk 需要的数据都在哪里,我们的数据在 D:Program FilesVTK 5.0vtkdata-5.0.4 build_examples: 就是询问是否编译 vtk 中的例子,我第一次的时候选上了,结果编译了 2个小时的例子还没编译完,所以我后来选了 off。 build_shared_libs: 如果设置为 off,就只会生成 lib

5、 文件,用于开发肯定是够了。如果设置为 on,将会多生成 dll 文件,这些 dll 需要拷到 windows/system 目录下。 。建议选 On, 5. cmake 中选 ok,在 bin 文件下,编译 dsw 文件就行,我大概花 6 分钟。 6. 测试:这时新建一个 project, win32 console application, an empty project, 生成后给source files 加一个 test.cpp,把下面的代码放进去。 #include “vtkConeSource.h“ #include “vtkPolyDataMapper.h“ #include

6、“vtkRenderWindow.h“ #include “vtkCamera.h“ #include “vtkActor.h“ #include “vtkRenderer.h“ #include “vtkProperty.h“ int main() vtkConeSource *cone = vtkConeSource:New(); cone-SetHeight( 3.0 ); cone-SetRadius( 1.0 ); cone-SetResolution( 10 ); vtkPolyDataMapper *coneMapper = vtkPolyDataMapper:New(); co

7、neMapper-SetInputConnection( cone-GetOutputPort() ); vtkActor *coneActor = vtkActor:New(); coneActor-SetMapper( coneMapper ); vtkRenderer *ren1= vtkRenderer:New(); ren1-AddActor( coneActor ); ren1-SetBackground( 0.1, 0.2, 0.4 ); vtkRenderWindow *renWin = vtkRenderWindow:New(); renWin-AddRenderer( re

8、n1 ); renWin-SetSize( 300, 300 ); int i; for (i = 0; i Render(); ren1-GetActiveCamera()-Azimuth( i ); cone-Delete(); coneMapper-Delete(); coneActor-Delete(); ren1-Delete(); renWin-Delete(); return 0; 环境路径设置,这个比较重要: 1).修改 Project setting-C/C+ -Category-Preprocessor-Additional include directories: D:P

9、rogram FilesVTK 5.0vtk-5.0.4Graphics,D:Program FilesVTK 5.0vtk-5.0.4Filtering,D:Program FilesVTK 5.0vtk-5.0.4Common,D:Program FilesVTK 5.0bin,D:Program FilesVTK 5.0vtk-5.0.4Rendering 2). 修改 Project setting-Link-Input-Object/library modules: opengl32.lib kernel32.lib user32.lib gdi32.lib winspool.lib

10、 comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib vtkCommon.lib vtkDICOMParser.lib vtkexoIIc.lib vtkexpat.lib vtkFiltering.lib vtkfreetype.lib vtkftgl.lib vtkGenericFiltering.lib vtkGraphics.lib vtkHybrid.lib vtkImaging.lib vtkIO.lib vtkjpeg.lib vtkNetCDF.lib vtkpng.l

11、ib vtkRendering.lib vtksys.lib vtktiff.lib vtkVolumeRendering.lib vtkWidgets.lib vtkzlib.lib 3) Project setting Link - Category: Input - Additional library path: D:Program FilesVTK 5.0binbinDebugVTK 编程简介(转载)0 如何利用文档 VTK 是由 Will Schroeder 等创立的 Kitware Inc. 的开放源码产品。Kitware 提供关于 VTK 的技术支持和各种服务产品,包括教科书和

12、用户指南:The Visualization Toolkit An Object-Oriented Approach To 3D Graphics, 3rd edition 和 The Visualization Toolkit Users Guide 。两本书的内容各有侧重,教科书主要介绍可视化的各种算法以及 VTK 中的数据结构,而用户指南强调软件的使用方法。可以根据使用过程中遇到的不同问题参考两本书中的相应章节。编程中对具体的类、函数等的使用可以参考电子版的手册。编程中遇到的问题,可以在 VTK 的 maillist 上提出,一般都会有解答。 1 编译 VTK 库 1.1 准备源代码 从

13、 http:/www.vtk.org/ 下载源代码。源代码按成熟度依次分为官方发行版、每日打包版和 CVS 开发版,其中官方发行版最稳定,CVS 开发版最新。一般应用使用官方发行版即可。 1.2 用 CMake 产生具体平台下的工程文件 VTK 是用 C+ 语言开发的平台无关的图形库。为了使相互关联的 VTK 库代码能在不同平台(如 Windows 和 Unix)和不同编译器(如 Visual Studio 6.0 和 Borland)下方便使用,Kitware 开发了 CMake 这一转换工具。比如使用 CMake,可以为 Windows 平台下的 Visual Studio 6.0 产生相

14、应的工程文件(.dsp 或 .dsw 文件) ,此后就可以在 Visual Studio 的集成开发环境(IDE)下进行编译连接了。 CMake 提供一个用户界面,用户可以定制某些变量,其中比较重要的是 BUILD_SHARED_LIBS,根据它的选择可以生成 VTK 的静态库或者动态链接库。如果编译成静态库,那么在开发应用程序时要将相应库代码加入可执行程序;如果是动态库,则可执行程序与动态链接库是分离的。用动态库的好处是可以减小主程序的体积,缺点是可执行程序不能独立运行。不过在有些情况下,因为某些专利算法在商业用途里只能授权使用,所以 VTK 提供的部分代码只能以动态链接库的方式使用,所以应

15、该熟悉编译动态链接库的方法。其他较常见的重要变量有 VTK_USE_PATENTED 、VTK_USE_HYBRID 等,编译时使它们打开开关,就可以编译出相应的库以便日后使用了。 图 1 1.3 编译库 以下以 Windows 平台下的 Visual Studio 6.0 编译环境为例来说明使用方法,不再声明。 打开用 CMake 产生的 .dsw 文件,选择工程类型进行编译。工程类型主要分两类:Release 和 Debug ,开发过程中一般用 Debug ,到发行时再用 Release ,所以在此用 Debug 即可。编译整个工程产生全部库,这个过程所需时间很长。编译完成后,会在 CMa

16、ke 里面指定的目标目录内(如 vtkbin )产生编译出的库文件(缺省在 vtkbin/bin/Debug 目录内) 。 2 在 Visual Studio 6.0 开发环境下使用 VTK 库 VTK 库编译好了以后,就可以在 Visual Studio 开发环境下使用 VTK 库了。使用 VTK 库首先要设置头文件和库文件的路径,以便使用 VTK 库的程序在编译和链接的时候可以搜索到。头文件的位置即源代码的各个子目录,里面包含了大量的 .h 文件。将其路径加入到 Visual Studio 6.0 的 Tools - Options - Directories 内,如图 2。注意除了源码的

17、各个子目录外,还要加上一个 vtkConfigure.h 文件的路径,它在 CMake 产生的目标目录内。库文件的设置与此类似,也在 Directories 页面进行,其路径是前述编译产生库文件的目录(如 vtkbin/bin/Debug ) 。这样设置好路径以后,使用 VTK 库的程序就可以正确地编译和链接了。对于使用动态链接库的程序来说,此时还不能运行编译出来的可执行程序( .exe) ,还需要一步,即把 VTK 的动态链接库文件所在路径加入操作系统的环境变量 PATH ,或直接将这些库文件拷贝到系统目录。 图 2 3 VTK 库编程特点 VTK 库是用面向对象的 C+ 语言写成的,由于主

18、要开发者有着十数年涉及可视化系统的经验,所以 VTK 拥有非常合理的模型和结构。 VTK 的编程风格在教科书的附录 A,包括命名规范、术语定义、各类对象的用途说明等。值得注意的,比如它的对象工厂(Object Factory)概念。在 VTK 里,是用 :New() 的方式来初始化对象的,而不是用 C+ 中的 new 来新建对象,对象工厂不仅可以做到代码与设备无关,而且通过引用计数(reference counting) ,可以使程序清晰简明,不容易发生内存泄漏或崩溃的问题。 VTK 中实现了数百个类及其方法,它们之间简化的继承和关联关系可以从教科书附录 A.3 的图中看到。熟悉不同的类的用途

19、和它们之间的关系,对编程十分有利。 对开发者来说,如何扩充这个类库是重要的,教科书的附录 A.4 介绍了这个问题,而用户指南的开发者指南部分有一章来讲具体的做法。 4 通过例子学习 VTK 概念及编程 要用 VTK 库进行可视化编程首先要对可视化要有一定的概念和基础。除了普通的可视化教科书以外,VTK 提供的教科书本身就非常好。 VTK 源程序包的 Example 目录包括了一系列例子,它们都有详尽的注释。一步步学习这些例子,可以很容易理解 VTK 涉及的可视化概念和 VTK 编程的一般特点。 学习这些例子首先要成功编译运行它们。这个步骤跟编译库类似,也需要先用 CMake 工具生成 Visu

20、al Studio 的工程文件,然后编译;而要保证程序能正确运行,还得保证 VTK 库文件在环境变量的 PATH 内。 初学者应该从 Tutorial 目录内的 Step x 例子入手,它们从最简单的 VTK 程序开始,一步步地增加概念,演示了各种可视化概念。注意例子里的注释,以第一个程序(Step1 的 Cone 程序)为例,看一下源程序: 源程序:Example/Tutorial/Step1/Cxx/Cone.cxx / / This example creates a polygonal model of a cone, and then renders it to / the scre

21、en. It will rotate the cone 360 degrees and then exit. The basic / setup of source - mapper - actor - renderer - renderwindow is / typical of most VTK programs. / / First include the required header files for the VTK classes we are using. #include “vtkConeSource.h“ #include “vtkPolyDataMapper.h“ #in

22、clude “vtkRenderWindow.h“ #include “vtkCamera.h“ #include “vtkActor.h“ int main( int argc, char *argv ) / / Next we create an instance of vtkConeSource and set some of its / properties. The instance of vtkConeSource “cone“ is part of a / visualization pipeline (it is a source process object); it pro

23、duces data / (output type is vtkPolyData) which other filters may process. / vtkConeSource *cone = vtkConeSource:New(); cone-SetHeight( 3.0 ); cone-SetRadius( 1.0 ); cone-SetResolution( 10 ); / / In this example we terminate the pipeline with a mapper process object. / (Intermediate filters such as

24、vtkShrinkPolyData could be inserted in / between the source and the mapper.) We create an instance of / vtkPolyDataMapper to map the polygonal data into graphics primitives. We / connect the output of the cone souece to the input of this mapper. / vtkPolyDataMapper *coneMapper = vtkPolyDataMapper:Ne

25、w(); coneMapper-SetInput( cone-GetOutput() ); 程序段 1 这个简单的例子是一个控制台下的程序,创建一个棱锥,在屏幕上绘制,旋转 360 度后退出。程序虽简单,但已经包括了数据源、映射器、演员、绘制器、绘制窗口等概念,这些概念在 VTK 编程中几乎都是必然涉及的。通过这个例子,就可以对教科书里讲到的各种可视化概念(如相机、演员) ,编程模型(如管道)等有直观的了解了。 这里仅举这个最简单的例子,事实上,VTK 自带的例子循序渐进,从简单的概念,到各种复杂的概念、算法和数据结构、GUI 编程、直到具体的应用等,都做了很好的例证。结合教科书和例子,可以较

26、快地理解 VTK 的各个方面。 比如说,如果要用 VTK 在 Win32 环境下编程,应该学习 Example/GUI/Win32 下的例程,如果要用 MFC 框架,那么可以参考其中的 vtkMFC 例程。体会 VTK 库和 Win32 的关系、和 MFC 框架的关系,以便在这些平台上开发自己的程序。这需要对 VTK 和操作系统、编程环境本身有比较深入的了解,而这种了解对自行开发程序是十分必要的。 5 用 VTK 进行 CT 片三维重构 VTK 作为一种通用的可视化类库,在科学和工程界有着广泛的应用。其中一种重要而常见的应用就是在医学领域,比如著名的“可视化人 ”项目,就有 VTK 的应用。实

27、际上,VTK 在医学方面的应用是是 VTK 比较强调的,在它提供的例程应用中,就有专门的医学目录。学习它们,并应用于我们的项目中,是一条合适的途径。 比如,如果要做一个 3D 的医学影像系统,其中重要的一个环节就是三维重构,这也是在全膝置换手术中需要的。所以,用 VTK 进行 CT 片的三维重构,就是一个合适的应用的例子。 利用 VTK 做 CT 片的三维重构,从算法和数据结构来看,就是一个读取数据问题和一个图形显示问题。 对于我们手里的 CT 片,因为它们符合 DICOM 3.0 标准,所以对它们的读取还是相对容易的。VTK 已经实现了这类数据的读取, vtkImageSource 类的很多

28、子类都可以完成这种工作,如vtkImageReader 类或者 vtkVolumeReader 等。这样我们编程的时候只要指定必须的参数,就可以实现对单张 CT 片乃至 CT 片序列的读取了。根据 VTK 的数据管道,原始数据读取入了以后,就可以使用各种各种过滤器进行数据转换,在这个例子里,即进行表面抽取、影射,然后就可以绘制了。因为是三维重建,所以还应该加入交互器,以便可以在绘制窗口里进行交互。 关于重建算法,对于 CT 片这种三维规则数据场,可以采取成熟、基本的算法来进行三维重建,比如 MarchingCubes 算法。 我们使用 Visual Studio 6.0 开发平台来完成上述的工

29、作,使对 CT 片的读取、重建及显示、交互等功能融合到 MFC 的框架中,以便提供一个方便的用户接口。具体的程序另件给出,各部分的功能可以参考注释。 参考文献 1.The Visualization Toolkit An Object-Oriented Approach To 3D Graphics, 3rd edition 2.The Visualization Toolkit Users Guide 3.VTK 源码: http:/www.vtk.org/get-software.php 4.VTK 电子文档:http:/www.vtk.org/get-software.php 5.VTK

30、 邮件列表:http:/ 6.http:/ VTK 数据类型分为两种:vtk 是基于 C+的库,自然是面向对象的库了 对象类型有两种 图形模型对象(the Graphics Models) 可视化模型对象(the Visualization Models) 整个图形模型主要分为九类对象: (1)渲染控制器: 定义与设备无关的坐标计算方法, 创建绘制窗口; (2)渲染窗口(RenderWindow):其基类为 vtkRenderWindow, 管理显示设备上的窗口, 一个或多个绘制方 法可在渲染窗口上创建一个场景。渲染窗口是用户图形界面 , 其中包括 了设置渲染窗口的大小, 产生立体显示效果等的

31、方法, 一共控制控制两个缓存; (3)渲染器(Renderer):基类为 vtkRenderer,作用是管理光源、照相机和绘制对象等的位置、属性等; 提供 世界坐标系 , 观察坐标系及显示坐标系之间的转换。建立好一个 Renderer 后将其加入RenderWindow 中即可将场景显示出来; (4)灯光( Light):VTK 中的实现类为 vtkLight, (5)照相机(Camera): VTK 实现类为 vtkCamera, (6)角色(Actor):vtkActor 代表渲染场景中的绘制对象实体,通过参数的调节可以设置角色的位置方向 , 渲染 特性 (Property),引用(ren

32、ference),纹理影射(Texture)等属性,并可对 Actor 进行放缩。角色 的改变是通过一个 4*4 的变换矩阵实现的; (7)属性(Property): 实现类为 vtkProperty。要使三维物体具有真实感, 必须说明几何物体的一些特性,例如 光照特性(泛光 ,漫反射,镜面反射 ,边缘颜色),反射强度,物体的灰度 ,物体的绘制样式(点, 线框, 表面) ,着色模式( flat, Gouraud, Phong)等; VTK 中正是通过属性模型来对其进行说明的; (8)映射(Mapper):vtkMapper 指定了渲染数据和图形库中基本图元之间的联系。VtkMapper 的一些

33、派生 类通过 LookupTable 映射数据并控制图形库中相应 Actor 图元的生成。一个或多个 Act or可以使用相同的 Mapper。Mapper 有多个参数对其进行控制, 如 ScalarVisibility 标志 可以设置 scalar 的数据是否影响相关的 Actor 的颜色 ; ScalarMode 可以控制 Actor 的颜 色是 scalar point 还是 cell 的值; 渲染方式可以通过 ( ImmediateModeRenderingOn)和( ImmediateModeRenderingOff) 控制, 前一项表示立即渲染, 后一 项表示将渲染放于渲染列表中,

34、 一般选择 ImmediateModeRenderingOn 方式进行, 选择后者将会占用较多的系统资源, 影响系统的性能; (9)变换(Transform):vtkTransform 是一个放置 4*4 变换矩阵的堆栈 , 可对这一堆栈进行各种操作, 如:平移, 缩放 , 旋转等 , 一般在栈的顶部进行。实现过程主要由渲染控制器创建渲染窗口,由渲染器在渲染窗口上绘制场景。场景包括绘制对象、映射、属性、变换、光 源、照相机等。VTK 获取数据的方式是基于拉技术, 即在管道的下一对象请 求数据时, 管道对象才进行数据集的相关处理, 因此可减小系统的运算负荷, 这对提 高系统实时性大有好处。 可视

35、化模型(theVisualization Models) 用 VTK 进行可视化应用是非常方便的,它包括两个基本部分。首先,建立适当的目标图形来演示数据;其次, 建立一个数据流水线(data pipeline)来处理数据, 建立流水线(pipeline)就是将 Source、Filters 和Mappers 连接起来。VTK 的可视化模型主要包括两类对象: (1)数据对象 (a)多边形数据(vtkPloyData):表示由顶点、直线、多边形即三角面片组成的几何体, 支持多种的原子类 型, 如 vtkVertex,vtk-PloyVertex, vtkLine 等。 (b)结构点数据(vtkSt

36、ructurePoint): 是一包括表面形状及几何形状的几何体。 (c)非结构点数据(vtkUnStructurePoint):指定了几何体的外观;结构网格( vtkStructureGrid):指定了几何 体的结构。 (d)非结构网格(vtkUnStructureGrid):可以为任意的 cell 类型的组合。 (e)数据对象继承关系。 (2)过程对象 VTK 中定义的过程对象根据其 pipeline 主要包括了数据源(Source),过滤器(Filters),映射(Mappers),数据流水线(data pipeline),过程如图所示: 下载 (9 KB)2007-12-24 11:5

37、0数据源(Source): vtkSource 是所有数据源的基类, 其子类定义了许多数据源类型; 过滤器(Filters):vtkFilter 是各种 Filter 的基类, 从 vtkSource 中派生出来, 接收 Source 中的数据, 进行种 不同的 Filter 处理工作。Filters 为 VTK 的主要部件, 由其基类派生出了许多子类, 实现了 图形学算法。将其封装起来, 用户只需要编写简单程序接口调用就可, 并可以通过改变 参数来达到想要的效果; 映射(Mappers) : vtkMapper 是所有 Mappers 的基类, 从 Filtes 接受数据,并把其映射为图形库

38、中的基本图 元。根据映射方式的不同, 有多个继承子类。VTK 教程之一 可视化管线VTK 是一个基于面向对象的开源三维绘图软件包,和其它的的三维绘图引擎如 OSG、OGRE 不同之处在于,VTK 可视化对象主要是各种数据,更加注重对数据分析处理后的可视化,可视化的内容是人们无法直接感受到的东西,如地质构造、地层分布、矿床分布、三维空间应力场的状态变化等等,而OSG、OGRE 是基于场景的可视化,更强调视觉感官的感受,所以 OSG 主要应用于虚拟现实领域,而VTK 主要应用于科学计算可视化领域,本教程主要介绍 VTK 的可视化应用。VTK 的可视化设计是基于管线流的设计模式,将要处理的数据作为流

39、动介质在管线中流动,不同的阶段对数据有不同的处理方式,VTK 的可视化管线主要由图形模型和可视化模型组成,如下图所示:可视化模型主要对数据进行处理,生成可被绘制的几何体,而图形模型主要对生成的几何体进行绘制,在 VTK 的可视化管线中所包含的对象一般包括:源对象、过滤器对象(可选)、映射器对象、Props 对象、绘制器对象、绘制窗口,其中 源对象、过滤器对象(可选)、映射器对象 、绘制器对象、绘制窗口为处理对象, Props 对象为数据对象,映射器对象是可视化模型和图形模型的接口。有了可视化管线,VTK 的可视化过程就可以用数据在可视化管线流动的过程来描述(数据在管线中流动过程中,被管线不同的

40、对象处理,最终以图形的方式表现数据信息),VTK 的可视化管线具有如下特点:1、变换数据从原始的形式变换成图元的形式,最终以图形的形式显示。2、表现用 VTK 内部定义的数据结构描述数据,形成数据集,用图形的方式表现数据。3、是基于面向对象的用面向对象的观点描述可视化管线,表现是数据对象,变换是处理对象。下面我们对 VTK 可视化管线的各个对象分别介绍,在可视化管线中,按对数据处理方式的不同,分为数据对象和处理对象,其中数据对象主要作用是表现数据信息,并对表现的信息进行维护(创建、访问、删除),处理对象主要是对输入的数据进行处理后生成输出新的数据,处理对象主要包括:1、源对象数据生成的源头,数

41、据来源主要包括从磁盘读取数据文件,如 VTK 所支持的各种格式文件生成数据源对象,这种源对象被称为读源对象,或者利用数学方法生成源对象,如利用多个四边形构建一个圆柱体,这种对象被称为程序源对象。2、过滤器对象对源对象进行处理,生成新的数据集输出。3、映射器对象映射器对象主要作用是将可视化模型生成的数据转换到图形模型进行绘制,或者以磁盘文件的形式进行输出。以上对 VTK 可视化管线做了一个简单的介绍,下面通过一个示例程序来说明数据是如何在可视化管线中流动的。#include “stdafx.h“#include “vtkCamera.h“#include “vtkGenericRenderWin

42、dowInteractor.h“#include “vtkInteractorStyleJoystickCamera.h“#include “vtkInteractorStyleTrackballCamera.h“#include “vtkLODActor.h“#include “vtkLight.h“#include “vtkPolyData.h“#include “vtkPolyDataMapper.h“#include “vtkPropPicker.h“#include “vtkProperty.h“#include “vtkRenderWindow.h“#include “vtkRen

43、derer.h“#include “vtkSTLReader.h“#include “vtkShrinkPolyData.h“int main( int argc, char *argv ) /创建绘制器对象vtkRenderer *ren1 = vtkRenderer:New();/设置相机ren1-GetActiveCamera()-SetClippingRange(0.294421 , 29.4421);ren1-GetActiveCamera()-SetDistance(7.94348);ren1-GetActiveCamera()-SetFocalPoint(-66.9367 , -

44、49.4539 , 258.453);ren1-GetActiveCamera()-SetPosition(-67.8091 , -57.3489 , 258.377);ren1-GetActiveCamera()-SetViewAngle(20);ren1-GetActiveCamera()-SetViewUp(-0.82718 , 0.0860684 , 0.555306);ren1-GetActiveCamera()-SetParallelProjection(0);ren1-GetActiveCamera()-SetUseHorizontalViewAngle(0);ren1-SetB

45、ackground(0.1 , 0.2 , 0.4);ren1-SetLightFollowCamera(1);/创建绘制窗口vtkRenderWindow *renWin = vtkRenderWindow:New();renWin-AddRenderer(ren1);renWin-SetSize(1134 , 624);/创建交互器vtkRenderWindowInteractor *iren = vtkRenderWindowInteractor:New();iren-SetRenderWindow(renWin);iren-SetLightFollowCamera(1);/读源对象读取

46、 stl 数据文件vtkSTLReader *part = vtkSTLReader:New();part-SetOutput(part-GetOutput();part-SetFileName(“42400-IDGH.stl“);/创建过滤器对象,该对象将输入数据集的每个单元向单元质心收缩/将会导致相邻单元之间出现裂缝vtkShrinkPolyData *shrink = vtkShrinkPolyData:New();/将源对象和过滤器连接shrink-SetInput(vtkPolyData *) part-GetOutput();/设置收缩系数,如果为 1,不收缩shrink-SetS

47、hrinkFactor(0.9);/创建映射器对象vtkPolyDataMapper *partMapper = vtkPolyDataMapper:New();partMapper-SetInput(vtkPolyData *) shrink-GetOutput();partMapper-SetNumberOfPieces(1);partMapper-SetScalarRange(0 , 1);partMapper-SetColorMode(0);partMapper-SetResolveCoincidentTopology(0);partMapper-SetScalarMode(0);pa

48、rtMapper-SetImmediateModeRendering(0);partMapper-SetScalarVisibility(1);partMapper-SetUseLookupTableScalarRange(0);/创建 Props 对象(Actor)vtkLODActor *partActor = vtkLODActor:New();partActor-SetMapper(partMapper);partActor-GetProperty()-SetAmbientColor(0.8275 , 0.8275 , 0.8275);partActor-GetProperty()-S

49、etColor(0.8275 , 0.8275 , 0.8275);partActor-GetProperty()-SetDiffuseColor(0.8275 , 0.8275 , 0.8275);partActor-GetProperty()-SetOpacity(1);partActor-GetProperty()-SetInterpolation(1);partActor-GetProperty()-SetRepresentation(2);partActor-GetProperty()-SetBackfaceCulling(0);partActor-GetProperty()-SetEdgeVisibility(0);partActor-GetProperty()-SetFrontfaceCulling(0);partAc

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报