Определение центра 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();

Если вы добавите такой код, вы увидите ось координат в левом нижнем углу.

Другие вопросы по тегам