zoukankan      html  css  js  c++  java
  • opencv中对图片的二值化操作并提取特定颜色区域

    一、最近因为所在的实习公司要求用opencv视觉库来写一个对图片识别并提取指定区域的程序。看了很多资料,只学会了皮毛,下面附上简单的代码。运行程序之前需要安装opencv库,官网地址为:https://opencv.org/。直接下载安装包到本地,解压即可。本人的opencv版本为24.10 。集成环境是visual studio 2013。

     1 #include<opencv2/core/core.hpp>  
     2 #include<opencv2/highgui/highgui.hpp>  
     3 #include<opencv2/imgproc/imgproc.hpp>  
     4 #include <vector>
     5 #include<iostream>  
     6 #include<string>
     7 
     8 using namespace std;
     9 using namespace cv;
    10 //bgr图像  
    11 Mat bgr;
    12 //HSV图像  
    13 Mat hsv;
    14 //色相  
    15 int hmin = 0;//h分量取下限
    16 int hmax = 180;//h分量取上限
    17 int h_Max = 180; //h分量可取的最大值
    18 //饱和度  
    19 int smin = 0;//s分量取下限
    20 int smax = 255;//s分量取上限
    21 int s_Max = 255;//s分量可取的最大值
    22 //亮度  
    23 int vmin = 0;//v分量取下限
    24 int vmax = 255;//v分量取上限
    25 int v_Max = 255;//v分量可取的最大值
    26 
    27 string windowName = "src";
    28 
    29 string dstName = "dst";
    30 //输出图像  
    31 Mat dst;
    32 //回调函数  
    33 void callBack(int, void*)
    34 {
    35     //输出图像分配内存  
    36     dst = Mat::zeros(bgr.size(), bgr.type());
    37      
    38     Mat mask;
    39     inRange(hsv, Scalar(hmin, smin, vmin), Scalar(hmax, smax, vmax), mask);
    40      
    41     for (int r = 0; r < bgr.rows; r++)
    42     {
    43         for (int c = 0; c < bgr.cols; c++)
    44         {
    45             if (mask.at<uchar>(r, c) == 255)
    46             {
    47                 dst.at<Vec3b>(r, c)[0] = bgr.at<Vec3b>(r, c)[0];
    48                 dst.at<Vec3b>(r, c)[1] = bgr.at<Vec3b>(r, c)[1];
    49                 dst.at<Vec3b>(r, c)[2] = bgr.at<Vec3b>(r, c)[2];
    50             }
    51         }
    52     }
    53     imshow("mask", mask);
    54     //输出图片
    55     imshow("dst", dst);
    56 }
    57 int main()
    58 {
    59     //输入图片 
    60     Mat srcImage = imread("C:\Users\Administrator\Desktop\0001.jpg");
    61     if (!srcImage.data){
    62         cout << "图片读取失败" << endl;
    63         system("pause");
    64         return -1;
    65     }
    66     imshow(windowName, srcImage);
    67     bgr = srcImage;
    68     //颜色空间转换  
    69     cvtColor(bgr, hsv, COLOR_BGR2HSV);
    70     //定义输出图像的显示窗口  
    71     namedWindow(dstName, 0);
    72     //调节色相 H  
    73     createTrackbar("hmin", dstName, &hmin, h_Max, callBack);
    74     createTrackbar("hmax", dstName, &hmax, h_Max, callBack);
    75     //调节饱和度 S  
    76     createTrackbar("smin", dstName, &smin, s_Max, callBack);
    77     createTrackbar("smax", dstName, &smax, s_Max, callBack);
    78     //调节亮度 V  
    79     createTrackbar("vmin", dstName, &vmin, v_Max, callBack);
    80     createTrackbar("vmax", dstName, &vmax, v_Max, callBack);
    81     callBack(0, 0);
    82     waitKey(0);
    83     return 0;
    84 }
  • 相关阅读:
    mfc中的_T
    zmq的send
    c++内存相关函数
    如何运行linux shell程序
    Dockfile中的命令如何在.sh中执行
    Linux 错误: $' ': command not found
    实战ZeroMQ的PUSH/PULL推拉模式
    Servlet笔记
    进程控制块(PCB)
    Makefile规则介绍
  • 原文地址:https://www.cnblogs.com/intruder/p/11965825.html
Copyright © 2011-2022 走看看