vtk用数组、迭代器访问元素
2016-05-05 10:59
288 查看
迭代器这货我写控制台的时候就没用明白过==
先说用数组直接访问的 实现的功能是将左下角的区域变黑
再说用迭代器的
先说用数组直接访问的 实现的功能是将左下角的区域变黑
#include <vtkSmartPointer.h> #include <vtkImageViewer2.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkRenderer.h> #include <vtkBMPReader.h> #include <vtkImageData.h> int main(int argc, char* argv[]) { vtkSmartPointer<vtkBMPReader> reader = vtkSmartPointer<vtkBMPReader>::New(); reader->SetFileName(",,/tmp.bmp"); reader->Update(); int dims[3]; reader->GetOutput()->GetDimensions(dims); int nbOfComp; nbOfComp = reader->GetOutput()->GetNumberOfScalarComponents(); for(int k=0; k<dims[2]; k++) { for(int j=0; j<dims[1]; j++) { for(int i=0; i<dims[0]; i++) { if(i<100 && j<100) { unsigned char * pixel = (unsigned char *) ( reader->GetOutput()->GetScalarPointer(i, j, k) ); *pixel = 0; *(pixel+1) = 0; *(pixel+2) = 0; } } } } vtkSmartPointer<vtkImageViewer2> imageViewer = vtkSmartPointer<vtkImageViewer2>::New(); imageViewer->SetInputConnection(reader->GetOutputPort()); vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New(); imageViewer->SetupInteractor(renderWindowInteractor); imageViewer->Render(); imageViewer->GetRenderer()->ResetCamera(); imageViewer->Render(); imageViewer->GetRenderer()->SetBackground(1.0, 1.0, 1.0); imageViewer->SetSize(640, 480); imageViewer->GetRenderWindow()->SetWindowName("VisitImagePixelDirectlyExample"); renderWindowInteractor->Start(); return EXIT_SUCCESS; }
再说用迭代器的
#include <vtkSmartPointer.h> #include <vtkImageViewer2.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkRenderer.h> #include <vtkBMPReader.h> #include <vtkImageData.h> #include <vtkImageIterator.h> //测试图像:../lena.bmp int main(int argc, char* argv[]) { //依旧是正常的读入 vtkSmartPointer<vtkBMPReader> reader = vtkSmartPointer<vtkBMPReader>::New(); reader->SetFileName("../lena.bmp"); reader->Update(); //设置变换的子区域 六个值分别代表x,y,z的最小值最大值 int subRegion[6] = { 0, 300, 0, 300, 0, 0 }; //两个参数:要访问的图像和访问区域 vtkImageIterator<unsigned char> it(reader->GetOutput(), subRegion); //注意这里两个while循环 while (!it.IsAtEnd()) { unsigned char *inSI = it.BeginSpan(); unsigned char *inSIEnd = it.EndSpan(); while (inSI != inSIEnd)//组内 { *inSI = 255 - *inSI; ++inSI; } it.NextSpan(); } vtkSmartPointer<vtkImageViewer2> imageViewer = vtkSmartPointer<vtkImageViewer2>::New(); imageViewer->SetInputConnection(reader->GetOutputPort()); vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New(); imageViewer->SetupInteractor(renderWindowInteractor); imageViewer->Render(); imageViewer->GetRenderer()->ResetCamera(); imageViewer->Render(); imageViewer->GetRenderer()->SetBackground(1.0, 1.0, 1.0); imageViewer->SetSize(640, 480); imageViewer->GetRenderWindow()->SetWindowName("VisitImagePixelIterativelyExample"); renderWindowInteractor->Start(); return EXIT_SUCCESS; }效果:
相关文章推荐
- Feature Scaling(归一化处理)
- 品高云SDN支持openflow标准与控制器HA的demo视频
- 机房收费系统前提工作
- jdbc连接mysql各种情况总结
- OC-遍历字符串
- Linux-16、17、18-服务器操作系统CentOS6.5安装实战(L003-30,31,32)
- clipToPadding
- 各种指针的的概览及造成原因
- 局部打印问题
- 初识String
- Linux与JVM的内存关系分析
- ViewPager动画之三个item的实现
- LeetCode-93.Restore IP Addresses
- SecureCRT 使用pem
- 应聘时最漂亮的回答
- c++第5次上机实验-1
- C#开发微信门户及应用(38)--微信摇一摇红包功能
- Struts2中关于"There is no Action mapped for namespace / and action name"的总结
- [问题集锦0001]]“nvidia grid vgpu支持与桌面设置不匹配”
- Eclipse+CXF框架开发Web服务实战