【OpenCV入门学习笔记1】:Mat对象的指针操作和掩膜操作

b站:https://www.bilibili.com/video/BV1uW411d7Wf?p=5
下面是我在b站上看视频学习的笔记和操作的示例代码
在这里插入图片描述

实例代码

#include<opencv2/opencv.hpp>
#include<iostream>
#include<math.h>

using namespace cv;

int main(int argc, char** argv)
{
	Mat src, dst;
	src = imread("E:/picture/pic_cv/pic.jpg");
	if (!src.data) {
		printf("Could not load image...\n");
		return -1;
	}
	namedWindow("input image", WINDOW_AUTOSIZE);
	imshow("input image", src);

	//-------------------------------------------------------------------------
	//----------------------【自定义掩膜操作过程】-----------------------------
	//------------------------------------------------------------------------
	int cols = src.cols  * src.channels();//RGB图像是三通道图像
	int offsetx = src.channels();//左右漂移多少是通道数决定的
	int rows = src.rows;
	dst = Mat::zeros(src.size(), src.type());//对dst图像矩阵初始化为src的大小和类型  //一定要注意初始化!!
	for (int row = 1; row < (rows - 1); row++) {
		const uchar* previous = src.ptr<uchar>(row - 1);
		uchar* current = src.ptr<uchar>(row);
		const uchar* next = src.ptr<uchar>(row + 1);

		uchar* output = dst.ptr<uchar>(row);//创建指针指向dst的row行
		for (int col = offsetx; col < cols - offsetx; col++)
		{
			//方法一:这样出来的图像跟麻脸一样,因为有的数据超过了255,或小于0,造成溢出
			//output[col] = 5 * current[col] - (current[col - offsetx] + current[col + offsetx] + previous[col] + next[col]);
		     //方法二:用saturate_cast(饱和函数)函数 处理溢出数据
			output[col] = saturate_cast<uchar>(5 * current[col] - (current[col - offsetx] + current[col + offsetx] + previous[col] + next[col]));
		}
	}
	//-------------------------------------------------------------------------
	//----------------------【end1】-----------------------------
	//------------------------------------------------------------------------
	namedWindow("contrast image demo 1", WINDOW_AUTOSIZE);
	imshow("contrast image demo 1", dst);


	//-------------------------------------------------------------------------
	//----------------------【调用filter2D函数操作】-----------------------------
	//------------------------------------------------------------------------

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

	namedWindow("contrast image demo 2", WINDOW_AUTOSIZE);
	imshow("contrast image demo 2", dst);


	waitKey(0);


	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值