亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

使用C#的aforge類庫識別驗證碼實例

2020-01-24 02:31:11
字體:
來源:轉載
供稿:網友

時間過得真快啊,轉眼今年就要過去了,大半年都沒有寫博客了,要說時間嘛,花在泡妹子和搞英語去了,哈哈。。。前幾天老大問我

怎么這么長時間都沒寫博客了,好吧,繼續堅持,繼續分享我的心得體會。

  這個系列我們玩玩aforge.net,套用官方都話就是一個專門為開發者和研究者基于C#框架設計的,這個框架提供了不同的類庫和關于類庫的

資源,還有很多應用程序例子,包括計算機視覺與人工智能,圖像處理,神經網絡,遺傳算法,機器學習,機器人等領域,這個系列研究的重點

就是瞎幾把搞下AForge.Imaging這個命名空間下面的東東,下載網址:http://www.aforgenet.com/framework/downloads.html

    對了,不知道有多少公司是用得仕卡作為員工的福利卡,我們公司就是這樣的,每個月公司都會充值一些money,然后我們這些屁碼農每個月15號就都開心的去看看發了多少。

上去看了后,喲呵~ 還有個90年代的驗證碼,我想這年頭估計找到這樣驗證碼的網站已經不多了,如果懂一點圖像處理都話,這張驗證碼

跟沒有一個樣,謝謝。。。這篇我們看看怎么去識別它。

一: 驗證碼處理

1.  一般處理原則

    這種驗證碼為什么說跟沒有一樣,第一點:字體規范工整,第二點:不旋轉扭曲粘連,第三點:字體顏色單一,下面看處理步驟。

這里要注意的是,aforge只接受像素格式為24/32bpp的像素格式圖片,所以處理前,先進行格式轉化。

復制代碼 代碼如下:

//轉化圖片像素格式
            var bnew = new Bitmap(b.Width, b.Height, PixelFormat.Format24bppRgb);

            Graphics g = Graphics.FromImage(bnew);

            g.DrawImage(b, 0, 0);

            g.Dispose();

<1>圖片灰度化

這是圖像識別通常都要走的第一步,圖片灰度化有助于減少后續對rgb的計算量,同時也方便我們進行二值化,在aforge中我們有專門的類一步搞定,簡潔方便。

復制代碼 代碼如下:

            //灰度化
            b = new Grayscale(0.2125, 0.7154, 0.0721).Apply(b);

<2>二值化

  二值化顧名思義就是二種值,比如非白即黑,非黑即白,那么白和黑的標準就需要提供一個閾值,大于或者小于怎么樣,在aforge同樣也有相似的類進行處理

復制代碼 代碼如下:

            //二值化
            b = new Threshold(50).Apply(b);

<3> 去噪點

  從上面的圖片可以發現有很多紅點點,搞得像皮膚病一樣,仔細觀察可以看到這種噪點具有獨立,體積小的特征,所以判斷的標準就是如果圖中某個區塊的大小在我設置的閾值內,就將其去掉,同樣也有專門的類進行處理。

復制代碼 代碼如下:

            //去噪點
            new BlobsFiltering(1, 1, b.Width, b.Height).Apply(b);

  這里具體怎么傳遞參數,后續系列會慢慢解讀。

<4>切割圖片

   切圖片的好處在于我們需要知道真正要識別的元素的有效范圍是多大,同時也方便我們將這些圖片作為模板保存下來。

代碼如下:

復制代碼 代碼如下:

/// <summary>
        /// 按照 Y 軸線 切割
        /// (丟棄等于號)
        /// </summary>
        /// <param name="?"></param>
        /// <returns></returns>
        public List<Bitmap> Crop_Y(Bitmap b)
        {
            var list = new List<Bitmap>();

            //統計每一列的“1”的個數,方便切除
            int[] cols = new int[b.Width];

            /*
             *  縱向切割
             */
            for (int x = 0; x < b.Width; x++)
            {
                for (int y = 0; y < b.Height; y++)
                {
                    //獲取當前像素點像素
                    var pixel = b.GetPixel(x, y);

                    //說明是黑色點
                    if (pixel.R == 0)
                    {
                        cols[x] = ++cols[x];
                    }
                }
            }

            int left = 0, right = 0;

            for (int i = 0; i < cols.Length; i++)
            {
                //說明該列有像素值(為了防止像素干擾,去噪后出現空白的問題,所以多判斷一下,防止切割成多個)
                if (cols[i] > 0 || (i + 1 < cols.Length && cols[i + 1] > 0))
                {
                    if (left == 0)
                    {
                        //切下來圖片的橫坐標left
                        left = i;
                    }
                    else
                    {
                        //切下來圖片的橫坐標right
                        right = i;
                    }
                }
                else
                {
                    //說明已經有切割圖了,下面我們進行切割處理
                    if ((left > 0 || right > 0))
                    {
                        Crop corp = new Crop(new Rectangle(left, 0, right - left + 1, b.Height));

                        var small = corp.Apply(b);

                        //居中,將圖片放在20*50的像素里面

                        list.Add(small);
                    }

                    left = right = 0;
                }
            }

            return list;
        }

        /// <summary>
        /// 按照 X 軸線 切割
        /// </summary>
        /// <param name="b"></param>
        /// <returns></returns>
        public List<Bitmap> Crop_X(List<Bitmap> list)
        {
            var corplist = new List<Bitmap>();

            //再對分割的圖進行上下切割,取出上下的白邊
            foreach (var segb in list)
            {
                //統計每一行的“1”的個數,方便切除
                int[] rows = new int[segb.Height];

                /*
                 *  橫向切割
                 */
                for (int y = 0; y < segb.Height; y++)
                {
                    for (int x = 0; x < segb.Width; x++)
                    {
                        //獲取當前像素點像素
                        var pixel = segb.GetPixel(x, y);

                        //說明是黑色點
                        if (pixel.R == 0)
                        {
                            rows[y] = ++rows[y];
                        }
                    }
                }

                int bottom = 0, top = 0;

                for (int y = 0; y < rows.Length; y++)
                {
                    //說明該行有像素值(為了防止像素干擾,去噪后出現空白的問題,所以多判斷一下,防止切割成多個)
                    if (rows[y] > 0 || (y + 1 < rows.Length && rows[y + 1] > 0))
                    {
                        if (top == 0)
                        {
                            //切下來圖片的top坐標
                            top = y;
                        }
                        else
                        {
                            //切下來圖片的bottom坐標
                            bottom = y;
                        }
                    }
                    else
                    {
                        //說明已經有切割圖了,下面我們進行切割處理
                        if ((top > 0 || bottom > 0) && bottom - top > 0)
                        {
                            Crop corp = new Crop(new Rectangle(0, top, segb.Width, bottom - top + 1));

                            var small = corp.Apply(segb);

                            corplist.Add(small);
                        }

                        top = bottom = 0;
                    }
                }
            }

            return corplist;
        }

<5> 圖片精處理

  這里要注意的是,比如數字“2”,切除上下左右的空白后,再加上噪點的干擾,不一定每次切下來的圖片大小都一樣,所以這里為了方便更好的識別,我們需要重置下圖片的大小,并且將“數字2”進行文字居中。

復制代碼 代碼如下:

/// <summary>
        /// 重置圖片的指定大小并且居中
        /// </summary>
        /// <param name="list"></param>
        /// <returns></returns>
        public List<Bitmap> ToResizeAndCenterIt(List<Bitmap> list, int w = 20, int h = 20)
        {
            List<Bitmap> resizeList = new List<Bitmap>();


            for (int i = 0; i < list.Count; i++)
            {
                //反轉一下圖片
                list[i] = new Invert().Apply(list[i]);

                int sw = list[i].Width;
                int sh = list[i].Height;

                Crop corpFilter = new Crop(new Rectangle(0, 0, w, h));

                list[i] = corpFilter.Apply(list[i]);

                //再反轉回去
                list[i] = new Invert().Apply(list[i]);

                //計算中心位置
                int centerX = (w - sw) / 2;
                int centerY = (h - sh) / 2;

                list[i] = new CanvasMove(new IntPoint(centerX, centerY), Color.White).Apply(list[i]);

                resizeList.Add(list[i]);
            }

            return resizeList;
        }

其實精處理后,這些圖片就可以作為我們的模板庫的圖片了,可以將每張模板圖都標記下具體的數字,后續我們再遇到時,計算下其相似度就可以了,下面就是已經制作好的模板。

<6> 模板匹配識別

  既然模板圖片都制作好了,一切都差不多水到渠成了,下次來的驗證碼我都切好后做成精圖片后跟模板進行匹配,在afroge里面

有一個ExhaustiveTemplateMatching,專門用來進行模板匹配用的,很方便。

復制代碼 代碼如下:

 ExhaustiveTemplateMatching templateMatching = new ExhaustiveTemplateMatching(0.9f);

這里的0.9f就是設定的閾值,只有大于0.9的閾值,我才認為該模板與目標圖片相似,然后在所有大于0.9的相似度中取到最大的一個作為

我們最后識別的圖像。

復制代碼 代碼如下:

var files = Directory.GetFiles(Environment.CurrentDirectory + "//Template//");

            var templateList = files.Select(i => { return new Bitmap(i); }).ToList();
            var templateListFileName = files.Select(i => { return i.Substring(30, 1); }).ToList();

            var result = new List<string>();

            ExhaustiveTemplateMatching templateMatching = new ExhaustiveTemplateMatching(0.9f);

            //這里面有四張圖片,進行四張圖的模板匹配
            for (int i = 0; i < list.Count; i++)
            {
                float max = 0;
                int index = 0;

                for (int j = 0; j < templateList.Count; j++)
                {
                    var compare = templateMatching.ProcessImage(list[i], templateList[j]);

                    if (compare.Length > 0 && compare[0].Similarity > max)
                    {
                        //記錄下最相似的
                        max = compare[0].Similarity;
                        index = j;
                    }
                }

                result.Add(templateListFileName[index]);
            }

最后的效果還是不錯的,識別率基本100%吧。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品亚洲一区二区三区| 国产亚洲综合久久| 久久精品最新地址| 77777少妇光屁股久久一区| 久久99国产精品自在自在app| 亚洲综合中文字幕68页| 亚洲精品电影网在线观看| 91九色蝌蚪国产| 亚洲无亚洲人成网站77777| 久久精品国产69国产精品亚洲| 九九久久精品一区| 欧美性猛交xxxx乱大交极品| 人人做人人澡人人爽欧美| 久久精品国产视频| 在线精品高清中文字幕| 久久精彩免费视频| 亚洲美女在线看| 欧美有码在线观看| 九九热这里只有精品6| 亚洲精品国产综合区久久久久久久| 91嫩草在线视频| 7777kkkk成人观看| 欧美在线视频一二三| 亚洲欧美综合图区| 日韩综合视频在线观看| 欧美中文字幕视频| 91精品国产沙发| 国产精品久久久久福利| 国产精品69久久| 亚洲欧美制服第一页| 91av在线视频观看| 欧日韩不卡在线视频| 日韩免费在线播放| 亚洲第一区中文字幕| 亚洲人高潮女人毛茸茸| 日韩电影免费观看在线| 亚洲国产精品久久久久秋霞蜜臀| 超碰91人人草人人干| 欧美激情图片区| 亚洲天堂男人天堂| 青青草原一区二区| 热久久美女精品天天吊色| 亚洲欧美国产精品va在线观看| 91免费电影网站| 91久久国产综合久久91精品网站| 国产在线观看不卡| 性欧美长视频免费观看不卡| 亚洲精选中文字幕| 国产欧美在线视频| 日韩暖暖在线视频| 在线播放精品一区二区三区| 欧美亚洲在线播放| 日韩在线视频国产| 国产91精品久久久久久久| 91社区国产高清| 日韩毛片中文字幕| 一区二区三区四区视频| 欧美黄网免费在线观看| 国产精品女视频| 国产丝袜一区二区三区| 午夜精品一区二区三区视频免费看| 亚洲欧美日韩国产中文专区| 最新的欧美黄色| 国产精品国产福利国产秒拍| 欧美电影院免费观看| 国模精品视频一区二区| 国产欧美va欧美va香蕉在| 亚洲国产精品一区二区久| 中文字幕国产亚洲2019| 97视频在线免费观看| 日本一欧美一欧美一亚洲视频| 欧美日韩一区二区精品| www亚洲欧美| 久久在线观看视频| 国产欧美一区二区| 国产成人精品在线观看| 97碰碰碰免费色视频| 国产aⅴ夜夜欢一区二区三区| 性色av一区二区三区免费| 亚洲国产精品大全| 欧美精品性视频| 青草热久免费精品视频| 秋霞成人午夜鲁丝一区二区三区| 国产精品午夜国产小视频| 在线观看国产精品淫| 日韩成人av在线| 欧美一级淫片videoshd| 91精品国产成人| 欧美性猛交xxxx黑人| 亚洲精品视频播放| 欧美日韩免费区域视频在线观看| 97在线观看视频国产| 国产精品亚洲网站| 日本中文字幕成人| 日韩视频在线观看免费| 国产精品久久久久久久久影视| 亚洲精品理论电影| 国产91久久婷婷一区二区| 成人黄色网免费| 91色视频在线观看| 日本一本a高清免费不卡| 国产一区二区动漫| 欧美第一淫aaasss性| 久久99久久99精品中文字幕| 欧美专区在线视频| 98精品国产自产在线观看| 国产精品亚洲视频在线观看| 国产精品丝袜一区二区三区| 成人在线播放av| 亚洲第一区在线观看| 亚洲欧美三级在线| 欧美黑人性视频| 成人免费看黄网站| 欧美日韩成人在线播放| 欧美精品xxx| 精品视频在线观看日韩| 国产福利视频一区| 国产精品激情av电影在线观看| 亚洲国产婷婷香蕉久久久久久| 国产精品久久久久影院日本| 久99九色视频在线观看| 日韩日本欧美亚洲| 国产精品久久久久久网站| 亚洲在线观看视频| 777国产偷窥盗摄精品视频| 日韩欧美精品中文字幕| 国产国语刺激对白av不卡| 粗暴蹂躏中文一区二区三区| 国外成人性视频| 亚洲电影免费观看高清完整版| 亚洲肉体裸体xxxx137| 日韩精品高清视频| 国产丝袜精品视频| 亚洲人成电影网站色www| 国产成人一区二| 久久亚洲精品成人| 久久久久久久91| 国产精品视频男人的天堂| 日韩午夜在线视频| 国产精品久久久久久av| 国外色69视频在线观看| 欧美制服第一页| 国产精品扒开腿做| 在线成人激情视频| 亚洲嫩模很污视频| 亚洲欧美精品中文字幕在线| 国产一区二区欧美日韩| 亚洲成av人片在线观看香蕉| 午夜精品视频网站| 97精品久久久| 欧美一区二区三区免费视| 国产美女直播视频一区| 国产成人高清激情视频在线观看| 国产91精品不卡视频| 亚洲高清久久网| 欧美精品999| 亚洲精品91美女久久久久久久| 亚洲欧美另类国产| 国产精品一区二区久久精品| 国产精品aaaa| 亚洲综合小说区| 国产精品福利片| 这里只有视频精品| 91日本在线视频|