opencv图像矩阵掩模

如上图所示,红色是中心像素,从上到下,从左到右对每个像素做同样的处理操作(上图的公式),得到最终结果就是对比度提高之后的输出图像Mat对象。

Mat图像在opencv中的存储形式一般是二维向量(可以理解为二维数组),即从(0,0)到(rows-1,cols-1)。

例如:RGB三通道彩色图的存储形式如下图:

例如:单通道灰度图的存储形式如下图:

那么我们在对像素点(row,col)进行掩模时需要注意,有些像素点不满足条件(二维向量图四边上的点,例如:(0,0),(0,1),(1,0)等)。

为了实现掩模操作,介绍几个函数:

1.获取图像像素指针

Mat.ptr<uchar>(int i=0) 获取像素矩阵的指针,索引i表示第几行,从0开始计行数。

获得当前行指针const uchar*  current= myImage.ptr<uchar>(row );

获取当前像素点P(row, col)的像素值 p(row, col) =current[col]

2.像素范围处理saturate_cast<uchar>

这个函数的功能是确保RGB值得范围在0~255之间

saturate_cast<uchar>(-100),返回 0

saturate_cast<uchar>(288),返回255

saturate_cast<uchar>(100),返回100

3.filter2D

我们可以通过opencv提供的函数定义掩膜,然后借助filter2D实现掩模

Mat kernel = (Mat_<char>(3,3) << 0, -1, 0, -1, 5, -1, 0, -1, 0);

filter2D( src, dst, src.depth(), kernel );

其中src与dst是Mat类型变量、src.depth表示位图深度,有32、24、8等。

 

首先,我们用第一种方法实现,不借助filter2D,代码如下:

#include <opencv2/opencv.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
using namespace cv;
int main()
{
    Mat img,dst;
    img=imread("C:/Users/Administrator/Pictures/jjskll.jpg");
    if(!img.data)
    {
        printf("read img failed...\n");
        return -1;
    }
    //namedWindow("displayImge",CV_WINDOW_AUTOSIZE); //创建一个新窗口
    imshow("inputImge",img);
 
   //每一列必须乘以通道数,因为有可能为彩色图像,列为灰度的三倍
   //由于最外围的一圈像素点没办法进行图像掩模(因为我们算的是模板中心点的值,
   //模板放在最边缘也算不出最外圈的掩模值)
   int cols = (img.cols-1)*img.channels();
   int offsetx = img.channels();
   int rows = img.rows;
   dst = Mat::zeros(img.size(),img.type());
   //row从1开始一直取到rows-2结束,表示不要对最外围的像素点掩模
   for (int row = 1; row < rows-1; row++)
   {
       
       //通过像素指针,拿到行指针
       const uchar* previous = img.ptr<uchar>(row-1);
       const uchar* current = img.ptr<uchar>(row);
       const uchar* next = img.ptr<uchar>(row+1);
       uchar* output = dst.ptr<uchar>(row);
       //col从3开始(第4列),因为彩色图像会有三个通道,最外围的像素点不掩模
       //每个像素有BGR三个通道
       //分别对每个像素的BGR都要分别进行掩模操作
       for (int col = offsetx; col < cols; col++)
       {
           output[col] = saturate_cast<uchar>(5* current[col] - (current[col-offsetx] + current[col+offsetx] + previous[col] + next[col]));
       }
   }
    namedWindow("contrast image demo",CV_WINDOW_AUTOSIZE);
    imshow("contrast image demo",dst);
    waitKey(0);
    return 0;
}



原图如下:

掩模后的效果如下:

上面是我们自己通过掩模的定义来实现的,接下来我们借助filter2D来实现

#include <opencv2/opencv.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
using namespace cv;
int main()
{
    Mat img,dst;
    img=imread("C:/Users/Administrator/Pictures/jjskll.jpg");
    if(!img.data)
    {
        printf("read img failed...\n");
        return -1;
    }
    //namedWindow("displayImge",CV_WINDOW_AUTOSIZE); //创建一个新窗口
    imshow("inputImge",img);

    double t = getTickCount();
    Mat kernel = (Mat_<char>(3, 3) << 0, -1, 0, -1, 5, -1, 0, -1, 0);
    filter2D(img, dst, img.depth(), kernel);
    double timeconsume = (getTickCount() - t) / getTickFrequency();
    printf("time consume %.2f", timeconsume);

    namedWindow("contrast image demo",CV_WINDOW_AUTOSIZE);
    imshow("contrast image demo",dst);
    waitKey(0);
    return 0;
}

运行效果和上面的完全一样,唯一的区别就是会输出运行时间

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: OpenCV 支持在图像上使用多个掩码。掩码可以用来控制图像上的操作,如缩放、剪切等。使用多个掩码可以在同一张图像上进行不同的操作,以获得更精细的控制。例如,您可以使用一个掩码对图像进行缩放,再使用另一个掩码对图像进行剪切。在 OpenCV 中,您可以通过函数 cv2.bitwise_and() 或 cv2.bitwise_or() 等来实现多个掩码的使用。 ### 回答2: 在OpenCV中,我们可以使用多个掩模(mask)来处理图像掩模是一个与原始图像具有相同大小的二进制图像,其中一些像素被标记为1,表示应该处理的区域,另一些像素被标记为0,表示应该忽略的区域。 在处理多个掩模时,我们可以使用逻辑运算符(如AND、OR、XOR)来组合它们,从而获得我们想要的结果。 例如,如果我们有两个掩模A和B,我们可以使用逻辑AND运算符将它们组合起来,得到一个新的掩模: cv2.bitwise_and(A, B, dst_mask) 这将使用A和B的逐个像素进行逻辑AND运算,生成一个新的掩模dst_mask。 类似地,我们可以使用逻辑OR运算符将两个掩模组合起来: cv2.bitwise_or(A, B, dst_mask) 这将使用A和B的逐个像素进行逻辑OR运算,生成一个新的掩模dst_mask。 我们还可以使用逻辑XOR运算符将两个掩模组合起来: cv2.bitwise_xor(A, B, dst_mask) 这将使用A和B的逐个像素进行逻辑XOR运算,生成一个新的掩模dst_mask。 通过使用多个掩模,我们可以更灵活地处理图像,根据需要选择不同的区域进行处理。这在图像分割、对象检测等任务中非常有用。 总结而言,OpenCV中的多个掩模允许我们使用逻辑运算符组合它们,以便根据需要对图像进行区域选择和处理。 ### 回答3: OpenCV是一个广泛使用的计算机视觉库,在处理图像和视频时非常有用。在OpenCV中,可以使用多个掩模(mask)来改变或限制对图像的操作。 多个掩模可能包括不同的形状和大小,用于选择图像的特定区域。例如,可以使用矩形、圆形或多边形的掩模来指定要处理的特定区域。 使用OpenCV的函数可以将掩模应用于图像上的任意位置。掩模作为一个矩阵,与输入图像具有相同的尺寸。通过将掩模的元素设置为非零值,可以选择要处理的像素。 在处理图像时,可以在图像上使用多个掩模。这样可以将不同的操作应用于不同的区域。例如,可以使用一个掩模来检测和处理图像中的人脸,使用另一个掩模来检测和处理图像中的车辆。 要使用多个掩模,可以首先创建一个与原始图像相同尺寸和数据类型的空白图像。然后,可以在空白图像上使用不同的掩模进行操作,将结果存储在相应的位置上。 使用多个掩模时,还可以通过将它们组合在一起来创建更复杂的选择。这可以通过逻辑运算(如AND、OR和NOT)来实现,以指定在哪些区域应用某个掩模。 总之,OpenCV允许我们在图像处理过程中使用多个掩模。这些掩模可以用于选择特定区域,并对这些区域进行不同的操作。通过灵活使用掩模,可以实现更精确和有针对性的图像处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Rookie Linux

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

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

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

打赏作者

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

抵扣说明:

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

余额充值