VTK如何让部分单位不可见

最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式

1.通过颜色映射表来进行,是最正规的做法

cpp 复制代码
vtkNew<vtkLookupTable> lut;
//值为0不显示,主要是最后一个参数,透明度调为0
lut->SetTableValue(0, 0, 0, 0, 0);
//值为1显示为红色
lut->SetTableValue(0, 1, 0, 0);
//设置一个颜色数组
vtkNew<vtkDoubleArray> colors;
//填充colors数组
...
//dataSet假设是我们的vtkDataSet模型数据
dataSet->GetCellData()->SetScalars(colors);
dataSet->GetCellData()->Modified();
//mapper假设是我们显示模型数据的vtkMapper
mapper->SetLookupTable(lut);
mapper->SetScalarRange(0, 1);

2.通过vtkThreshold过滤不需要的单元数据,这个方法的缺陷是会改变点的数量和单元的数量,导致对应的点ID和单元ID会和原来的模型不同。

cpp 复制代码
const vtkNew<vtkThreshold> threshold;
threshold->SetInputData(model);
threshold->SetInputArrayToProcess(0, 0, 0, vtkDataObject::CELL, name);
//只保留标记为0的单元
threshold->SetUpperThreshold(0);
threshold->SetLowerThreshold(0);
threshold->Update();

3.通过vtkShaderProperty通过自己写着色器来定义,这个难度是最大的,而且我也还没搞懂,所以不敢随便发表意见了。

4.这是我最近发现的,但是效果却惊人的好。通过把单元的点ID置为单一点,就能实现隐藏该单元

cpp 复制代码
vtkCellArray* cells = vtkUnstructuredGrid::SafeDownCast(modelData)->GetCells();
//假设我要隐藏十号单元
vtkCell* cell = modelData->GetCell(10);
vtkNew<vtkIdList> list;
const auto pIds = cell->GetPointIds();
for (int j = 0;j < pIds->GetNumberOfIds();++j) {
    //把十号单元的点ID全部换为第一个
    list->InsertNextId(pIds->GetId(0));
}
//更换该单元的点列表
cells->ReplaceCellAtId(10, list);
相关推荐
txinyu的博客30 分钟前
解析muduo源码之 SocketsOps.h & SocketsOps.cc
c++
ctyshr1 小时前
C++编译期数学计算
开发语言·c++·算法
努力写代码的熊大1 小时前
c++异常和智能指针
java·开发语言·c++
John_ToDebug1 小时前
WebContent 与 WebView:深入解析浏览器渲染架构的双层设计
c++·chrome·ui
千秋乐。1 小时前
C++-string
开发语言·c++
孞㐑¥1 小时前
算法—队列+宽搜(bfs)+堆
开发语言·c++·经验分享·笔记·算法
yufuu981 小时前
并行算法在STL中的应用
开发语言·c++·算法
charlie1145141912 小时前
嵌入式C++教程——ETL(Embedded Template Library)
开发语言·c++·笔记·学习·嵌入式·etl
陳10302 小时前
C++:AVL树的模拟实现
开发语言·c++
CSDN_RTKLIB2 小时前
错进错出得到正确的字节序列
c++