vtk镜像图

vtkReflectionFilter :用于将数据集沿一个平面进行镜像反射的过滤器

  • SetPlane:设置镜像平面,有x_min,y_min,z_min,x_max,y_max,z_max,x,y,z几种选项
  • SetCenter:平面位置,仅在Plane设为 X, Y, Z 时有效,用于指定平面的具体坐标
  • SetCopyInput:是否复制原数据。设为 On (默认) 则输出镜像和原数据,设为 Off 则仅输出镜像数据
  • SetFlipAllInputArrays:翻转所有数组。默认仅翻转向量、法线等。开启后会翻转输入中的所有3分量数组,需注意:此选项仅在 VTK 7.0+ 版本中可用
cpp 复制代码
 int vtkPlaneMode = vtkReflectionFilter::USE_X;
 double planeCenter = model.planePosition;
 m_reflectFilter = vtkSmartPointer<vtkReflectionFilter>::New();
 m_reflectFilter->SetInputData(m_dataSet);
 switch (model.planeMode) {
     case 0: vtkPlaneMode = vtkReflectionFilter::USE_X_MIN; break;
     case 1: vtkPlaneMode = vtkReflectionFilter::USE_Y_MIN; break;
     case 2: vtkPlaneMode = vtkReflectionFilter::USE_Z_MIN; break;
     case 3: vtkPlaneMode = vtkReflectionFilter::USE_X_MAX; break;
     case 4: vtkPlaneMode = vtkReflectionFilter::USE_Y_MAX; break;
     case 5: vtkPlaneMode = vtkReflectionFilter::USE_Z_MAX; break;
     case 6: vtkPlaneMode = vtkReflectionFilter::USE_X; break;
     case 7: vtkPlaneMode = vtkReflectionFilter::USE_Y; break;
     case 8: vtkPlaneMode = vtkReflectionFilter::USE_Z; break;
     default:
         return false;
 }
 m_reflectFilter->SetPlane(vtkPlaneMode);
 m_reflectFilter->SetCenter(planeCenter);
 m_reflectFilter->SetCopyInput(static_cast<int>(model.copyInput));
 m_reflectFilter->SetFlipAllInputArrays(true);

 m_reflectMapper = vtkSmartPointer<vtkDataSetMapper>::New();
 m_reflectMapper->SetInputConnection(m_reflectFilter->GetOutputPort());
 m_reflectMapper->ScalarVisibilityOff();

 if (!m_reflectActor) {
     m_reflectActor = vtkSmartPointer<vtkActor>::New();
 }

 m_renderer->RemoveActor(m_reflectActor);
 m_renderer->AddActor(m_reflectActor);
 m_reflectActor->SetMapper(m_reflectMapper);
 m_reflectActor->GetProperty()->SetColor(0.9, 0.9, 0.9);
 setActorRenderMode(m_reflectActor);
相关推荐
@小码农2 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
【 】4232 小时前
C++&STL(Standard Template Library,标准模板库)
java·开发语言·c++
一只牛_0072 小时前
pthread亲和性继承的一个坑:main绑核让整个进程退化到单核
c++
张健11564096483 小时前
C++访问控制与友元
java·开发语言·c++
BirdenT4 小时前
20260424紫题训练
c++·算法
还是阿落呀4 小时前
基本控制结构
开发语言·c++·算法
样例过了就是过了4 小时前
LeetCode热题100 最长有效括号
c++·算法·leetcode·动态规划
南境十里·墨染春水4 小时前
C++笔记 forward完美转发
开发语言·c++·笔记
吃着火锅x唱着歌4 小时前
深度探索C++对象模型 学习笔记 第四章 Function语意学(2)
c++·笔记·学习