一杯清酒邀明月
天下本无事,庸人扰之而烦耳。
posts - 3121,comments - 209,views - 578万

复制代码
 1 #include <vtkAutoInit.h>
 2 VTK_MODULE_INIT(vtkRenderingOpenGL2);
 3 VTK_MODULE_INIT(vtkRenderingVolumeOpenGL2); //错误:no override found for 'vtkRayCastImageDisplayHelper'.
 4 VTK_MODULE_INIT(vtkRenderingFreeType);
 5 VTK_MODULE_INIT(vtkInteractionStyle);
 6 
 7 #include <vtkSmartPointer.h>
 8 #include <vtkImageData.h>
 9 #include <vtkStructuredPoints.h>
10 #include <vtkStructuredPointsReader.h>
11 #include <vtkFixedPointVolumeRayCastMIPHelper.h>
12 #include <vtkFixedPointVolumeRayCastMapper.h>
13 #include <vtkColorTransferFunction.h>
14 #include <vtkPiecewiseFunction.h>
15 #include <vtkRenderer.h>
16 #include <vtkRenderWindow.h>
17 #include <vtkRenderWindowInteractor.h>
18 #include <vtkVolumeProperty.h>
19 #include <vtkAxesActor.h>
20 #include <vtkImageShiftScale.h>
21 #include <vtkImageCast.h>
22 
23 //测试:../data/mummy.128.vtk
24 int main(int argc, char *argv[])
25 {
26     vtkSmartPointer<vtkStructuredPointsReader> reader =
27         vtkSmartPointer<vtkStructuredPointsReader>::New();
28 
29     reader->SetFileName("C:\\Users\\Administrator\\Desktop\\VTK2\\hellovtk\\vtk_图像处理学习\\第七章_VTK体绘制\\data\\mummy.128.vtk");
30     reader->Update();
31 
32     vtkSmartPointer<vtkFixedPointVolumeRayCastMIPHelper> rayCastFun =
33         vtkSmartPointer<vtkFixedPointVolumeRayCastMIPHelper>::New();
34 
35     vtkSmartPointer<vtkFixedPointVolumeRayCastMapper> volumeMapper =
36         vtkSmartPointer<vtkFixedPointVolumeRayCastMapper>::New();
37     volumeMapper->SetInputData(reader->GetOutput());
38     //volumeMapper->Set
39         //SetVolumeRayCastMapperFunction(rayCastFun);//必须设置,否则出错
40 
41     vtkSmartPointer<vtkVolumeProperty> volumeProperty = 
42         vtkSmartPointer<vtkVolumeProperty>::New();
43     volumeProperty->SetInterpolationTypeToLinear();
44     volumeProperty->ShadeOn();
45     volumeProperty->SetAmbient(0.4);
46     volumeProperty->SetDiffuse(0.6);
47     volumeProperty->SetSpecular(0.2);
48 
49     vtkSmartPointer<vtkPiecewiseFunction> compositeOpacity = 
50         vtkSmartPointer<vtkPiecewiseFunction>::New();
51     compositeOpacity->AddPoint(70,   0.00);
52     compositeOpacity->AddPoint(90,   0.40);
53     compositeOpacity->AddPoint(180,  0.60);
54     volumeProperty->SetScalarOpacity(compositeOpacity);
55 
56     vtkSmartPointer<vtkColorTransferFunction> color = 
57         vtkSmartPointer<vtkColorTransferFunction>::New();
58     color->AddRGBPoint(0.000,  0.00, 0.00, 0.00);
59     color->AddRGBPoint(64.00,  1.00, 0.52, 0.30);
60     color->AddRGBPoint(190.0,  1.00, 1.00, 1.00);
61     color->AddRGBPoint(220.0,  0.20, 0.20, 0.20);
62     volumeProperty->SetColor(color);
63 
64     vtkSmartPointer<vtkVolume> volume = 
65         vtkSmartPointer<vtkVolume>::New();
66     volume->SetMapper(volumeMapper);
67     volume->SetProperty(volumeProperty);
68 
69     vtkSmartPointer<vtkRenderer> ren = vtkSmartPointer<vtkRenderer>::New();
70     ren->SetBackground(1.0, 1.0, 1.0);
71     ren->AddVolume( volume ); 
72 
73     vtkSmartPointer<vtkRenderWindow> renWin = vtkSmartPointer<vtkRenderWindow>::New();
74     renWin->AddRenderer(ren);
75     renWin->SetSize(640, 480);
76     renWin->Render();
77     renWin->SetWindowName("MIPVolRenderingApp");
78 
79     vtkSmartPointer<vtkRenderWindowInteractor> iren = 
80         vtkSmartPointer<vtkRenderWindowInteractor>::New();
81     iren->SetRenderWindow(renWin);
82     ren->ResetCamera();
83 
84     renWin->Render();
85     iren->Start();
86 
87     return EXIT_SUCCESS;
88 }
复制代码

posted on   一杯清酒邀明月  阅读(165)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)
历史上的今天:
2022-08-16 Qt 无法解析的外部符号“public: virtual struct QMetaObject const ...“
2022-08-16 Qt char*,wchar_t*与QString之间的转换(利用reinterpret_cast和_stprintf函数,fromWCharArray从字符数组里读取数据)
2021-08-16 C++ 实现 COM → IUnknown → 接口
2021-08-16 C++ COM编程之IUnknown接口
2021-08-16 C++ COM三大接口:IUnknown、IClassFactory、IDispatch。
2021-08-16 C++ COM组件QueryInterface函数
2021-08-16 C++ COM组件的AddRef和Release()方法使用
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示