C#使用OpenCV剪切圖片中的人物頭像的實現方法
前言
本文主要介紹如何使用OpenCV剪切圖形中的人物頭像。
準備工作
首先創建一個Wpf項目——OpenCV_Face_Wpf,這裡版本使用Framework4.7.2。
然後使用Nuget搜索【Emgu.CV】,如下圖。
這裡的Emgu.CV選擇4.3.0.3890版本,然後安裝Emgu.CV和Emgu.CV.runtime.windows。
然後下載所需文件haarcascade_frontalface_default.xml。
可以去OpenCV的開源代碼中下載,下載地址:https://github.com/opencv/opencv/tree/master/data/haarcascades。
然後將文件加入進項目,並修改屬性,讓xml文件輸出到啟動目錄,如下圖。
使用OPenCV剪切人臉部分
現在,我們進入項目,進行OPenCV的調用。
首先引入命名空間,如下:
using Emgu.CV; using Emgu.CV.CvEnum; using Emgu.CV.Structure; using System.Drawing; using System.Windows.Forms;
然後編寫人臉剪切函數——CutFace。
函數裡,我們先使用CascadeClassifier類讀取haarcascade_frontalface_default.xml文件,建立人臉檢測的對象。
再使用Mat類來導入圖片(灰度模式)。
然後再使用人臉檢測的對象的方法——DetectMultiScale進行人臉數量識別。
最後通過Bitmap類把識別出來的人臉進行剪切保存。
代碼如下:
public void CutFace(string filename) { //CvInvoke.UseOpenCL = CvInvoke.HaveOpenCLCompatibleGpuDevice;//使用GPU運算 var face = new CascadeClassifier("haarcascade_frontalface_default.xml"); var mat = new Mat(filename, ImreadModes.Grayscale);//灰度導入圖片 int minNeighbors = 7;//最小矩陣組,默認3 var size = new System.Drawing.Size(10, 10);//最小頭像大小 var facesDetected = face.DetectMultiScale(mat, 1.1, minNeighbors, size); //循環把人臉部分切割出來並保存 int index = 0; var bitmap = Bitmap.FromFile(filename); foreach (var item in facesDetected) { index++; var bmpOut = new Bitmap(item.Width, item.Height, System.Drawing.Imaging.PixelFormat.Format24bppRgb); var g = Graphics.FromImage(bmpOut); g.DrawImage(bitmap, new System.Drawing.Rectangle(0, 0, item.Width, item.Height), new System.Drawing.Rectangle(item.X, item.Y, item.Width, item.Height), GraphicsUnit.Pixel); g.Dispose(); bmpOut.Save($"Face_{index}.png", System.Drawing.Imaging.ImageFormat.Png); bmpOut.Dispose(); } bitmap.Dispose(); mat.Dispose(); face.Dispose(); }
然後編寫一個打開文件的函數,在成功打開文件後調用CutFace。
public void SelectImg() { System.Windows.Forms.OpenFileDialog frm = new System.Windows.Forms.OpenFileDialog(); frm.Filter = "(*.jpg,*.png,*.jpeg,*.bmp)|*.jgp;*.png;*.jpeg;*.bmp|All files(*.*)|*.*"; if (frm.ShowDialog() == System.Windows.Forms.DialogResult.OK) { CutFace(frm.FileName); } }
現在我們啟動項目,如下圖:
運行結果
點擊界面中的打開圖片,選中帶人臉的圖片進行測試。
代碼中默認把剪切的圖片保存到Debug文件夾下,我們打開Debug文件夾,如下圖:
因為我選中的圖片隻有一個人臉,所以得到一個剪切圖片——Face_1.png。
原圖與剪切後的圖片對比如下:
現在,我們換一個人臉多的圖片,再測試一下。測試圖片如下。
運行後結果如下:
—————————————————————————————————-
到此C#使用OpenCV剪切圖形中的人物頭像就已經介紹完瞭。
代碼已經傳到Github上瞭,歡迎大傢下載。
Github地址:https://github.com/kiba518/OpenCV_Face_Wpf
到此這篇關於C#使用OpenCV剪切圖片中的人物頭像的文章就介紹到這瞭,更多相關C# OpenCV剪切圖片內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- C#使用OpenCV剪切圖像中的圓形和矩形的示例代碼
- 基於python3+OpenCV實現人臉和眼睛識別
- C# 控件屬性和InitializeComponent()關系案例詳解
- C# wpf Bitmap轉換成WriteableBitmap的方法
- C#實現截圖幫助類