VTK复习笔记——切割(一)——切割模型
来源:互联网 发布:淘宝店铺首页设计 编辑:程序博客网 时间:2024/05/16 10:03
1、效果图
切割前:(红色的线用于标记切割面)
切割后:(切割的位置不封口)
2、代码如下
vtkClipPolyData* clipper = vtkClipPolyData::New();clipper->SetInput(src);//src为被切割物体的 vtkPolyData* 类型clipper->SetClipFunction(plane); //plane为切割面,为vtkPlane* 类型clipper->Update();//更新生成切割物体。//复制切割后物体的vtkPolyData*vtkPolyData* result = vtkPolyData::New();result->DeepCopy(clipper->GetOutput());
3、简单记录
主要介绍VTK中的类 vtkClipPolyData的功能。其父类为vtkPolyDataAlgorithm类。
类 vtkClipPolyData的功能是裁剪模型。
(1)被裁剪模型通过SetInput()函数设置。
(2)裁剪的方法有2中。SetClipFunction()设置裁剪的方法,或者通过SetValue (double)函数设置裁剪值。(这里我只应用了第一种SetClipFunction()设置裁剪的方法)
(3)SetClipFunction()设置裁剪的方法,需要设置vtkImplicitFunction类的子类。在上面的代码中我设置了vtkPlane类。用一个平面裁剪。
(4)VTK中已有的vtkImplicitFunction类的子类,如下图:
这些类都可以用来做裁剪的输入。
利用vtkBox做剪切的代码:
double bounds[6], center[3];src->GetCenter(center);src->GetBounds(bounds);vtkBox* box = vtkBox::New();box->SetBounds(center[0],bounds[1],center[1]-20,bounds[3],center[2],bounds[5]);vtkClipPolyData* clipper = vtkClipPolyData::New();clipper->SetInput(src);clipper->SetClipFunction(box); //clipper->SetInsideOut(-1);clipper->Update();vtkPolyData* res = vtkPolyData::New();res->DeepCopy(clipper->GetOutput());
下图是利用vtkBox做剪切的效果图:
(5)还一个把去掉的和留下的部分交换。使用函数SetInsideOut(-1);
效果图如下:
(6)注意:
特殊情况是裁剪完的模型就原模型的全部,或者裁剪完的模型里面没有任何点、线、面。
后一种情况下,clipper->GetOutput()->GetNumberOfCells()==0,需要特殊处理。
- VTK复习笔记——切割(一)——切割模型
- VTK切割模型
- VTK实现面模型切割
- VTK实现面模型切割
- sstream——切割单词
- java——list切割
- 编程之美笔记——光影切割问题
- 【vtk实例】平面切割
- 算法导论——钢条切割问题
- 动态规划——钢条切割
- caffee学习——图像切割
- 算法导论例题——钢管切割
- IO流——切割流
- 动态规划—钢条切割问题
- 《算法导论》学习笔记——钢条切割,斐波那契数列(动态规划)
- Unreal Engine 4 —— 使用ProceduralMeshComponent实现模型实时切割
- Unreal Engine 4 —— 使用ProceduralMeshComponent实现模型实时切割
- 灰度变换——反转,对数变换,伽马变换,灰度拉伸,灰度切割,位图切割
- 开启线程CreatThread函数的使用,主线程与工作线程的交互
- iframe中的页面缓存清不掉解决方法
- VC++线程的同步
- study plan --- New Concept English
- jBPM4.4开发(三)-----------task任务节点
- VTK复习笔记——切割(一)——切割模型
- 护卫犬挺身护主被20多人砍死 主人为其开追悼会
- PCL配置(1)
- SQL 用户权限(表、函数、存储过程等)---收藏
- LinearGradient类来实现图片的渐变效果
- MySQL中字符串字段连接
- PCL入门文档
- javascript帮助类---提示信息
- 最短路(Dijkstra+优先队列)