【09】大恒相机SDK C#开发 ——库函数 IntPtr ConvertToRGB24详细解释 及 示例

文章目录

  • [1 ConvertToRGB24 功能及参数解释](#1 ConvertToRGB24 功能及参数解释)
  • [2 使用案例](#2 使用案例)

1 ConvertToRGB24 功能及参数解释

cpp 复制代码
IntPtr ConvertToRGB24(GX_VALID_BIT_LIST emValidBits, GX_BAYER_CONVERT_TYPE_LIST emConvertType, [MarshalAs(UnmanagedType.U1)] bool bFlip);

功能: 将从大恒相机获取的原始图像数据转换为RGB24格式的图像数据。

参数的详细解释:

  • emValidBits:这个参数是一个枚举类型,用于指定原始数据中哪些位是有效的。在图像传感器中,每个像素通常用一个或多个位来表示亮度值。这个参数可以帮助指定应该使用哪些位来生成RGB图像。例如,如果相机采用的是8位深度的传感器,那么可能有效位为GX_BIT_0_7,表示使用0到7位的数据。如果是10位深度的传感器,可能有效位为GX_BIT_0_9,表示使用0到9位的数据。

  • emConvertType:这个参数是另一个枚举类型,用于指定转换的类型。大恒相机库可能提供了不同的转换算法,以满足不同应用场景的需求。可能的选项包括GX_RAW2RGB_NEIGHBOUR(使用邻近插值算法进行转换)、GX_RAW2RGB_ADAPTIVE(自适应插值算法)等。你可以根据实际需要选择适合的转换类型。

  • bFlip:这是一个布尔值参数,用于指定是否需要翻转图像。在某些情况下,相机获取的原始图像可能需要在垂直方向上翻转才能正确显示。如果设置为true,则表示需要进行垂直翻转;如果设置为false,则表示不进行翻转。

这个方法返回一个 IntPtr 类型的指针,指向转换后的RGB24格式的图像数据。在使用这个指针时,需要谨慎确保内存的正确释放,以避免内存泄漏或其他问题。通常,你可以将这个指针传递给其他处理图像数据的函数,或者将其转换为 Bitmap 等图像格式进行显示和处理。

GX_VALID_BIT_LIST参数可选项

cpp 复制代码
public enum GX_VALID_BIT_LIST
{
    GX_BIT_4_11 = 4,
    GX_BIT_3_10 = 3,
    GX_BIT_2_9 = 2,
    GX_BIT_1_8 = 1,
    GX_BIT_0_7 = 0
}


GX_BAYER_CONVERT_TYPE_LIST参数可选项

cpp 复制代码
public enum GX_BAYER_CONVERT_TYPE_LIST
{
    GX_RAW2RGB_NEIGHBOUR3 = 2,
    GX_RAW2RGB_ADAPTIVE = 1,
    GX_RAW2RGB_NEIGHBOUR = 0
}

2 使用案例

该案例将中

  • objIFrameData 图像数据 通过 m_objGxBitmap1.Show(objIFrameData);显示相机原画面

  • 通过ConvertToRGB24函数将相机获取到的原图像数据objIFrameData 换换为RGB24格式的图像数据,

    该方法返回一个 IntPtr 类型的指针pBuffer1指向转换后的RGB24格式的图像数据。然后可以将这个指针传递给其他处理图像数据的函数(比如传给C++接口函数,将其转换为Mat 图像进行opencv处理),或者将其转换为 Bitmap 等图像格式进行显示和处理。

cpp 复制代码
 private void __OnFrameCallbackFun_1(object objUserParam, IFrameData objIFrameData)
 {
     try
     {
         if (null != objIFrameData)
         {
             lock (this)
             {
                 if (isShowSrcImg) //是否显示原画面
                 {
                     //************************************************************
                     //显示相机获取的原图
                     //************************************************************ 
                     m_objGxBitmap1.Show(objIFrameData);

                 }
                 //else if (camImg_isProcess[0])//Buffer要一直获取,等到要处理时在获取来及不,buffer报错
                 {
                     //************************************************************
                     //图像处理显示 等功能做准备
                     //*************************************************************

                     //获取图像宽高
                     SrcImgHeight = (int)objIFrameData.GetHeight();
                     SrcImgWidth = (int)objIFrameData.GetWidth();


                     //图像缓存传给C++处理
                     if (colorFlag)//彩色//判断是黑板还是彩色相机
                     {
                         //获取图像buffer 
                         pBuffer1 = objIFrameData.ConvertToRGB24(GX_VALID_BIT_LIST.GX_BIT_0_7, GX_BAYER_CONVERT_TYPE_LIST.GX_RAW2RGB_NEIGHBOUR, false);

                     }
                     else//黑白
                     {
                         pBuffer1 = objIFrameData.GetBuffer();
                     }
                 }

                 m_objCFps1.IncreaseFrameNum();
                 ////刷新界面
                 //m_objGxBitmap1 = new GxBitmap(m_listCCamerInfo[m_nOperateID].m_objIGXDevice, ImageShow1);
             }
         }
     }
     catch (Exception ex)
     {
         MessageBox.Show("回调函数1" + ex.Message);
     }
 }

值得注意的是,

  • 相机获得的原图像数据 显示相机原画面Show(objIFrameData)是需要垂直翻转,即图像上下颠倒,至于为什么这样,可能是大恒相机获取的图像数据在内存中存储方式有关。

  • 而我们转换为ConvertToRGB24格式进行其他处理,是不需要垂直翻转的。如,获取pBuffer传给C++接口函数,获取pBuffer然后进行ROI截图,用pictureBox显示等都不需要垂直翻转。

  • (那就奇了,显示相机原画面Show(objIFrameData)是需要垂直翻转,objIFrameData进行ROI截图显示不需要翻转;这不都是在C#中 pictureBox中显示吗?为啥

显示相机原画面Show()函数中 ConvertToRGB24函数,最后一个参数 bFlip = true;

cpp 复制代码
IntPtr pBufferColor = objIBaseData.ConvertToRGB24(emValidBits, GX_BAYER_CONVERT_TYPE_LIST.GX_RAW2RGB_NEIGHBOUR, true);

而我 传给C++接口函数 、ROI截图用pictureBox显示 中 ConvertToRGB24函数,最后一个参数 bFlip = false;(我刚开始也跟着 true,结果截取的ROI位置不对,画面也上下颠倒)

cpp 复制代码
 pBuffer1 = objIFrameData.ConvertToRGB24(GX_VALID_BIT_LIST.GX_BIT_0_7, GX_BAYER_CONVERT_TYPE_LIST.GX_RAW2RGB_NEIGHBOUR, false);

下面是 显示相机原画面Show()函数,他最终也是通过 pictureBox显示的;

cpp 复制代码
 /// <summary>
 /// 用于显示图像
 /// </summary>
 /// <param name="objIBaseData">图像数据对象</param>
 public void Show(IBaseData objIBaseData)
 {
     GX_VALID_BIT_LIST emValidBits = GX_VALID_BIT_LIST.GX_BIT_0_7;
     
     //检查图像是否改变并更新Buffer
     __UpdateBufferSize(objIBaseData);
  

     if (null != objIBaseData)
     {
         emValidBits = __GetBestValudBit(objIBaseData.GetPixelFormat());
         if (GX_FRAME_STATUS_LIST.GX_FRAME_STATUS_SUCCESS == objIBaseData.GetStatus())
         {
             if (m_bIsColor)
             {
                 IntPtr pBufferColor = objIBaseData.ConvertToRGB24(emValidBits, GX_BAYER_CONVERT_TYPE_LIST.GX_RAW2RGB_NEIGHBOUR, true);
                 Marshal.Copy(pBufferColor, m_byColorBuffer, 0, __GetStride(m_nWidth, m_bIsColor) * m_nHeigh);
                 __ShowImage(m_byColorBuffer);
             }
             else
             {
                 IntPtr pBufferMono = IntPtr.Zero;
                 if (__IsPixelFormat8(objIBaseData.GetPixelFormat()))
                 {
                     pBufferMono = objIBaseData.GetBuffer();
                 }
                 else
                 {
                     pBufferMono = objIBaseData.ConvertToRaw8(emValidBits);
                 }

                 byte[] byMonoBufferTmp = new byte[__GetStride(m_nWidth, m_bIsColor) * m_nHeigh];
                 Marshal.Copy(pBufferMono, byMonoBufferTmp, 0, __GetStride(m_nWidth, m_bIsColor) * m_nHeigh);

                 // 黑白相机需要翻转数据后显示
                 for (int i = 0; i < m_nHeigh; i++)
                 {
                     Buffer.BlockCopy(byMonoBufferTmp, (m_nHeigh - i - 1) * m_nWidth, m_byMonoBuffer, i * m_nWidth, m_nWidth);
                 }

                 __ShowImage(m_byMonoBuffer);
             }
         }
     }
 }

/// <summary>
/// 显示图像处理
/// </summary>
/// <param name="byBuffer">图像数据buffer</param>
private void __ShowImage(byte[] byBuffer)
{
    if (null != m_pic_ShowImage)//m_pic_ShowImage是pictureBox控件
    {
        CWin32Bitmaps.SetStretchBltMode(m_pHDC, COLORONCOLOR);
        CWin32Bitmaps.StretchDIBits(
                    m_pHDC,
                    0,
                    0,
                    m_pic_ShowImage.Width,
                    m_pic_ShowImage.Height,
                    0,
                    0,
                    m_nWidth,
                    m_nHeigh,
                    byBuffer,
                    m_pBitmapInfo,
                    DIB_RGB_COLORS,
                    SRCCOPY);            
    }
}
相关推荐
月巴月巴白勺合鸟月半9 小时前
如果 我退休了
c#
专注VB编程开发20年9 小时前
.NET组件读取压缩包中的内存数据电子表格XLSX文件和图片,不需要解压
linux·服务器·windows·c#·.net·excel·zip
爱上纯净的蓝天19 小时前
迁移面试题
java·网络·c++·pdf·c#
单单单单点20 小时前
C# 相机内存复用(减少图像采集耗时)以及行数复用
图像处理·计算机视觉·c#·相机
余衫马21 小时前
Mysql 5.7 与 SqlSugar 5.X 整合开发实战
mysql·c#·orm·sqlsugar
cplmlm1 天前
WPF+MVVM入门学习
c#·wpf
阿登林1 天前
C#微服务架构:实现指南与问题解决方案
微服务·架构·c#
山猪打不过家猪1 天前
(一)C#基础(异步)
c#
专注VB编程开发20年1 天前
对excel xlsx文件格式当成压缩包ZIP添加新的目录和文件后,OpenXml、NPOI、EPPlus、Spire.Office组件还能读出来吗
数据库·c#·excel
俊昭喜喜里1 天前
C#和SQL Server Management Studio的连接
服务器·数据库·c#