本文主要是介绍【OpenCV学习之路】(1)实现在图像上画对角线和分割之一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
看到了 这位老哥 @冰不语 的文章
OpenCV实践之路——方形图片对角线切割
同时写代码的时候也参考了这位老哥 @yqtaowhu 的文章
Opencv学习笔记(三)–图像处理的基本操作
于是我也想自己尝试一下把图片画一条对角线
在实现了画一条左上角到右下角的对角线后,我又尝试画一条从右上角到左下角的对角线。
注意:此次实现是以正方形图为模版
Talk is cheap,show you my code;
#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\imgproc\imgproc.hpp>
using namespace cv;
int main()
{Mat srcImage = imread("04.jpg",0);//以下判断把矩形兔转换成正方形图if (srcImage.rows > srcImage.cols)resize(srcImage, srcImage, Size(srcImage.cols, srcImage.cols));elseresize(srcImage, srcImage, Size(srcImage.rows, srcImage.rows));Mat dst1(srcImage.size(),CV_8UC1,Scalar::all(0)),dst2(srcImage.size(), CV_8UC1, Scalar::all(0));imshow("origin1", srcImage);for (int j = 0; j < srcImage.rows; j++){ for (int i = 0; i < srcImage.cols; i++){if (i == j) srcImage.at<uchar>(j, i) = 0;else if(j == (-i + srcImage.rows)) srcImage.at<uchar>(j, i) = 0;else srcImage.at<uchar>(j, i) = srcImage.at<uchar>(j, i);}} imshow("origin",srcImage);waitKey(0);return 0;
}
以下是代码运行结果截图:
然后其中有一点 个人颇为不明的是在遍历图像像素的时候
for (int j = 0; j < srcImage.rows; j++)
{ for (int i = 0; i < srcImage.cols; i++){if (i == j) srcImage.at<uchar>(Point(j, i)) = 0;//我的代码那里是 srcImage.at<uchar>(Point(j, i)) = 0;else if(j == (-i +srcImage.rows)) srcImage.at<uchar>(Point(j, i)) = 0;else srcImage.at<uchar>(Point(j, i)) = srcImage.at<uchar>(Point(j, i));}
}
多了一个Point(j,i)这个有什么用呢?因为也不影响运行结果,百度了一下
看到 @giantchen2010 这位老哥的文章 OpenCV参考手册之Mat类详解(三)
我的理解是:
Mat::at 这个类有多个重载,所以有没有Point它都能正确识别
然后就可以实现 把图像分割的效果
#include<opencv2\core\core.hpp>
#include<opencv2\highgui\highgui.hpp>
#include<opencv2\imgproc\imgproc.hpp>
using namespace cv;
int main()
{Mat srcImage = imread("04.jpg",0);//一下判断把矩形兔转换成正方形图if (srcImage.rows > srcImage.cols)resize(srcImage, srcImage, Size(srcImage.cols, srcImage.cols));elseresize(srcImage, srcImage, Size(srcImage.rows, srcImage.rows));Mat dst0(srcImage.size(), CV_8UC1, Scalar::all(0)),dst1(srcImage.size(),CV_8UC1,Scalar::all(0)),dst2(srcImage.size(), CV_8UC1, Scalar::all(0));imshow("原始图像", srcImage);for (int j = 0; j < srcImage.rows; j++){ for (int i = 0; i < srcImage.cols; i++){if (i == j) dst0.at<uchar>(Point(j, i)) = 0;else if(j == (-i +srcImage.rows)) dst0.at<uchar>(Point(j, i)) = 0;else dst0.at<uchar>(Point(j, i)) = srcImage.at<uchar>(Point(j, i));if (i >= j) dst1.at<uchar>(j, i) = srcImage.at<uchar>(j, i);elsedst2.at<uchar>(j, i) = srcImage.at<uchar>(j, i);}} imshow("对角线", dst0);imshow("左上角", dst1);imshow("右下角", dst2);waitKey(0);return 0;
}
运行效果:
而 @冰不语 在对原图画一条线的操作是用line函数实现的
步骤是:
1.用Point确定两个点的坐标
Point a = Point(0,0);
Point b = Point(srcImage.cols,srcImage.rows);//注意这里代表(x,y)所以图片的列才是x,行是y
2.再用line函数连接这两个点
line(srcImage, a, b, Scalar(255), 1);
就可以实现画线的效果了。
下次再补充长方形的图片,和彩色图片。
修改时间:2018/5/12 17:19:24
注意!!!
其实.at< uchar>(j, i) 和.at< uchar>(Point(j, i)) 两者还是有点区别的!!
详情请看(你可以先看完整篇文章再来看这个区别):
对于.at(j, i) 和.at(Point(j, i)) 的区别
这篇关于【OpenCV学习之路】(1)实现在图像上画对角线和分割之一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!