【OpenCV学习之路】(1)实现在图像上画对角线和分割之一

本文介绍使用OpenCV库实现方形图片的对角线切割方法。通过代码演示如何画出两条对角线并实现图像分割,同时对比了不同方式设置像素的方法,并使用line函数快速完成画线。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

看到了 这位老哥 @冰不语 的文章
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));
    else
        resize(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));
    else
        resize(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);
            else
                dst2.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)) 的区别



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值