C#調用OpenCV開發簡易版美圖工具

前言html

在C#調用OpenCV其實很是簡單,由於C#中有不少OPenCV的開源類庫。git

本文主要介紹在WPF項目中使用OpenCVSharp3-AnyCPU開源類庫處理圖片,下面咱們先來作開發前的準備工做。github

準備工做app

首先,咱們先建立一個WPF項目。工具

而後,在Nuget上搜索OpenCVSharp,以下圖:學習

接着,咱們選擇OpenCVSharp3-AnyCPU選項進行安裝 。spa

安裝了OpenCVSharp3-AnyCPU後,咱們的項目會自動引入4個類庫,以下圖: 3d

 到這裏,咱們的準備工做就完成了,很是簡單。orm

C#中應用OPenCVhtm

如今,咱們進入項目,進行OPenCV的調用。

咱們先引入OpenCV相關的命名空間,以下:

using OpenCvSharp;
using OpenCvSharp.Extensions;

而後咱們在項目中使用Mat類來進行圖片操做。

----------------------------------------------------------------------------------------------------

紅藍顏色通道互換

在OPenCV裏,Mat類是很是重要的,它是處理圖片的入口。

如今,咱們先作一個簡單的圖片操做,紅藍通道顏色互換,代碼以下:

Mat mat = new Mat(@"..\..\Images\ocv02.jpg", ImreadModes.Unchanged);
for (var y = 0; y < mat.Height; y++)
{
    for (var x = 0; x < mat.Width; x++)
    {
        Vec3b color = mat.Get<Vec3b>(y, x);
        var temp = color.Item0;
        color.Item0 = color.Item2; //B 轉 R
        color.Item2 = temp;        //R 轉 B
        mat.Set(y, x, color);
    }
}
var mem = mat.ToMemoryStream();
BitmapImage bmp = new BitmapImage();
bmp.BeginInit();
bmp.StreamSource = mem;
bmp.EndInit();
imgOutput.Source = bmp;
mat.Dispose();/// 該方法在mat裏被重寫了,能夠釋放資源,能夠放心調用

效果圖以下:

能夠看到,咱們成功的處理了圖片的紅藍通道顏色互換。

如今咱們再多作一些OpenCV的操做。

腐蝕

代碼以下:

using (var src = new Mat(@"..\..\Images\ocv02.jpg", ImreadModes.AnyDepth | ImreadModes.AnyColor))
{
    Cv2.Erode(src, src, new Mat());
    var mem = src.ToMemoryStream();
    BitmapImage bmp = new BitmapImage();
    bmp.BeginInit();
    bmp.StreamSource = mem;
    bmp.EndInit();
    imgOutput.Source = bmp; 
}

效果圖以下:

反轉

代碼以下:

using (var src = new Mat(@"..\..\Images\ocv02.jpg", ImreadModes.AnyDepth | ImreadModes.AnyColor))
{
    using (var dst = new Mat())//複製之後處理
    {
        Cv2.BitwiseNot(src, dst, new Mat());
        var mem = dst.ToMemoryStream();
        BitmapImage bmp = new BitmapImage();
        bmp.BeginInit();
        bmp.StreamSource = mem;
        bmp.EndInit();
        imgOutput.Source = bmp;
    }
}

效果圖以下:

亮度—變暗

代碼以下:

BitmapImage bmpSource = new BitmapImage(new Uri("pack://application:,,,/images/ocv02.jpg" )); 
Mat mat = bmpSource.ToMat();
for (var y = 0; y < mat.Height; y++)
{
    for (var x = 0; x < mat.Width; x++)
    {
        Vec3b color = mat.Get<Vec3b>(y, x);
        int item0 = color.Item0;
        int item1 = color.Item1;
        int item2 = color.Item2;
        #region  變暗
        item0 -= 60;
        item1 -= 60;
        item2 -= 60;
        if (item0 < 0)
            item0 = 0;
        if (item1 < 0)
            item1 = 0;
        if (item2 < 0)
            item2 = 0;
        #endregion
        #region  變亮
        //item0 += 80;
        //item1 += 80;
        //item2 += 80;
        //if (item0 > 255)
        //    item0 = 255;
        //if (item1 > 255)
        //    item1 = 255;
        //if (item2 > 255)
        //    item2 = 255;
        #endregion

        color.Item0 = (byte)item0;
        color.Item1 = (byte)item1;
        color.Item2 = (byte)item2;
        mat.Set(y, x, color);
    }
}
var mem = mat.ToMemoryStream();
BitmapImage bmp = new BitmapImage();
bmp.BeginInit();
bmp.StreamSource = mem;
bmp.EndInit();
imgOutput.Source = bmp;
mat.Dispose();/// 該方法在mat裏被重寫了,能夠釋放資源,能夠放心調用

能夠看到,這裏的代碼稍微有點特別。

咱們經過BitmapImage導入圖片後,直接使用BitmapImage的對象的ToMat方法,把BitmapImage轉換成了Mat類的對象。

這個ToMat方法,咱們須要特別留意一下,由於他並非BitmapImage類的方法,它是一個擴展方法,只有咱們引用了OpenCvSharp命名空間,BitmapImage和Bitmap對象纔會增長擴展方法ToMat。

效果圖以下:

頂點變化

代碼以下:

using (var src = new Mat(@"..\..\Images\ocv02.jpg", ImreadModes.AnyDepth | ImreadModes.AnyColor))
{
    using (var dst = new Mat())//複製之後處理
    {   
        //設置原圖變換頂點
       List< Point2f> AffinePoints0  =new List<Point2f>() { new Point2f(100, 50), new Point2f(100, 390), new Point2f(600, 50) };
        //設置目標圖像變換頂點
        List<Point2f> AffinePoints1 = new List<Point2f>() { new Point2f(200, 100), new Point2f(200, 330), new Point2f(500, 50) };
        //計算變換矩陣
        Mat Trans =Cv2.GetAffineTransform(AffinePoints0, AffinePoints1);
        //矩陣仿射變換
        Cv2.WarpAffine(src, dst, Trans,new OpenCvSharp.Size() { Height= src.Cols, Width= src.Rows }); 
        var mem = dst.ToMemoryStream();
        BitmapImage bmp = new BitmapImage();
        bmp.BeginInit();
        bmp.StreamSource = mem;
        bmp.EndInit();
        imgOutput.Source = bmp;
    }
}

效果圖以下:

美顏磨皮 雙邊濾波

代碼以下:

using (var src = new Mat(@"..\..\Images\ocv02.jpg", ImreadModes.AnyDepth | ImreadModes.AnyColor))
{
    using (var dst = new Mat())//複製之後處理
    {
        Cv2.BilateralFilter(src, dst, 15, 35d, 35d);
        var mem = dst.ToMemoryStream();
        BitmapImage bmp = new BitmapImage();
        bmp.BeginInit();
        bmp.StreamSource = mem;
        bmp.EndInit();
        imgOutput.Source = bmp;
    }
}

效果圖以下:

----------------------------------------------------------------------------------------------------

你們能夠看到,圖片中有不少OpenCV的特效處理,而文章中只是介紹了幾個,這是由於其餘處理和文章中的特效處理的方法大同小異,因此就只列舉了這幾個。

有興趣的朋友能夠自行下載代碼學習。

----------------------------------------------------------------------------------------------------

到此C#調用OpenCV開發簡易版美圖工具就講完了。

代碼已經傳到Github上了,歡迎你們下載。

Github地址:https://github.com/kiba518/WpfOpenCV

----------------------------------------------------------------------------------------------------

注:此文章爲原創,任何形式的轉載都請聯繫做者得到受權並註明出處!
若您以爲這篇文章還不錯,請點擊下方的推薦】,很是感謝!
本文已獨家受權給腳本之家(ID:jb51net)公衆號發佈!

http://www.javashuo.com/article/p-ybsvwert-dy.html

 

相關文章
相關標籤/搜索