簡體   English   中英

VTK:為什么 vtkBooleanOperationPolyDataFilter 無法檢測平面和球體之間的交點

[英]VTK: Why vtkBooleanOperationPolyDataFilter can not dectect intersection between a plane and a sphere

我想用 vtkBooleanOperationPolyDataFilter 與一個平面和一個球體相交,但它告訴我即使兩個對象相交,兩個對象之間也沒有相交。 誰能向我解釋為什么?

代碼在這里:

#include <vtkActor.h>
#include <vtkBooleanOperationPolyDataFilter.h>
#include <vtkCleanPolyData.h>
#include <vtkNamedColors.h>
#include <vtkNew.h>
#include <vtkPlaneSource.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkSmartPointer.h>
#include <vtkTriangleFilter.h>

#include <vtkBYUReader.h>
#include <vtkOBJReader.h>
#include <vtkPLYReader.h>
#include <vtkPolyDataReader.h>
#include <vtkSTLReader.h>
#include <vtkXMLPolyDataReader.h>

#include <vtkSphereSource.h>
#include <vtksys/SystemTools.hxx>

int main(int argc, char* argv[]) {
  vtkSmartPointer<vtkPolyData> input1;
  vtkSmartPointer<vtkPolyData> input2;

  vtkNew<vtkSphereSource> sphereSource1;
  sphereSource1->SetCenter(-0.15, 0, 0);
  sphereSource1->SetPhiResolution(20);
  sphereSource1->SetThetaResolution(20);
  sphereSource1->Update();
  input1 = sphereSource1->GetOutput();

  vtkNew<vtkPlaneSource> plane;
  plane->SetXResolution(100);
  plane->SetYResolution(100);
  plane->SetOrigin(-1, -1, 0);
  plane->SetPoint1(1, -1, 0);
  plane->SetPoint2(-1, 1, 0);
  plane->Update();
  input2 = plane->GetOutput();

  vtkNew<vtkNamedColors> colors;

  vtkNew<vtkPolyDataMapper> input1Mapper;
  input1Mapper->SetInputData(input1);
  input1Mapper->ScalarVisibilityOff();
  vtkNew<vtkActor> input1Actor;
  input1Actor->SetMapper(input1Mapper);

  vtkNew<vtkPolyDataMapper> input2Mapper;
  input2Mapper->SetInputData(input2);
  input2Mapper->ScalarVisibilityOff();
  vtkNew<vtkActor> input2Actor;
  input2Actor->SetMapper(input2Mapper);

  vtkNew<vtkBooleanOperationPolyDataFilter> booleanOperation;
  booleanOperation->SetOperationToIntersection();
  booleanOperation->SetInputData(0, input1);
  booleanOperation->SetInputData(1, input2);

  vtkNew<vtkPolyDataMapper> booleanOperationMapper;
  booleanOperationMapper->SetInputConnection(booleanOperation->GetOutputPort());
  booleanOperationMapper->ScalarVisibilityOff();

  vtkNew<vtkActor> booleanOperationActor;
  booleanOperationActor->SetMapper(booleanOperationMapper);

  vtkNew<vtkRenderer> renderer;
  renderer->AddActor(booleanOperationActor);
  renderer->AddActor(input2Actor);
  renderer->AddActor(input1Actor);
  renderer->SetBackground(colors->GetColor3d("Silver").GetData());
  vtkNew<vtkRenderWindow> renderWindow;
  renderWindow->AddRenderer(renderer);
  renderWindow->SetSize(640, 480);
  renderWindow->SetWindowName("BooleanOperationPolyDataFilter");

  vtkNew<vtkRenderWindowInteractor> renWinInteractor;
  renWinInteractor->SetRenderWindow(renderWindow);

  renderWindow->Render();
  renWinInteractor->Start();

  return EXIT_SUCCESS;
}

此圖像顯示兩個對象相交:

在此處輸入圖像描述

這是 vtk 的調試日志,說明兩個對象不相交:

ERROR: In C:\Users\micha\Documents\vtk\Common\DataModel\vtkPointLocator.cxx, line 845
vtkPointLocator (000001AE26DA9270): No points to subdivide

Generic Warning: In C:\Users\micha\Documents\vtk\Filters\General\vtkIntersectionPolyDataFilter.cxx, line 2410
No Intersection between objects 

ERROR: In C:\Users\micha\Documents\vtk\Filters\General\vtkDistancePolyDataFilter.cxx, line 81
vtkDistancePolyDataFilter (000001AE26F75FF0): No points/cells to operate on

ERROR: In C:\Users\micha\Documents\vtk\Filters\General\vtkDistancePolyDataFilter.cxx, line 81
vtkDistancePolyDataFilter (000001AE26F75FF0): No points/cells to operate on

我認為你必須更新 booleanOperation。 booleanOperation.Update()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM