VTK切割模型

1、效果图

切割前:(红色的线用于标记切割面)

切割前模型

切割后:(切割的位置不封口)

切割后

 

2、代码如下

[cpp] view plaincopyprint?

  1. vtkClipPolyData* clipper = vtkClipPolyData::New(); 
  2. clipper->SetInput(src);  //src为被切割物体的 vtkPolyData* 类型 
  3. clipper->SetClipFunction(plane);  //plane为切割面,为vtkPlane* 类型 
  4. clipper->Update();   //更新生成切割物体。 
  5.  
  6. //复制切割后物体的vtkPolyData* 
  7. vtkPolyData* result = vtkPolyData::New(); 
  8. 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做剪切的代码:

[cpp] view plaincopyprint?

  1. double bounds[6], center[3]; 
  2. src->GetCenter(center); 
  3. src->GetBounds(bounds); 
  4.  
  5. vtkBox* box = vtkBox::New(); 
  6. box->SetBounds(center[0],bounds[1],center[1]-20,bounds[3],center[2],bounds[5]); 
  7. vtkClipPolyData* clipper = vtkClipPolyData::New(); 
  8. clipper->SetInput(src); 
  9. clipper->SetClipFunction(box);  
  10. //clipper->SetInsideOut(-1); 
  11. clipper->Update(); 
  12. vtkPolyData* res = vtkPolyData::New(); 
  13. res->DeepCopy(clipper->GetOutput()); 


下图是利用vtkBox做剪切的效果图:

(5)还一个把去掉的和留下的部分交换。使用函数SetInsideOut(-1);

效果图如下:

(6)注意:

特殊情况是裁剪完的模型就原模型的全部,或者裁剪完的模型里面没有任何点、线、面。

后一种情况下,clipper->GetOutput()->GetNumberOfCells()==0,需要特殊处理。

 

http://blog.csdn.net/jean7155/article/details/7556260

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值