利用C#版OpenCV實(shí)現(xiàn)圓心求取實(shí)例代碼
前言
OpenCVSharp是OpenCV的.NET wrapper,是一名日本工程師開發(fā)的,項(xiàng)目地址為:https://github.com/shimat/opencvsharp。
該源碼是 BSD開放協(xié)議,BSD開源協(xié)議是一個給于使用者很大自由的協(xié)議?;旧鲜褂谜呖梢浴睘樗麨椤?可以自由的使用,修改源代碼,也可以將修改后的代碼作為開源或者專有軟件再發(fā)布或商業(yè)化銷售。
1.OpenCVSharp的下載
可以直接從上面的github上下載源碼,自行編譯引用;
也可用vs中的nuget包管理器下載;
打開【工具】->【庫程序包管理器】->【管理解決方案的NuGet程序包】,在其中搜索OpenCVSharp,選擇合適的點(diǎn)擊【安裝】(最好安裝最新的)。一直等待完成。
我的環(huán)境是vs2017,下載之后最好直接拷貝OpenCVSharp系列dll到項(xiàng)目中引用即可。
2.擬合圓并求取圓心
本次舉例比較貼近實(shí)際,我們求如下原始圖片的中間部分圓的圓心,選取的圖片故意只留了一半:
源碼如下:
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ù)找到的輪廓點(diǎn),擬合橢圓
for (int i = 0; i < contours.Length; i++)
{
//擬合函數(shù)必須至少5個點(diǎn),少于則不擬合
if (contours[i].Length < 5) continue;
//橢圓擬合
var rrt = Cv2.FitEllipse(contours[i]);
//ROI復(fù)原
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)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對我們的支持。
上一篇:C#編程中常見數(shù)據(jù)結(jié)構(gòu)的比較(Unity3D游戲開發(fā))
欄 目:C#教程
下一篇:幾分鐘搞懂c#之FileStream對象讀寫大文件(推薦)
本文標(biāo)題:利用C#版OpenCV實(shí)現(xiàn)圓心求取實(shí)例代碼
本文地址:http://www.jygsgssxh.com/a1/C_jiaocheng/4758.html
您可能感興趣的文章
- 01-10C#利用反射技術(shù)實(shí)現(xiàn)去掉按鈕選中時的邊框效果
- 01-10C#修改IIS站點(diǎn)framework版本號的方法
- 01-10C#圖片處理3種高級應(yīng)用
- 01-10C#異步下載文件
- 01-10C#實(shí)例代碼之抽獎升級版可以經(jīng)表格數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫,抽獎設(shè)置
- 01-10C# Console利用mspaint打開圖像并保存的方法
- 01-10C#利用delegate實(shí)現(xiàn)Javascript的each方法
- 01-10C# WCF簡單入門圖文教程(VS2010版)
- 01-10C#利用GDI繪制常見圖形和文字
- 01-10利用C#實(shí)現(xiàn)網(wǎng)絡(luò)爬蟲


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


