news 2026/1/28 3:01:39

图像的基本操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
图像的基本操作
读取图像
imread 函数用于读取图像,语法:Matimread(filename,flags);
filename:图像文件的路径。
flags:读取方式,常见取值如下:
值 含义 数值
IMREAD_UNCHANGED 保持图片原有格式不变 -1
IMREAD_GRAYSCALE 将图像调整为单通道的灰度图像0
IMREAD_COLOR 将图像调整为 3通道的BGR图像(默认值)1

例子:Mat img=imread("image.jpg",IMREAD_COLOR);

显示图像
namedWindow函数创建一个指定名称的窗口如果同名的窗口已经存在,函数不执行任何操作。
voidnamedWindow(constString&winname,intflags=WINDOW_AUTOSIZE);
winname:要创建的窗口名称
flags:窗口标志。常用值包括WINDOW_AUTOSIZE(自动调整窗口大小以适应图像)。

例子:namedWindow("原图",WINDOW_AUTOSIZE);

imshow函数用于显示图像,voidimshow(constString&winname,InputArray mat);
winname:显示窗口名称。
mat:要显示的图像。

例子:imshow("原图",img);

waitKey函数用于等待按键输入并获取返回值,intcv::waitKey(intdelay=0);
delay:等待时间(毫秒),默认值为0,表示无限等待。

例子:intkey=waitKey(0);

destroyWindow函数用于销毁指定窗口voiddestroyWindow(constString&winname);
winname:要销毁的窗口名称。
例子:destroyWindow("原图");
destroyAllWindows 函数用于销毁所有已创建的窗口:voidcv::destroyAllWindows();

例子:destroyAllWindows();

保存图像
imwrite函数用于将图像保存到文件
boolcv::imwrite(constString&filename,InputArray img,conststd::vector<int>&
params=std::vector<int>());
filename:保存图像的完整路径名。路径+文件名+文件扩展名
img:要保存的图像。
params:可选的保存参数。
返回值 :保存成功时返回true,否则返回false

例子:boolsuccess=imwrite("output.jpg",img);

Scalar标量
ScalarOpenCV中的一个结构体,代表标量scalar)。
typedef structScalar{
doubleval[4];
}Scalar;

例子:MatM(7,7,CV_32FC2,Scalar(1,3));

图像窗口滑动条
图像窗口滑动条,顾名思义,就是在显示图像的窗口中创建一个可以通过滑动改变数值的滑动条。 在OpenCV 4 中,可以通过createTrackbar()函数在显示图像的窗口上创建滑动条。
例子:
intcv::createTrackbar(
constString&trackbarname,//滑动条名称
constString&winname,//创建滑动条的图像窗口名称
int *value,//滑动条位置值的指针
intcount,//滑动条的最大值,默认是0
TrackbarCallback onChange=0,//滑动条改变时调用的回调函数
void *userdata=0//传递给回调函数的额外数据,默认为`NULL
);
voidFoo(intpos,void *userdata);
/*
○ pos是滑块的当前位置值。

○ userdata是用户自定义数据。此参数为NULL,则不会调用回调函数,仅更新滑块数值。*/

分离通道
多通道矩阵为例,使用OpenCV提供的split函数。
//将多通道矩阵分离为多个单通道矩阵。

voidsplit(constMat&src,std::vector<Mat>&mv);

合并通道
voidmerge(constMat*mv,size_tcount,OutputArray dst);

voidmerge(conststd::vector<Mat>&mv,Mat&dst);

获得Mat中某一区域的值
使用成员函数row(i)col(j)可以得到矩阵的第i行或第j列。
intr=1;
intc=0;
//矩阵的第r
Mat nr=mat.row(r);
//矩阵的第c
Mat nc=mat.col(c);
Range(intstart,intend);//该序列为左闭右开,即[start, end)
使用成员函数rowRangecolRange可以得到矩阵的连续行或连续列。
rowRange(intstart,intend);
colRange(intstart,intend);
需要特别注意的是,成员函数rowcolrowRangecolRange返回的矩阵其实是指向原矩阵的。使用成员函数 clonecopyTo 可以复制矩阵区域的内容。
matrix.rowRange(2,4).clone();
matrix.rowRange(2,4).copyTo(r_range);
使用Rect类获取矩形区域
OpenCV提供了一种简单的方式,使用Rect(RectRectangle的缩写,矩形的意思)构造一个矩形有多种方式。
Rect(intx,inty,intwidth,intheight);
Rect(intx,inty,Size.size);
Rect(Point2i&pt1,Point2i&pt2);
Mat roi1=matrix(Rect(Point(2,1),Point(4,3)));//左上角坐标和右下角坐标
Mat roi2=matrix(Rect(2,1,2,2));// x, y,宽度,高度
Mat roi3=matrix(Rect(Point(2,1),Size(2,2)));//左上角坐标和尺寸
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/21 6:20:46

Linly-Talker支持WebRTC实现实时远程交互

Linly-Talker 支持 WebRTC 实现实时远程交互 在虚拟主播与智能客服逐渐走入日常的今天&#xff0c;用户早已不再满足于“播放预录视频”的数字人。他们期待的是能听、会说、有表情、可互动的“真人级”对话体验。然而&#xff0c;传统系统受限于高延迟、单向输出和部署复杂等问…

作者头像 李华
网站建设 2026/1/22 15:13:09

Linly-Talker支持离线模式运行保护数据隐私

Linly-Talker&#xff1a;如何在本地构建一个真正“数据不出门”的数字人系统&#xff1f; 你有没有想过&#xff0c;当你对着智能音箱说出一句“我今天心情不好”&#xff0c;这句话不仅被听见&#xff0c;还可能被上传到某个遥远的数据中心&#xff1f;语音、语义、甚至情绪特…

作者头像 李华
网站建设 2026/1/25 22:45:32

Linly-Talker支持多人协同对话场景模拟

Linly-Talker支持多人协同对话场景模拟 在虚拟主播、AI客服、远程教育等应用日益普及的今天&#xff0c;用户对数字人系统的期待早已超越了“能说会动”的初级阶段。人们希望看到的是更自然、更具互动性的角色——不仅能听懂问题&#xff0c;还能与其他角色协作交流&#xff0c…

作者头像 李华
网站建设 2026/1/21 6:21:28

Linly-Talker被纳入高校人工智能课程实验项目

Linly-Talker&#xff1a;当数字人走进高校课堂 在南京某高校的AI实验课上&#xff0c;一名学生正对着摄像头提问&#xff1a;“Transformer的自注意力机制是怎么工作的&#xff1f;”屏幕中的“虚拟教授”微微点头&#xff0c;嘴唇精准地随着语音节奏开合&#xff0c;用清晰温…

作者头像 李华
网站建设 2026/1/19 7:57:07

Linly-Talker助力教育行业:智能讲师自动讲课不是梦

Linly-Talker助力教育行业&#xff1a;智能讲师自动讲课不是梦 在今天&#xff0c;越来越多的学校和教育机构开始面临一个共同挑战&#xff1a;如何在师资有限、教学资源分布不均的情况下&#xff0c;依然为学生提供高质量、个性化的学习体验&#xff1f;尤其是在远程教育、企业…

作者头像 李华
网站建设 2026/1/25 8:58:16

Linly-Talker集成Stable Diffusion实现虚拟形象定制

Linly-Talker集成Stable Diffusion实现虚拟形象定制 在直播带货、在线教育和智能客服日益普及的今天&#xff0c;人们不再满足于冷冰冰的文字回复或预录视频。用户期待的是有“人格”的交互体验——一个能听懂你说话、用你的声音回应、长着你喜欢的模样&#xff0c;并且随时在线…

作者头像 李华