栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

Opencv图像处理之轮廓外背景颜色改变

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Opencv图像处理之轮廓外背景颜色改变

本文实例为大家分享了Opencv轮廓外背景颜色改变的具体代码,供大家参考,具体内容如下

自行学习弄得简单代码,使用了图像中的轮廓发现以及提取,再绘制出来,改变轮廓外的像素

首先,头文件,写的比较多,没用的可以自己去除

#include  
#include 
#include"opencv2/imgproc/imgproc.hpp" 
#include 
#include 
#include  

//命名空间
using namespace cv;
using namespace std;
//图片数据名字,原图,灰度图,二值图,直方图
Mat src,src_gray,dst,src_equ;
//声明一个函数,建立滑动条
static void on_trackbar(int, void*);

主函数

int main(int argc, char** argv)
{
  //图片读入
  src = imread("D:\PersonWork\OpenCV\program\picture data\0400.bmp");

  //判断是否存在
  if (!src.data)
  {
    cout << "Image no find,error!" << endl;
  }

  //灰度转换
  cvtColor(src,src_gray, CV_BGR2GRAY);

  //原图窗口,显示
  namedWindow("原图", 0);
  imshow("原图", src);

  //二值图窗口
  namedWindow("二值图", 0);

  // 滑动条  
  int nThreshold = 120;
  createTrackbar("graybar", "二值图", &nThreshold, 255,on_trackbar); 
  on_trackbar(nThreshold, 0);

  waitKey(0);
  destroyWindow("原图");
  destroyWindow("二值图");
  destroyWindow("result");
  return 0;
}

回调函数

static void on_trackbar(int pos, void*)
{

  //二值化
  threshold(src_gray, dst, pos, 255, CV_THRESH_BINARY);
  imshow("二值图", dst);

  //直方均匀化
  equalizeHist(dst, src_equ);

  //识别轮廓
  vector> contours;
  vector hierarchy;
  findContours(src_equ, contours, hierarchy, CV_RETR_CCOMP, CV_CHAIN_APPROX_NONE);    

  //轮廓数量,可没有
  //int len=contours.size();
  //cout<(j);
    for(int i=0;i

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/62397.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号