在C#中使用OpenCV的.net包装器EmguCV

Emgu.CV OpenCvSharp 两个库都是OpenCV的C#封装。这里不讨论优劣,两个都有相应的用途。

下载安装4.6.0.5131,执行文件exe

https://sourceforge.net/projects/emgucv/files/emgucv/4.6.0/

安装到一个目录下,这里安装到H:\Emgu\ 目录下。

使用示例说明:我们要在C# 里使用OpenCV的一个函数 CvtColor做颜色空间转换;用到了工业相机的原始数据输出,大多数工业相机的输出格式都是 Bayer格式,很多时候都需要转为RGB格式才可以使用,所以这里用OpenCV的CvtColor函数转换。

新建C# 工程项目

工程项目名称

添加库引用

运行64位的

程序完整源码

cs 复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

using MVSDK;//使用SDK接口
using CameraHandle = System.Int32;
using MvApi = MVSDK.MvApi;
using System.Runtime.InteropServices;

using Emgu.CV;
using Emgu.CV.CvEnum;
using Emgu.CV.Structure;
using Emgu.CV.UI;

namespace BasicEmguTest
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void btnGrab_Click(object sender, EventArgs e)
        {
            CameraSdkStatus status;
            CameraHandle m_hCamera = 0;
            tSdkCameraDevInfo[] tCameraDevInfoList;
            IntPtr ptr;
            IntPtr m_ImageBuffer;
            status = MvApi.CameraEnumerateDevice(out tCameraDevInfoList);
            if (status != CameraSdkStatus.CAMERA_STATUS_SUCCESS)
            {
                return;
            }
            if (tCameraDevInfoList == null)
            {
                return;
            }
            status = MvApi.CameraInit(ref tCameraDevInfoList[0], -1, -1, ref m_hCamera);
            if (status != CameraSdkStatus.CAMERA_STATUS_SUCCESS)
            {
                return;
            }
            tSdkCameraCapbility tCameraCapability;
            MvApi.CameraGetCapability(m_hCamera, out tCameraCapability);
            m_ImageBuffer = Marshal.AllocHGlobal(tCameraCapability.sResolutionRange.iWidthMax * tCameraCapability.sResolutionRange.iHeightMax * 4);
            MvApi.CameraPlay(m_hCamera);

            tSdkFrameHead FrameHead;
            IntPtr uRawBuffer;
            status = MvApi.CameraGetImageBuffer(m_hCamera, out FrameHead, out uRawBuffer, 20000);
            if (status != CameraSdkStatus.CAMERA_STATUS_SUCCESS)
            {
                return;
            }
            MvApi.CameraImageProcess(m_hCamera, uRawBuffer, m_ImageBuffer, ref FrameHead);
            
            MvApi.CameraSaveImage(m_hCamera, ".\\test.bmp", m_ImageBuffer, ref FrameHead, emSdkFileType.FILE_BMP, 100);

            //--------------------直接转换相机原始数据,假设输出是8位深度
            Mat matTmp0 = new Mat(FrameHead.iHeight, FrameHead.iWidth, DepthType.Cv8U, 1, uRawBuffer, FrameHead.iWidth * 1);
            Mat matRGB = new Mat();

            CvInvoke.CvtColor(matTmp0, matRGB, ColorConversion.BayerGb2Rgb);
            CvInvoke.NamedWindow("OpenCVRaw2RGB", WindowFlags.Normal);
            //CvInvoke.Imshow("OpenCVRaw2RGB", matRGB);
            //CvInvoke.WaitKey(5);
            CvInvoke.Imwrite(".\\testCV.bmp", matRGB);

            MvApi.CameraReleaseImageBuffer(m_hCamera, uRawBuffer);

            MvApi.CameraUnInit(m_hCamera);
            Marshal.FreeHGlobal(m_ImageBuffer);
        }
    }
}

最后采图转换成功的结果

(结束)

相关推荐
格林威37 分钟前
常规线扫描镜头有哪些类型?能做什么?
人工智能·深度学习·数码相机·算法·计算机视觉·视觉检测·工业镜头
倔强青铜三1 小时前
苦练Python第63天:零基础玩转TOML配置读写,tomllib模块实战
人工智能·python·面试
R-G-B2 小时前
【02】大恒相机SDK C#开发 —— 初始化相机,采集第一帧图像
c#·大恒相机sdk·大恒相机初始化·大恒相机采集图像
B站计算机毕业设计之家2 小时前
智慧交通项目:Python+YOLOv8 实时交通标志系统 深度学习实战(TT100K+PySide6 源码+文档)✅
人工智能·python·深度学习·yolo·计算机视觉·智慧交通·交通标志
高工智能汽车2 小时前
棱镜观察|极氪销量遇阻?千里智驾左手服务吉利、右手对标华为
人工智能·华为
txwtech2 小时前
第6篇 OpenCV RotatedRect如何判断矩形的角度
人工智能·opencv·计算机视觉
正牌强哥2 小时前
Futures_ML——机器学习在期货量化交易中的应用与实践
人工智能·python·机器学习·ai·交易·akshare
倔强青铜三2 小时前
苦练Python第62天:零基础玩转CSV文件读写,csv模块实战
人工智能·python·面试
大模型真好玩2 小时前
低代码Agent开发框架使用指南(二)—Coze平台核心功能概览
人工智能·coze·deepseek
jerryinwuhan3 小时前
最短路径问题总结
开发语言·人工智能·python