Opencv学习记录:函数Size()、Rect()、Mat.type()、minMaxLoc()

Size()函数

对于一个目标Mat Image来讲,若想Image的像素矩阵大小是m×n的,即有m行n列,实现方法如下:

Image(Size(n,m),Type);      // 即先列数再行数
Image = zeros(n, m, Type);   // 即先行数再列数

Rect()函数

当使用 Rect() 选取 ROI 时,使用方法如下:

Rect(x0, y0, width, height);   //此时的height是行数,width是列数

Mat数据类型对照表(Mat.type())

Mat存在各种类型,其中Mat有一个type()函数可以返回该Mat的类型。类型表示了矩阵中元素的类型以及矩阵的通道个数,它是一系列的预定义的常量,其命名规则为CV_(位数)+(数据类型)+(通道数)。具体的有以下值:

CodeC1C2C3C4
CV_8U081624
CV_8S191725
CV_16U2101826
CV_16S3111927
CV_32S4122028
CV_32F5132129
CV_64F6142230

minMaxLoc()函数

minMaxLoc()函数可以在一幅图像上查找最大最小值及其位置坐标。
函数声明:

void minMaxLoc(InputArray src, double* minVal, double* maxVal=0, Point* minLoc=0, Point* maxLoc=0, InputArray mask=noArray() )

参数:最大值maxVlaue、最小值minValue、最大值位置maxLoc、最小值位置minLoc等。
(一些不需要的参数,在调用时直接设置为0即可)。最后一个参数是mask,默认为noArray()。
一个例子:

int main()
{
    Mat img = imread("D:/YHImage/lena.jpg",0);

    Mat mask(img.rows, img.cols, img.type(), Scalar::all(0));
    mask(Rect(150, 50, 100, 100)) = 255 ;//设定搜索区域
    imshow("mask", mask);

    imshow("img", img);
    double maxv;
    minMaxLoc(img, 0, &maxv, 0, 0, mask);
    cout << "maxvalue = " << maxv << endl;
    waitKey();
    return 0;
}
### OpenCV `cv::Mat` 类的背景 `cv::Mat` 是 OpenCV 库中最基础也是最重要的数据结构之一,主要用于表示图像和矩阵。该类支持多种操作,包括但不限于算术运算、逻辑运算以及各种变换。 ### 关于 `back()` 方法的理解 对于 `cv::Mat` 并不存在名为 `back()` 的成员函数或方法[^1]。这可能是对 C++ STL 容器(如 vector 或 deque)中同名方法的一种误解,在这些容器里它用来访问最后一个元素。然而,在 `cv::Mat` 上并没有这样的功能实现。 通常情况下,如果想要获取 `cv::Mat` 对象的最后一行或者最后一列,则可以通过索引来完成: ```cpp // 获取最后一行 cv::Mat lastRow = mat.row(mat.rows - 1); // 获取最后一列 cv::Mat lastCol = mat.col(mat.cols - 1); ``` 另外一种可能性是指向了错误的方法名称或者是特定上下文中定义的一个自定义辅助函数而非官方 API 提供的功能。 为了更好地帮助理解如何操作 `cv::Mat` ,这里给出几个常见的例子来展示其灵活性与强大之处: #### 创建并初始化一个全白图片 ```cpp #include <opencv2/opencv.hpp> int main(){ // 创建大小为 (100x100),类型为 CV_8UC1 (单通道灰度),初始值设为最大亮度(白色) cv::Mat whiteImage(cv::Size(100, 100), CV_8UC1, cv::Scalar(255)); // 显示窗口显示此图像 cv::imshow("White Image", whiteImage); cv::waitKey(0); } ``` #### 复制矩形区域内的像素到另一个相同尺寸的位置上 ```cpp #include <opencv2/opencv.hpp> int main(){ // 初始化两张不同颜色填充的小图 cv::Mat srcImg(cv::Size(100, 100), CV_8UC1, cv::Scalar(0)), dstImg; srcImg.setTo(cv::Scalar(255)); // 定义要复制的目标区间的左上角坐标及宽高范围 cv::Rect roi(Point(10, 10), Size(30, 30)); // 将源图roi部分赋给目标图相应位置 srcImg(roi).copyTo(dstImg(roi)); // 展示效果对比 cv::imshow("Source Image", srcImg); cv::imshow("Destination Image", dstImg); cv::waitKey(0); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

视觉闫小亘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值