如何使用ITK将调色板图像作为标量图像读取?

时间:2016-12-24 05:23:50

标签: c++ image itk color-palette

当我正在阅读图片时,itk::ImageIOBase(已实施here)告诉我该图片具有RGB像素类型。图像的格式是TIFF,但也可以是png或gif。

itk::ImageIOBase::Pointer imageIO =
    itk::ImageIOFactory::CreateImageIO(
        fileName, itk::ImageIOFactory::ReadMode);

如何知道通过ITK ,图像是否实际上是调色板图像,标量图像以及调色板,并将图像作为标量图像读取+调色板?我需要检索存储在文件中的索引以及文件中使用的调色板。

目前,我唯一的解决方案是使用freeImagePlus来识别和读取这种类型的图像。我没有在课程ImageIOBase中找到任何与此相关的函数。

任何帮助将不胜感激,我没有在互联网上找到这方面的很多信息!

2 个答案:

答案 0 :(得分:0)

您是否尝试将其作为灰度图像阅读?如果没有明确设置IO,这个读者会产生什么结果呢?

{{1}}

除非你需要彩色调色板,否则这就足够了。

答案 1 :(得分:0)

要回答我自己的问题,该功能现在在ITK中,在主分支中实现,并为png tif和bmp图像提供调色板支持

这是一个工作示例,对于那些感兴趣的人:

#include "itkImage.h"
#include <iostream>
#include <string>

#include "itkPNGImageIOFactory.h"
#include "itkImageFileReader.h"
#include "itkPNGImageIO.h"

int main()
{
    std::string filename("testImage_palette.png");

    auto io = itk::PNGImageIO::New();

    // tell the reader not to expand palette to RGB, if possible
    io->SetExpandRGBPalette(false);

    typedef unsigned short PixelType;
    typedef itk::Image<PixelType, 2> imageType;
    typedef itk::ImageFileReader<imageType> ReaderType;
    ReaderType::Pointer reader = ReaderType::New();

    reader->SetFileName(filename);
    reader->SetImageIO(io);

    try {
        reader->Update();
    } catch (itk::ExceptionObject &err) {
        std::cerr << "ExceptionObject caught !" << std::endl;
        std::cerr << err << std::endl;
        return EXIT_FAILURE;
    }

    std::cout<< std::endl << "IsReadAsScalarPlusPalette:" <<io->GetIsReadAsScalarPlusPalette() << std::endl;

    if (io->GetIsReadAsScalarPlusPalette()) {
        auto palette(io->GetColorPalette());
        std::cout<< "palette (size="<< palette.size()<<"):"<< std::endl;
        auto m(std::min(static_cast<size_t>(10),palette.size()));
        for (size_t i=0; i<m;++i) {
            std::cout << "["<<palette[i]<< "]"<< std::endl;
        }
        if (m< palette.size())
            std::cout<< "[...]"<< std::endl;
    }
    // if io->GetIsReadAsScalarPlusPalette() im will be the index of the palette image
    auto im(reader->GetOutput()); 
}