Opencv 图像读取与保存问题

本文详细介绍了OpenCV中imread和imwrite函数的使用,包括图像读取的参数选择,如IMREAD_UNCHANGED、IMREAD_GRAYSCALE等,并讨论了不同图像格式对4通道图像的支持情况。此外,还提到了图像保存时的限制和注意事项,如对PNG图像支持保存Alpha通道。
摘要由CSDN通过智能技术生成


本系列文章由 @yhl_leo 出品,转载请注明出处。
文章链接: http://blog.csdn.net/yhl_leo/article/details/49737357


本文仅对 Opencv图像读取与保存进行阐述,重在探讨图像读取与保存过程中应注意的细节问题。

1 图像读取

首先看一下,imread函数的声明:

// C++: Mat based
Mat imread(const string& filename, int flags=1 );

// C: IplImage based
IplImage* cvLoadImage(const char* filename, int iscolor=CV_LOAD_IMAGE_COLOR );

// C: CvMat based
CvMat* cvLoadImageM(const char* filename, int iscolor=CV_LOAD_IMAGE_COLOR );

此处,就不列出python的函数声明。随着2.x和3.x版本不断更新, OpencvC++版本数据结构和C版本有较大差异,前者减少了指针的大量使用,用法更加便捷,因此建议多使用前者。以C++版本函数进行分析,形参列表包括:

  • filename : 待加载图像(包括:文件路径和文件名,图像在工程默认路径下的可省略文件路径);
  • flags : 标志符,指定图像加载颜色类型,默认值为1:

    • IMREAD_UNCHANGED / CV_LOAD_IMAGE_UNCHANGED :不加改变的加载原图。
    • IMREAD_GRAYSCALE / CV_LOAD_IMAGE_GRAYSCALE :图像转为灰度图(GRAY,1通道)。
    • IMREAD_COLOR / CV_LOAD_IMAGE_COLOR :图像转为彩色图(BGR,3通道)。
    • IMREAD_ANYDEPTH / CV_LOAD_IMAGE_ANYDEPTH :任何位深度,如果载入的图像不是16-bit位图或者32-bit位图,则转化为8-bit位图。
    • IMREAD_ANYCOLOR / CV_LOAD_IMAGE_ANYCOLOR :任何彩色,单独使用的时候等价于 IMREAD_UNCHANGED / CV_LOAD_IMAGE_UNCHANGED
    • > 0 :返回3通道的彩色图,但是如果是4通道(RGBA),其中Alpha需要保留的话,不建议这么使用,因为一旦这么使用,就会导致Alpha通道被剥离掉,此时建议使用负值。
    • = 0 :返回灰度图像。
    • < 0 :返回具有Alpha通道的图像。

如果你喜欢使用imread("file.jpg")缺省参数的形式加载图像,务必要留意你所加载后的图像可能已经不是你原本想要的图像了!

Opencv源码枚举类型中也可以看到上述标识符含义:

// highgui.hpp
enum
{
    // 8bit, color or not
    IMREAD_UNCHANGED  =-1,
    // 8bit, gray
    IMREAD_GRAYSCALE  =0,
    // ?, color
    IMREAD_COLOR      =1,
    // any depth, ?
    IMREAD_ANYDEPTH   =2,
    // ?, any color
    IMREAD_ANYCOLOR   =4
};

// highui_c.h
enum
{
/* 8bit, color or not */
    CV_LOAD_IMAGE_UNCHANGED  =-1,
/* 8bit, gray */
    CV_LOAD_IMAGE_GRAYSCALE  =0,
/* ?, color */
    CV_LOAD_IMAGE_COLOR      =1,
/* any depth, ? */
    CV_LOAD_IMAGE_ANYDEPTH   =2,
/* ?, any color */
    CV_LOAD_IMAGE_ANYCOLOR   =4
};

Opencv已经支持目前很多图像格式,但是并非全部。主要包括:

  • Windows bitmaps    ->    *.bmp, *.dib (always supported)
  • JPEG files
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值