VTK 模型的颜色映射

摘要:
对于其他类型的标量数据,将通过查询表映射。
1 #include <vtkActor.h>
2 #include <vtkFloatArray.h>
3 #include <vtkLookupTable.h>
4 #include <vtkPointData.h>
5 #include <vtkPolyData.h>
6 #include <vtkPolyDataMapper.h>
7 #include <vtkRenderer.h>
8 #include <vtkRenderWindow.h>
9 #include <vtkRenderWindowInteractor.h>
10 #include <vtkSmartPointer.h>
11 #include <vtkSTLReader.h>
12 #include <vtkInteractorStyleTrackballCamera.h>
13  
14 #include <vtkAutoInit.h> 
15 VTK_MODULE_INIT(vtkRenderingOpenGL2);
16 VTK_MODULE_INIT(vtkInteractionStyle);
17 VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2);
18 VTK_MODULE_INIT(vtkRenderingFreeType);
19  
20 int main(int, char*[])
21 {
22     //加载一个J20的STL模型
23     vtkSmartPointer<vtkSTLReader> source = vtkSmartPointer<vtkSTLReader>::New();
24     source->SetFileName("C:\Users\wangjun\3D Objects\J20.stl");
25     source->Update();
26  
27     int numPts = source->GetOutput()->GetPoints()->GetNumberOfPoints();                    //获取模型的顶点数量
28     vtkSmartPointer<vtkFloatArray> scalars = vtkSmartPointer<vtkFloatArray>::New();        //创建存储顶点属性的float数组
29     scalars->SetNumberOfValues(numPts);
30     for (int i = 0; i < numPts; ++i)        //为属性数组中的每个元素设置标量值(这个标量值可以当作颜色值)
31         scalars->SetValue(i, i);
32  
33     vtkSmartPointer<vtkPolyData> poly = vtkSmartPointer<vtkPolyData>::New();
34     poly->DeepCopy(source->GetOutput());
35     poly->GetPointData()->SetScalars(scalars);
36  
37     //创建颜色查找表
38     vtkSmartPointer<vtkLookupTable> hueLut = vtkSmartPointer<vtkLookupTable>::New();
39     hueLut->SetNumberOfColors(numPts);        //指定颜色查找表中有多少种颜色
40     hueLut->SetHueRange(0.67, 0.0);            //设定HSV颜色范围,色调H取值范围为0°~360°,从红色开始按逆时针方向计算,红色为0°/0.0,绿色为120°/0.34,蓝色为240°/0.67
41     hueLut->Build();
42  
43     vtkSmartPointer<vtkPolyDataMapper> mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
44     mapper->SetInputData(poly);
45     mapper->SetScalarRange(0, numPts);            //设置标量值的范围
46     mapper->ScalarVisibilityOn();
47     //mapper->SetColorModeToMapScalars();        //无论变量数据是何种类型,该方法都通过查询表对标量数据进行映射
48     mapper->SetColorModeToDefault();            //默认的映射器行为,即把unsigned char类型的标量属性数据当作颜色值,不执行隐式。对于其他类型的标量数据,将通过查询表映射。
49     mapper->SetLookupTable(hueLut);
50  
51     vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New();
52     actor->SetMapper(mapper);
53  
54     vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New();
55     renderer->GradientBackgroundOn();
56     renderer->SetBackground(1, 1, 1);
57     renderer->SetBackground2(0, 0, 0);
58  
59     vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New();
60     renderWindow->AddRenderer(renderer);
61  
62     vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New();
63     renderWindowInteractor->SetRenderWindow(renderWindow);
64     vtkSmartPointer<vtkInteractorStyleTrackballCamera> style = vtkSmartPointer<vtkInteractorStyleTrackballCamera>::New();
65     renderWindowInteractor->SetInteractorStyle(style);
66  
67     renderer->AddActor(actor);
68     renderWindow->SetSize(600, 600);
69     renderWindow->Render();
70     renderWindowInteractor->Start();
71  
72     return 0;
73 }

VTK 模型的颜色映射第1张

免责声明:文章转载自《VTK 模型的颜色映射》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇web app会遇到那些问题jsp里的逻辑语句c:if和c:choose下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

c/c++实现获取NOD32升级账号密码

功能有待完善和添加 #include <iostream> #include <ctime> #include <cstring> #include <string> #include <fstream> #include <sstream> #include <cstdlib...

maven filters 和 resource

1 filter 1.1 用途 对多个配置文件进行选择。 1.2 选择的依据 1.3 使用的方式 第一,在<resource>标签下面加<filtering>标签,并且<filtering>标签的值设置为true; 第二,添加<filters>标签,添加<filter>,并且值中使用env变量 第...

C/C++读取时间的方法

【摘要】本文介绍C/C++下获取日历时间的方法,区别于JAVA语言的方便,C/C++标准库好像并没有一次性得到具有可读性的HH:MM:SS的方法,本文介绍常用的三步法得出具有可读性的时间,并且介绍了纳秒和微秒的时间获取。 1、对于C语言,需包含的头文件: 1 #include <sys/time.h> 2、获取日期需要先获取日历时间,即1970...

笔记vscode下的c_cpp_properties.json文件配置,兼容visual studio

这篇笔记的目的就是配置好c/c++插件代码的智能提示,方便以后写嵌入式代码的时候能够快速配置好例子(来自官方文档) { "env": { "myDefaultIncludePath": ["${workspaceFolder}", "${workspaceFolder}/include"], "myCompilerPath": "/...

预编译头文件

一、预编译头文件使用经验: 如果预编译头文件被正确使用时,它确实大大提高我们编程的效率(你工作中,有多少时间是在等编译完成?很多吧,这个时候一般都很无聊,无奈,浪费时间)。但是他太容易用错了. 下面是几种常见的错误用法. 1) 在预编译头文件里include自己的头文件(当然, 如果你的头文件不经常变化, 也可以) 原因:自己的头文件一般会经常变, 便利后...

NX二次开发-获取面的法向向量UF_MODL_ask_face_data

1 NX9+VS2012 2 3 #include <uf.h> 4 #include <uf_modl.h> 5 #include <uf_obj.h> 6 #include <uf_ui.h> 7 8 9 UF_initialize()...