openCV

Mat能存储的数据类型:

_Tp:用户自定义的数据类型

Mat类的创建

1、利用矩阵宽、高和类型参数创建Mat类

cpp 复制代码
cv:Mat::Mat(int rows, int cols, int type);

rows:构造矩阵的行数

cols:矩阵的列数

type:矩阵中存储的数据类型。此处除了CV_8UC1\CV_64FC4等从1到4通道以外,还提供了更多通道的参数,通过CV_8UC(n)中的n来构建多通道矩阵,其中n最大可以取到512.

2、利用矩阵Size()结构和数据类型参数2创建Mat类

cpp 复制代码
cv:Mat:Mat(Size size, int type);

size:2D数组变量尺寸,通过Size(cols, rows)进行赋值。

type:矩阵中存储的数据类型。此处除了CV_8UC1\CV_64FC4等从1到4通道以外,还提供了更多通道的参数,通过CV_8UC(n)中的n来构建多通道矩阵,其中n最大可以取到512.

3、利用已有Mat类创建新的Mat类

cpp 复制代码
cv:Mat:Mat(const Mat & m, const Range & rowRange, const Range & colRange = Range::all());

m:已经构建完成的Mat类矩阵数据。

rowRange:在已有矩阵中需要截取的行数范围,是一个Range变量,例如从第2行到第5行可以表示为Range(2,5)。

colRange:在已有矩阵中需要截取的列数范围,是一个Range变量,例如从第2列到第5列可以表示为Range(2,5),当不输入任何值时表示所有列都会被截取。

Mat类的赋值

1、类方法赋值

eye:单位对角阵

diag:对角矩阵

ones:元素全为1的矩阵

zeros:元素全为0的矩阵

2、

cpp 复制代码
cv::Mat::Mat(int rows, int cols, int type, const Scalar & s);

rows:矩阵的行数
l cols :矩阵的列数
l type :存储数据的类型
s:给矩阵中每个像素赋值的参数变量,例如Scalar(0, 0, 255) 。

3、枚举法赋值

cv::Mat a = (cv::Mat_<int>(3, 3)<<1, 2, 3, 4, 5, 6, 7, 8, 9);
l cv::Mat b = (cv::Mat_<double>(2, 3) << 1.0, 2.1, 3.2, 4.0, 5.1, 6.2);

图像加载(读取)

cpp 复制代码
cv::Mat cv::imread(const String & fliename, int flags = IMREAD_COLOR);

filename:需要读取图像的文件名称,包含图像地址、名称和图像文件扩展名

flags:读取图像形式的标志

图像显示

cpp 复制代码
void cv::namedWindow(const String & winName, int flags = WINDOW_AUTOSIZE);

winName:窗口名称,作用窗口的标识符

flags:窗口属性设置标志

cpp 复制代码
void cv::imshow(const String & winname, InputArray mat);

winname:要显示图像窗口的名字,用字符串形式赋值

mat:要显示的图像矩阵

图像保存

cpp 复制代码
bool cv::imwrite(const String & filename, InputArray img, const std::vector<int> & params = std::vector<int> ());

filename:保存图像的地址和文件名,包含图像格式

img:将要保存的Mat类矩阵变量

params:保存图片格式属性设置标志

视频加载(读取)/摄像头调用

cpp 复制代码
cv::VideoCapture::VideoCapture(const String & fileName, int apiPreference = CAP_ANY);

fileNmae:读取的视频文件或者图像序列名称

apiPreference:读取数据时设置的属性,例如编码格式、是否调用OpenNI等

cpp 复制代码
cv::VideoWriter::VideoWriter(const String filename, int fourcc, double fps, Size frameSize, bool isColor = true);

filename :保存视频的地址和文件名,包含视频格式
fourcc :压缩帧的 4 字符编解码器代码,详细参数在表 2-7 给出。
fps :保存视频的帧率,即视频中每秒图像的张数。
framSize :视频帧的尺寸
isColor :保存视频是否为彩色视频

相关推荐
说私域1 小时前
百丽企业数字化转型失败案例分析及其AI智能名片S2B2C商城小程序的适用性探讨
人工智能·小程序
不当菜鸡的程序媛2 小时前
Stable Diffusion的U-Net中,交叉注意力机制的QKV
人工智能
不当菜鸡的程序媛2 小时前
Stable Diffusion里面Cross-Attention设计:为啥Q来自图像/噪声,K和V来自文本
人工智能·计算机视觉·stable diffusion
2401_841495645 小时前
【计算机视觉】基于数学形态学的保留边缘图像去噪
人工智能·python·算法·计算机视觉·图像去噪·数学形态学·边缘保留
三天哥5 小时前
Sora 2为什么会火?
人工智能·gpt·ai·aigc·agi·ai视频·sora
逻辑留白陈5 小时前
2025年实用大模型工具清单
人工智能·学习方法
许泽宇的技术分享5 小时前
AI驱动的视频生成革命:MoneyPrinterTurbo技术架构深度解析
人工智能·内容创作·ai视频生成
飞哥数智坊6 小时前
“成章”写作助手开源:中秋赏不成月,那就开源一个 AI 实战项目吧
人工智能·ai编程·trae
colus_SEU6 小时前
【循环神经网络6】LSTM实战——基于LSTM的IMDb电影评论情感分析
人工智能·rnn·深度学习·神经网络·lstm
zezexihaha6 小时前
AI + 制造:从技术试点到产业刚需的 2025 实践图鉴
人工智能·制造