VTK切割图

vtkPlane:表示一个无限的平面,要由一个法向量和一个通过该平面的点来定义

  • SetOrigin:设置原点(平面经过的点)
  • SetNormal:垂直于平面的方向向量(法向量)

vtkCutter:使用指定的vtkPlane对数据进行切割

  • SetCutFunction:切割工具,可以是vtkPlane
  • SetInputData:切割的数据
  • Update:执行切割
cpp 复制代码
 // 获取数据集的边界框
double bounds[6];
m_dataSet->GetBounds(bounds);

// 根据方向和位置计算切割平面
// model.sliceDirection: 0=XY平面(Z值变化), 1=XZ平面(Y值变化), 2=YZ平面(X值变化)
// model.slicePosition: 0.0~1.0 相对范围
double origin[3] = {
    0.5 * (bounds[0] + bounds[1]),
    0.5 * (bounds[2] + bounds[3]),
    0.5 * (bounds[4] + bounds[5])
};
double normal[3] = {0.0, 0.0, 1.0};

const double t = qBound(0.0, model.slicePosition, 1.0);
switch (model.sliceDirection) {
    case 0: // XY: Z = zMin + t * (zMax - zMin)
        origin[2] = bounds[4] + t * (bounds[5] - bounds[4]);
        normal[0] = 0.0; normal[1] = 0.0; normal[2] = 1.0;
        break;
    case 1: // XZ: Y = yMin + t * (yMax - yMin)
        origin[1] = bounds[2] + t * (bounds[3] - bounds[2]);
        normal[0] = 0.0; normal[1] = 1.0; normal[2] = 0.0;
        break;
    case 2: // YZ: X = xMin + t * (xMax - xMin)
        origin[0] = bounds[0] + t * (bounds[1] - bounds[0]);
        normal[0] = 1.0; normal[1] = 0.0; normal[2] = 0.0;
        break;
    default:
        return false;
}

// 构建切割管线:DataSet -> Plane + Cutter -> Mapper -> Actor
m_slicePlane = vtkSmartPointer<vtkPlane>::New();
m_slicePlane->SetOrigin(origin);
m_slicePlane->SetNormal(normal);

m_sliceCutter = vtkSmartPointer<vtkCutter>::New();
m_sliceCutter->SetCutFunction(m_slicePlane);
m_sliceCutter->SetInputData(m_dataSet);
m_sliceCutter->Update();

if (m_sliceCutter->GetOutput()->GetNumberOfCells() == 0)
    return false;

m_sliceMapper = vtkSmartPointer<vtkDataSetMapper>::New();
m_sliceMapper->SetInputConnection(m_sliceCutter->GetOutputPort());
m_sliceMapper->ScalarVisibilityOff();

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

m_renderer->RemoveActor(m_sliceActor);
m_renderer->AddActor(m_sliceActor);
m_sliceActor->SetMapper(m_sliceMapper);
m_sliceActor->GetProperty()->SetRepresentationToSurface();
m_sliceActor->GetProperty()->SetColor(1.0, 0.2, 0.2);
m_sliceActor->GetProperty()->SetLineWidth(2.0);
m_sliceActor->GetProperty()->LightingOff();

// 切割显示时隐藏本体,避免截面被不透明外表面完全遮挡。
if (m_actor)
    m_actor->SetVisibility(0);

// 切割显示时隐藏云图色标,避免右侧图例误导。
if (m_scalarBar)
    m_scalarBar->SetVisibility(0);
相关推荐
Jun6268 小时前
QT(2)-通过管道关联CMD
开发语言·qt·命令模式
程序员老舅8 小时前
从内核视角,看Linux文件读写过程
linux·服务器·c++·内核·linux内核·vfs·linux内存
Soari9 小时前
llama.cpp更新(b9553):LLM inference in C/C++,本地和云端实现高性能大模型推理
c语言·c++·llama
2601_961194029 小时前
考研资料电子版|去哪找|网盘
java·c语言·c++·python·考研·php
Peter·Pan爱编程9 小时前
23. 算法库:用算法代替手写循环
c++·人工智能·算法
大白话_NOI9 小时前
【洛谷 P1303】A*B Problem + 详细分析
c++
小欣加油10 小时前
leetcode2161 根据给定数字划分数组
数据结构·c++·算法·leetcode·职场和发展
吃着火锅x唱着歌10 小时前
深度探索C++对象模型 学习笔记 第五章 构造、解构、拷贝语意学(2)
c++·笔记·学习
玖釉-10 小时前
Vulkan 离屏渲染详解:从 Framebuffer 到后处理、阴影贴图与 Render Texture
c++·windows·计算机视觉·图形渲染
cpp_250110 小时前
P2947 [USACO09MAR] Look Up S
数据结构·c++·算法·题解·单调栈·洛谷