文章目录
- 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等。