Skip to content

vtk图片显示

Qt 下使用 vtk 显示图片,主要是相机的设置和缩放比例尺。增加了很多实用的接口。

    if (this->vmtk_renderer_ == nullptr) {
        qWarning() << "renderer is null";
        return false;
    }
    if (this->actor_ == nullptr) {
        this->actor_ = vtkSmartPointer<vtkImageActor>::New();
    }
    this->actor_->SetInputData(this->image_);
    this->vmtk_renderer_->GetRenderer()->AddActor(this->actor_);
    if (this->scale_actor_ == nullptr) {
        this->scale_actor_ = vtkSmartPointer<vtkLegendScaleActor>::New();
    }
    this->scale_actor_->SetLabelMode(1);
    this->scale_actor_->TopAxisVisibilityOff();
    this->scale_actor_->LeftAxisVisibilityOn();
    this->scale_actor_->BottomAxisVisibilityOff();
    this->scale_actor_->RightAxisVisibilityOff();
    this->scale_actor_->LegendVisibilityOff();
    this->scale_actor_->SetLeftBorderOffset(90);
    this->scale_actor_->SetBottomBorderOffset(35);
    this->scale_actor_->SetTopBorderOffset(35);
    this->scale_actor_->GetLeftAxis()->SetNumberOfLabels(5);
    this->scale_actor_->GetLeftAxis()->SetAdjustLabels(true);
    this->scale_actor_->GetLeftAxis()->SetFontFactor(1);
    this->vmtk_renderer_->GetRenderer()->AddActor(this->scale_actor_);
    double origin[3];
    double spacing[3];
    int extent[6];
    this->image_->GetOrigin(origin);
    this->image_->GetSpacing(spacing);
    this->image_->GetExtent(extent);
    vtkSmartPointer<vtkCamera> camera =
        this->vmtk_renderer_->GetRenderer()->GetActiveCamera();
    camera->ParallelProjectionOn();
    double xc = origin[0] + 0.5 * (extent[0] + extent[1]) * spacing[0];
    double yc = origin[1] + 0.5 * (extent[2] + extent[3]) * spacing[1];
    double xd = (extent[1] - extent[0] + 1) * spacing[0];
    double yd = (extent[3] - extent[2] + 1) * spacing[1];
    double d = camera->GetDistance();
    Q_UNUSED(xd)
    camera->SetFocalPoint(xc, yc, 0.0);
    camera->SetPosition(xc, yc, d);
    camera->SetParallelScale(0.5 * (yd - 1));
    this->vmtk_renderer_->Render();