Определение центра VTKPolyDataMapper
У меня есть приложение, которое импортирует файл STEP и преобразует геометрию в объект OpenCascade. Затем этот объект визуализируется с помощью средства просмотра VTK.
Это код (C++, QT):
Импортируйте файл STEP и преобразуйте его в объект OpenCascade
QString pathFileName = "component.step" ;
STEPControl_Reader reader;
reader.ReadFile(pathFileName.toStdString().c_str());
reader.NbRootsForTransfer();
reader.TransferRoots();
TopoDS_Shape shape;
shape = reader.OneShape();
BRepTools::Clean(shape);
Визуализируйте форму, используя VTK
IVtkOCC_Shape::Handle shapeImpl = new IVtkOCC_Shape(shape);
vtkSmartPointer<IVtkTools_ShapeDataSource> DS = vtkSmartPointer<IVtkTools_ShapeDataSource>::New();
DS->SetShape(shapeImpl);
vtkSmartPointer<vtkPolyDataMapper> Mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
Mapper->SetInputConnection(DS->GetOutputPort());
vtkSmartPointer<vtkActor> Actor = vtkSmartPointer<vtkActor>::New();
Actor->SetMapper(Mapper);
vtkSmartPointer<vtkRenderer> Renderer = vtkSmartPointer<vtkRenderer>::New();
Renderer->AddActor(Actor);
Результат показан здесь:
Это неплохо, однако, ось координат довольно далеко, как мы видим, если я увеличу масштаб:
Если я печатаю центр картографа, я получаю эти значения:
X: 0
Y: 172,333
Z: 0
Я хотел бы установить "Y" на Cero, но я не знаю, как это сделать, поскольку атрибут "центр" класса защищен.
1 ответ
Решение
vtkAxesActor *axes = vtkAxesActor::New();
vtkOrientationMarkerWidget *widget = vtkOrientationMarkerWidget::New();
widget->SetDefaultRenderer(renderer);
widget->SetOrientationMarker(axes);
widget->SetInteractor(ren);
widget->EnabledOn();
Если вы добавите такой код, вы увидите ось координат в левом нижнем углу.