How to fix the vtkCamera inverted y axis

本文详细介绍了如何使用ITK和VTK库创建并配置一个视图,包括设置坐标系、相机位置、焦距点及视角方向,实现场景填充。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 Go back to the basics, it is actually quite simple.
    There is a right-handed coordinate system,
    the same in ITK and VTK.

    You must put your camera in a location in space,
    (defined in term of that coordinate system)
    aim the camera to a point in space
    (defined in term of that coordinate system)
    orient the camera to have a vertical direction
    (defined in term of that coordinate system)


    Then you can start populating your scene.

    this->m_viewer2 = vtkSmartPointer<vtkImageViewer2>::New();

    this->m_viewer2->SetInput(vtkReader->GetOutput());
    this->m_viewer2->SetSliceOrientationToXY();

    // Fixed invert y axis

    double pos[2], foc[2];
    this->m_viewer2->GetRenderer()->GetActiveCamera()->GetPosition(pos);
    this->m_viewer2->GetRenderer()->GetActiveCamera()->GetFocalPoint(foc);
    pos[2] = -1;
    this->m_viewer2->GetRenderer()->GetActiveCamera()->SetPosition(pos);
    //    std::cout<<pos[0]<<pos[1]<<pos[2]<<std::endl<<foc[0]<<foc[1]<<foc[2]<<std::endl;

    this->m_viewer2->GetRenderer()->GetActiveCamera()->SetViewUp(0, -1, 0);
    this->m_viewer2->GetRenderer()->ResetCamera();
    this->m_viewer2->UpdateDisplayExtent();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值