利用C#版OpenCV實現(xiàn)圓心求取實例代碼
前言
OpenCVSharp是OpenCV的.NET wrapper,是一名日本工程師開發(fā)的,項目地址為:https://github.com/shimat/opencvsharp。
該源碼是 BSD開放協(xié)議,BSD開源協(xié)議是一個給于使用者很大自由的協(xié)議。基本上使用者可以”為所欲為”,可以自由的使用,修改源代碼,也可以將修改后的代碼作為開源或者專有軟件再發(fā)布或商業(yè)化銷售。
1.OpenCVSharp的下載
可以直接從上面的github上下載源碼,自行編譯引用;
也可用vs中的nuget包管理器下載;
打開【工具】->【庫程序包管理器】->【管理解決方案的NuGet程序包】,在其中搜索OpenCVSharp,選擇合適的點擊【安裝】(最好安裝最新的)。一直等待完成。
我的環(huán)境是vs2017,下載之后最好直接拷貝OpenCVSharp系列dll到項目中引用即可。
2.擬合圓并求取圓心
本次舉例比較貼近實際,我們求如下原始圖片的中間部分圓的圓心,選取的圖片故意只留了一半:
源碼如下:
using OpenCvSharp; namespace SamplesWinform { public class CircleFit { public void Run() { //讀取圖片 var img = Cv2.ImRead("Data/Image/c1.bmp"); //顯示圖片 //Cv2.ImShow("Input Image", img); //轉(zhuǎn)換成灰度圖 Mat gray = img.CvtColor(ColorConversionCodes.BGR2GRAY); //閾值二值化操作 閾值參數(shù)可以用一些可視化工具來調(diào)試得到 Mat ThresholdImg = gray.Threshold(11, 255, ThresholdTypes.Binary); Cv2.ImShow("Threshold", ThresholdImg); //降噪 //方法一:高斯變化 //Mat gaussImg= ThresholdImg.GaussianBlur(new Size(5, 5), 0.8); //Cv2.ImShow("GaussianBlur", gaussImg); //方法二:中值濾波降噪 Mat medianImg = ThresholdImg.MedianBlur(5); Cv2.ImShow("MedianBlur", medianImg); //方法三:膨脹+腐蝕 ////膨脹處理 //Mat kernel = new Mat(15, 15, MatType.CV_8UC1); //Mat DilateImg = ThresholdImg.Dilate(kernel); ////腐蝕處理 //Mat binary = DilateImg.Erode(kernel); ////顯示中間結(jié)果 //Cv2.ImShow("Dilate & Erode", binary); //設(shè)置感興趣的區(qū)域 int x = 150, y = 100, w = 294, h = 337; Rect roi = new Rect(x, y, w, h); Mat ROIimg = new Mat(medianImg, roi); //Cv2.ImShow("ROI Image", ROIimg); //尋找圖像輪廓 Point[][] contours; HierarchyIndex[] hierachy; Cv2.FindContours(ROIimg, out contours, out hierachy, RetrievalModes.List, ContourApproximationModes.ApproxTC89KCOS); //根據(jù)找到的輪廓點,擬合橢圓 for (int i = 0; i < contours.Length; i++) { //擬合函數(shù)必須至少5個點,少于則不擬合 if (contours[i].Length < 5) continue; //橢圓擬合 var rrt = Cv2.FitEllipse(contours[i]); //ROI復原 rrt.Center.X += x; rrt.Center.Y += y; //畫橢圓 Cv2.Ellipse(img, rrt, new Scalar(0, 0, 255), 2, LineTypes.AntiAlias); //畫圓心 Cv2.Circle(img, (int)(rrt.Center.X), (int)(rrt.Center.Y), 4, new Scalar(255, 0, 0), -1, LineTypes.Link8, 0); } Cv2.ImShow("Fit Circle", img); } } }
中間處理過程效果圖如下:
分別是閾值分割后,中值濾波后,擬合圓之后
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對我們的支持。
上一篇:C#編程中常見數(shù)據(jù)結(jié)構(gòu)的比較(Unity3D游戲開發(fā))
欄 目:C#教程
下一篇:幾分鐘搞懂c#之FileStream對象讀寫大文件(推薦)
本文標題:利用C#版OpenCV實現(xiàn)圓心求取實例代碼
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/4758.html
您可能感興趣的文章
- 01-10C#利用反射技術(shù)實現(xiàn)去掉按鈕選中時的邊框效果
- 01-10C#修改IIS站點framework版本號的方法
- 01-10C#圖片處理3種高級應(yīng)用
- 01-10C#異步下載文件
- 01-10C#實例代碼之抽獎升級版可以經(jīng)表格數(shù)據(jù)導入數(shù)據(jù)庫,抽獎設(shè)置
- 01-10C# Console利用mspaint打開圖像并保存的方法
- 01-10C#利用delegate實現(xiàn)Javascript的each方法
- 01-10C# WCF簡單入門圖文教程(VS2010版)
- 01-10C#利用GDI繪制常見圖形和文字
- 01-10利用C#實現(xiàn)網(wǎng)絡(luò)爬蟲


閱讀排行
本欄相關(guān)
- 01-10C#通過反射獲取當前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁無法打開的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實現(xiàn)txt定位指定行完整實例
- 01-10WinForm實現(xiàn)仿視頻 器左下角滾動新
- 01-10C#停止線程的方法
- 01-10C#實現(xiàn)清空回收站的方法
- 01-10C#通過重寫Panel改變邊框顏色與寬度的
- 01-10C#實現(xiàn)讀取注冊表監(jiān)控當前操作系統(tǒng)已
隨機閱讀
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-11ajax實現(xiàn)頁面的局部加載
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實例總結(jié)
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個骰子