文章目录

  • 1.图像文件的读取
  • 2.图像效果展示
  • 3.将彩色图转换为灰度图
  • 4.视频文件的读取
  • 5.读取视频中指定帧的图像
  • 6.图片文件的报错


1.图像文件的读取

语法介绍

A = imread(filename)
A = imread(filename, fmt)

参数介绍

  • filename:要读取的图像文件名,可以是完整的路径。
  • fmt:可选参数,指定图像的格式。默认情况下,imread会尝试猜测文件格式。常用的格式包括 ‘bmp’、‘gif’、‘jpeg’、‘png’、'tiff’等。

返回值

  • A:返回读取的图像数据矩阵,它可以是灰度图像(2维矩阵)或者是彩色图像(3维矩阵)。

注意事项:需要注意的是,imread函数读取的图像数据类型是 uint8,即无符号8位整型。如果需要进行浮点运算或其他类型的处理,需要将数据类型转换为相应的类型,比如 double 或 single。此外,在读取大型图像时,可能需要使用 imread 的第二个输出参数来分批读取图像数据。

2.图像效果展示

语法介绍

imshow(I, [low high])

参数介绍

  • I:要显示的图像数据矩阵,可以是灰度图像(2维矩阵)或者是彩色图像(3维矩阵)。
  • low:可选参数,指定图像灰度值的下限,范围在[0, 1]之间。默认值为最小灰度值。
  • high:可选参数,指定图像灰度值的上限,范围在[0, 1]之间。默认值为最大灰度值。

注意事项:需要注意的是,imshow函数的缩放方式默认是自适应的,即根据窗口大小自动缩放图像。

3.将彩色图转换为灰度图

语法介绍

I_gray = rgb2gray(I_rgb)

参数和返回值

  • I_rgb:要转换的RGB彩色图像数据矩阵。
  • I_gray:转换后的灰度图像数据矩阵。

注意事项:需要注意的是,rgb2gray函数采用的是加权平均法将RGB三个通道的像素值转换为灰度值,因此,转换后的灰度图像不是简单地将RGB通道平均得到的结果。

4.视频文件的读取

语法介绍

V = VideoReader(filename)

参数和返回值介绍

  • filename:要读取的视频文件名,可以是绝对路径或相对路径。
  • vid:一个VideoReader对象,表示视频文件。

注意事项:需要注意的是,VideoReader函数支持读取多种视频格式(如AVI、MP4等),但对于某些特殊的视频格式可能会出现不兼容或读取失败的情况。在使用时需要根据实际情况进行测试和调试。

VideoReader对象的常用属性

  • Name:视频文件名。
  • Path:视频文件路径。
  • Duration:视频文件时长。
  • FrameRate:视频文件的帧率。
  • Width:视频帧的宽度。
  • Height:视频帧的高度。
  • NumberOfFrames:视频文件的帧数。
  • BitsPerPixel:视频文件的每个像素使用的位数。
  • VideoFormat:视频文件的格式。
  • Tag:用户可以将任意数据附加到对象中,以便在后续操作中使用。

5.读取视频中指定帧的图像

语法介绍

I = read(videoReader, index)

参数和返回值介绍

  • videoReader:一个VideoReader对象,表示被读取的视频;
  • index:要读取的帧的编号;
  • I:一个二维或三维矩阵,表示该帧的图像数据。

6.图片文件的报错

语法介绍

imwrite(A, filename)

参数介绍

  • A:要保存的图像数据,可以是二维或三维矩阵;
  • filename:要保存的文件名。

除了上面介绍的基本语法外,imwrite函数还有一些其他的可选参数,例如:

  • Quality:用于指定JPEG格式的图像质量,取值范围为0~100,默认值为75。
  • Compression:用于指定PNG格式的压缩等级,取值范围为0~9,默认值为6。

注意事项:文件格式由文件扩展名决定,imwrite函数可以自动根据文件扩展名确定文件格式,常见的文件格式包括BMP、JPEG、PNG等。