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);
相关推荐
程序leo源9 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
zh_xuan10 小时前
解决VS Code 控制台中文乱码
c++·vscode·乱码
郭涤生10 小时前
飞凌 RK3588 开发板同显 / 异显模式切换
c++·rk3588
计算机安禾10 小时前
【c++面向对象编程】第38篇:设计原则(二):里氏替换、接口隔离与依赖倒置
开发语言·c++
我在人间贩卖青春10 小时前
重学Qt——事件处理
qt
code_whiter11 小时前
C++1进阶(继承)
开发语言·c++
小宋00111 小时前
QT中控件qss样式修改
开发语言·qt
智者知已应修善业11 小时前
【51单片机LED闪烁10次数码管显示0-9】2023-12-14
c++·经验分享·笔记·算法·51单片机
智者知已应修善业11 小时前
【51单片机2按键控制1个敞亮LED灯闪烁和熄灭】2023-11-3
c++·经验分享·笔记·算法·51单片机
咩咦12 小时前
C++学习笔记20:日期类比较运算符重载
c++·学习笔记·类和对象·运算符重载·比较运算符·日期类