Study-VTK:Qt VTK图片 读取和写出

本文详细介绍了VTK库中多种图像格式的读取与写出方法,包括JPEG、PNG、DICOM等常见格式,以及如何使用VTK进行图像处理前后的文件保存。适用于初学者快速上手VTK图像操作。

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

以前从未接触过vtk,用这玩意每次读取数据总要各种搜索,特此记录下vtk下自己常用的数据读入读出
主要参考:vtk帮助文档
案例源码

vtk 图像读取
ImageReader2Factory 读取任意格式图片
JPEGReader 读取jpg图片
MetaImageReader 读取mha,mhd,raw图片
PNGReader 读取png图片
ReadBMP 读取bmp图片
ReadDICOM读取dicom图片单张
ReadDICOMSeries读取连续dicom图片
ReadPNM读取pnm图片
ReadTIFF读取tif图片

使用方法基本雷同,读取不同格式替换为不同类即可,实在烦就直接用ImageReader2Factory
下边输入参数解释下

读取连续dicom图片argv[1] 是文件夹名字
其余读取图片argv[1]是文件名字

// 读取任意格式图片
  vtkSmartPointer<vtkImageReader2Factory> readerFactory =vtkSmartPointer<vtkImageReader2Factory>::New();
  vtkSmartPointer<vtkImageReader2> imageReader;
  imageReader.TakeReference(
  readerFactory->CreateImageReader2(argv[1] c_str()));
  imageReader->SetFileName(argv[1] .c_str());
  imageReader->Update();
 //读取jpg图片
  vtkSmartPointer<vtkJPEGReader> jpegReader =vtkSmartPointer<vtkJPEGReader>::New();
  jpegReader->SetFileName ( argv[1] );
 //读取mha,mhd,raw图片
 vtkSmartPointer<vtkMetaImageReader> reader =vtkSmartPointer<vtkMetaImageReader>::New();
reader->SetFileName(inputFilename.c_str());
reader->Update();
 //读取png图片
  vtkSmartPointer<vtkPNGReader> reader =vtkSmartPointer<vtkPNGReader>::New();
  reader->SetFileName(argv[1]);
 //读取bmp图片
  vtkSmartPointer<vtkBMPReader> reader =vtkSmartPointer<vtkBMPReader>::New();
  reader->SetFileName ( argv[1] );
 //读取dicom图片单张
  vtkSmartPointer<vtkDICOMImageReader> reader = vtkSmartPointer<vtkDICOMImageReader>::New();
  reader->SetFileName(inputFilename.c_str());
  reader->Update();
 //读取连续dicom图片
   vtkSmartPointer<vtkDICOMImageReader> reader =vtkSmartPointer<vtkDICOMImageReader>::New();
   reader->SetDirectoryName(folder.c_str());
   reader->Update();
 //读取pnm图片
  vtkSmartPointer<vtkPNMReader> reader =vtkSmartPointer<vtkPNMReader>::New();
  reader->SetFileName ( argv[1] );
 //读取tif图片
vtkSmartPointer<vtkTIFFReader> reader =vtkSmartPointer<vtkTIFFReader>::New();
  reader->SetFileName ( argv[1] );

获取读取的图片统一用

imageReader->GetOutputPort()

vtk 图像写出

WriteImage()
提供了一个通用函数writeImage(),该函数根据文件扩展名选择要使用的图像编写器,然后将渲染窗口写入文件。支持以下格式:bmp、jpeg、pnm、png、postscript、tiff。
vtkJPEGWriter写出jpg图片
vtkMetaImageWriter写出 .mha/.mhd + .raw图片
vtkPNGWriter写出png图片
vtkBMPWriter写出bmp图片
vtkPNMWriter写出pnm图片
vtkTIFFWriter写出tif图片

这个是直接根据图片格式保存对应图片,单独某一个类型的用法类似

#include <vtkActor.h>
#include <vtkNamedColors.h>
#include <vtkPolyDataMapper.h>
#include <vtkProperty.h>
#include <vtkRenderWindow.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkRenderer.h>
#include <vtkSmartPointer.h>
#include <vtkSphereSource.h>

#include <vtkBMPWriter.h>
#include <vtkImageWriter.h>
#include <vtkJPEGWriter.h>
#include <vtkPNGWriter.h>
#include <vtkPNMWriter.h>
#include <vtkPostScriptWriter.h>
#include <vtkTIFFWriter.h>
#include <vtkWindowToImageFilter.h>

#include <array>
#include <locale>
#include <string>

namespace {
void WriteImage(std::string const &fileName, vtkRenderWindow *renWin,
                bool rgba = true);
}

int main(int, char *[]) {
    auto colors = vtkSmartPointer<vtkNamedColors>::New();
    std::array<unsigned char, 4> bkg{{26, 51, 102, 255}};
    colors->SetColor("BkgColor", bkg.data());
    auto ren = vtkSmartPointer<vtkRenderer>::New();
    auto renWin = vtkSmartPointer<vtkRenderWindow>::New();
    renWin->AddRenderer(ren);
    auto iren = vtkSmartPointer<vtkRenderWindowInteractor>::New();
    iren->SetRenderWindow(renWin);
    auto source = vtkSmartPointer<vtkSphereSource>::New();
    source->SetCenter(0, 0, 0);
    source->SetRadius(5.0);
    auto mapper = vtkSmartPointer<vtkPolyDataMapper>::New();
    mapper->SetInputConnection(source->GetOutputPort());
    auto actor = vtkSmartPointer<vtkActor>::New();
    actor->SetMapper(mapper);
    actor->GetProperty()->SetColor(colors->GetColor3d("Yellow").GetData());
    ren->AddActor(actor);
    ren->SetBackground(colors->GetColor3d("BkgColor").GetData());
    renWin->Render();
    std::vector<std::string> ext = {{""},      {".png"}, {".jpg"}, {".ps"},
        {".tiff"}, {".bmp"}, {".pnm"}
    };
    std::vector<std::string> filenames;
    std::transform(ext.begin(), ext.end(), std::back_inserter(filenames),
    [](const std::string & e) {
        return "ImageWriter" + e;
    });
    filenames[0] = filenames[0] + '1';
    for (auto f : filenames) {
        WriteImage(f, renWin, false);
    }
    iren->Initialize();
    iren->Start();
    return EXIT_SUCCESS;
}
namespace {
void WriteImage(std::string const &fileName, vtkRenderWindow *renWin, bool rgba) {
    if (!fileName.empty()) {
        std::string fn = fileName;
        std::string ext;
        auto found = fn.find_last_of(".");
        if (found == std::string::npos) {
            ext = ".png";
            fn += ext;
        } else {
            ext = fileName.substr(found, fileName.size());
        }
        std::locale loc;
        std::transform(ext.begin(), ext.end(), ext.begin(),
        [ = ](char const & c) {
            return std::tolower(c, loc);
        });
        auto writer = vtkSmartPointer<vtkImageWriter>::New();
        if (ext == ".bmp") {
            writer = vtkSmartPointer<vtkBMPWriter>::New();
        } else if (ext == ".jpg") {
            writer = vtkSmartPointer<vtkJPEGWriter>::New();
        } else if (ext == ".pnm") {
            writer = vtkSmartPointer<vtkPNMWriter>::New();
        } else if (ext == ".ps") {
            if (rgba) {
                rgba = false;
            }
            writer = vtkSmartPointer<vtkPostScriptWriter>::New();
        } else if (ext == ".tiff") {
            writer = vtkSmartPointer<vtkTIFFWriter>::New();
        } else {
            writer = vtkSmartPointer<vtkPNGWriter>::New();
        }
        auto window_to_image_filter =
            vtkSmartPointer<vtkWindowToImageFilter>::New();
        window_to_image_filter->SetInput(renWin);
        window_to_image_filter->SetScale(1); // image quality
        if (rgba) {
            window_to_image_filter->SetInputBufferTypeToRGBA();
        } else {
            window_to_image_filter->SetInputBufferTypeToRGB();
        }
        // Read from the front buffer.
        window_to_image_filter->ReadFrontBufferOff();
        window_to_image_filter->Update();

        writer->SetFileName(fn.c_str());
        writer->SetInputConnection(window_to_image_filter->GetOutputPort());
        writer->Write();
    } else {
        std::cerr << "No filename provided." << std::endl;
    }
    return;
}
}







vtk学习教程
Study-VTK

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Beyond欣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值