zoukankan      html  css  js  c++  java
  • 数码管数字提取与识别(附源码)

    第一部分(数字区域提取)

    首先,准备一张待提取数字的图片(存放路径与当前工程的主程序一致)

    提取原理:颜色空间由RGB转换到HSV空间下,通过对H、S、V分别设置上下限显示出当前图片,直到选取到最佳的数字区域。

     上图为数字区域提取效果,记录下当前的H、S、V的上下限。

    下面为这一部分的程序源码

    #include<opencv2/core.hpp>
    #include<opencv2/highgui.hpp>
    #include<opencv2/imgproc.hpp>
    using namespace cv;
    #include<iostream>
    #include<string>
    using namespace std;
    //输入图像
    Mat img;
    //灰度值归一化
    Mat bgr;
    //HSV图像
    Mat hsv;
    //色相
    int hmin = 0;
    int hmin_Max = 360;
    int hmax = 180;
    int hmax_Max = 360;
    //饱和度
    int smin = 0;
    int smin_Max = 255;
    int smax = 255;
    int smax_Max = 255;
    //亮度
    int vmin = 106;
    int vmin_Max = 255;
    int vmax = 255;
    int vmax_Max = 255;
    
    //显示原图的窗口
    string windowName = "src";
    //输出图像的显示窗口
    string dstName = "dst";
    //输出图像
    Mat dst;
    //回调函数
    void callBack(int, void*)
    
    {
    
        //输出图像分配内存
        dst = Mat::zeros(img.size(), img.type());
        //掩码
        Mat mask;
        inRange(hsv, Scalar(hmin, smin, vmin), Scalar(hmax, smax, vmax), mask);
        //掩模到原图的转换
        imshow("mask", mask);
        for (int r = 0; r < bgr.rows; r++)
        {
            for (int c = 0; c < bgr.cols; c++)
            {
                if (mask.at<uchar>(r, c) == 255)
                {
                    dst.at<Vec3b>(r, c) = bgr.at<Vec3b>(r, c);
                }
            }
        }
    
        //输出图像
        imshow(dstName, dst);
        //保存图像
        //dst.convertTo(dst, CV_8UC3, 255.0, 0);
        imwrite("HSV_inRange.jpg", dst);
    }
    
    int main(int argc, char** argv)
    {
        //输入图像
        img = imread("40.jpg");
        if (!img.data || img.channels() != 3)
            return -1;
        imshow(windowName, img);
        bgr = img.clone();
        //颜色空间转换
        cvtColor(bgr, hsv, CV_BGR2HSV);
        //cout << hsv << endl;
        //定义输出图像的显示窗口
        namedWindow(dstName, WINDOW_GUI_EXPANDED);
        //调节色相 H
        createTrackbar("hmin", dstName, &hmin, hmin_Max, callBack);
        createTrackbar("hmax", dstName, &hmax, hmax_Max, callBack);
        //调节饱和度 S
        createTrackbar("smin", dstName, &smin, smin_Max, callBack);
        createTrackbar("smax", dstName, &smax, smax_Max, callBack);
        //调节亮度 V
        createTrackbar("vmin", dstName, &vmin, vmin_Max, callBack);
        createTrackbar("vmax", dstName, &vmax, vmax_Max, callBack);
        callBack(0, 0);
        waitKey(0);
        return 0;
    
    }

    下一篇为数字的分割

    ·

  • 相关阅读:
    arm gdbserver armlinuxgdb
    建立非模态对话框与在线程中建立非模态对话框
    AutoLock C++
    Uboot bootcmd 和bootargs
    SetRegistryKey
    飞凌OK6410 uboot支持网络
    uboot 源码修改 bootcmd,IP ,BOOTARGS等参数
    TextBox(richTextBox) 光标和滚动条到文本末尾
    Windbg中使用查找内存并设置访问断点
    opencv EXAMPLES 编译 VS2010 (C++)
  • 原文地址:https://www.cnblogs.com/victorywr/p/12178367.html
Copyright © 2011-2022 走看看