本系列文章由 @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版本不断更新, Opencv的C++
版本数据结构和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