不知道什么原因,国内有关VTK,体绘制的博客少之又少,大部分内容也多互相借鉴,有价值的信息少之又少,大部分代码也存在着各种各样的问题
也可能因为我才疏学浅,配置上有一定的问题,但是99%的代码都不能成功运行,十分不利于初学者学习,因此想到在成功以后将自己的代码Po上,
方便大家学习交流
关键词:VTK7.0 CMAKE 体绘制 VolumeRender 高斯滤波 各向异性扩散滤波 .RAW文件读取 VolumeMapper
代码:
#include <vtkSmartPointer.h>
#include <vtkSmartVolumeMapper.h>
#include <vtkColorTransferFunction.h>
#include <vtkPiecewiseFunction.h>
#include <vtkRenderer.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkVolumeProperty.h>
#include <vtkCamera.h>
#include <vtkImageData.h>
#include <vtkImageReader.h>
#include <vtkVolumeRayCastMapper.h>
#include <vtkImageGaussianSmooth.h>
#include <vtkImageAnisotropicDiffusion2D.h>
static void CreateImageData(vtkImageData* im);
int main(int argc, char *argv[])
{
vtkSmartPointer<vtkImageData> imageData =
vtkSmartPointer<vtkImageData>::New();
CreateImageData(imageData);
//*********************************************************调用函数 创建图像
vtkSmartPointer<vtkRenderWindow> renWin =
vtkSmartPointer<vtkRenderWindow>::New();
vtkSmartPointer<vtkRenderer> ren1 = vtkSmartPointer<vtkRenderer>::New();
ren1->SetBackground(0.1,0.4,0.2);
renWin->AddRenderer(ren1);
renWin->SetSize(500,500);
vtkSmartPointer<vtkRenderWindowInteractor> iren =
vtkSmartPointer<vtkRenderWindowInteractor>::New();
<