vc++图片平滑代码_OpenCV代码系列_05

继续分享OpenCV高级代码实操系列。

b700f04e3b5e40dfad2afd03031a521d.png

实现简单的图像分割

/*

*

* 功能:通过灰度图做简单的图像分割

*

*/

#include

#include

#include

int main(int argc,char* argv[]){

//--1.读入图片

cv::Mat image = cv::imread("horses.jpg");

//--2.转换灰度图

cv::Mat gray;

cv::cvtColor(image,gray,CV_RGB2GRAY);

//--3.二值化灰度图

cv::Mat dst;

cv::threshold(gray,dst,60,255,cv::THRESH_BINARY_INV);

//平滑处理(平滑/高斯平滑两种)

//cv::blur(dst,dst,cv::Size(3,3));

//cv::GaussianBlur(dst,dst,cv::Size(3,3),0,0); //高斯平滑

//形态学操作(此处效果不好,只用来展示加强理解)

//cv::erode(dst,dst,cv::Mat(),cv::Point(-1,-1),1);

//cv::dilate(dst,dst,cv::Mat(),cv::Point(-1,-1),1);

//--4.显示结果(原图和结果图显示在一起)

const int width = image.cols;

const int height = image.rows;

cv::Mat show_image(cv::Size(2*width,height),CV_8UC3);

//将image拷贝到显示图片指定位置

image.copyTo(show_image(cv::Rect(0,0,width,height)));

//将dst转换为3通道,使得show_image和dst通道数一致,或者使用convertTo()函数做操作

cv::cvtColor(dst,dst,CV_GRAY2RGB);

//将dst拷贝image指定位置

dst.copyTo(show_image(cv::Rect(width,0,width,height)));

//显示

cv::imshow("show",show_image);

cv::waitKey(0);

}

ebfc8ed51793115f5c99af051cb20f3a.png

注:喜欢请留言,共同学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值