csharp通过dll调用opencv函数,图片作为参数

简介: [blog 项目实战派]csharp通过dll调用opencv函数,图片作为参数          ​一直想做着方面的研究,但是因为这个方面的知识过于小众,也是由于自己找资料的能力比较弱,知道今天才找到了比较好的资料。
[blog 项目实战派]csharp通过dll调用opencv函数,图片作为参数
 
       ​一直想做着方面的研究,但是因为这个方面的知识过于小众,也是由于自己找资料的能力比较弱,知道今天才找到了比较好的资料。一个是thinimage,一个是basework,里面都实现了这里的“csharp通过dll调用opencv函数,并且采用图片作为参数”。这里小结如下。
       关于如何“ csharp通过dll调用opencv函数 ”,请参考前面博文,这里主要说如何“采用图片为参数”。
       在编写图像识别/增强/机器视觉等项目的时候,一般会将算法打包成dll文件给客户,如果界面是用mfc写的话,是很好实现这个功能的。但是也有一些时候,由于特殊的需求,或者为了更快地实现更为丰富的界面效果,选择csharp作为界面。这个时候就需要“图片作为参数”。
      本项目是一个实验项目,功能就是csharp下读入一个24位彩色图片,调用opencv进行ycbcr变换后,然后再csharp上面显示出来。
      因为在调用的过程中,传递的只是指针,  所以 这个转换需要做两方面的工作。 一个方面是 csharp这边的,具体来说就是需要创建bitmap的结构,并且在调用的过程中锁定内存;一个方面是在opencv和dll编写这边的,要能够读入内存区域,并且翻译成mat结构。然后在这个基础上面编写相关的处理程序。
       继续开源项目ThinyImage,这个过程的以实现。
       ThinyImage本身就是csharp调用c++编写的dll实现的图像处理软件,也实现了一些功能:
那么在现有的程序上面添加GO算法接口
csharp这边,进行内存锁定和函数调用操作
   private  void ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            StartImageProcess();
             try
            {
                BitmapData bitmapData  = m_bitmap.LockBits( new Rectangle( 00, m_bitmap.Width, m_bitmap.Height),
                                                            ImageLockMode.ReadWrite, PixelFormat.Format32bppArgb);
                NativeMethods.DirectCopy(bitmapData.Scan0, bitmapData.Width, bitmapData.Height, bitmapData.Stride, m_bpp);
                m_bitmap.UnlockBits(bitmapData);
            }
             catch (System.Exception)
            {
            }
            EndImageProcess();
        }
相应添加程序接口,
//联合opencv的模板函数
void  DirectCopy(TiBitmapData & bitmap){
      //获得基本参数
      int width     = bitmap.GetWidth();
      int height     = bitmap.GetHeight();
      int stride     = bitmap.GetStride();
      int bpp         = bitmap.GetBpp();
     u8 * bmpData     = bitmap.GetBmpData();
      int offset     = stride  - width  * bpp;
     Mat src  = Mat : :zeros(width,height,CV_8UC3);
      //将bitmap的内容拷贝到src中
      for( int i = 0;i <src.rows;i ++){       
          for( int j = 0;j <src.cols;j ++){    
             src.at <Vec3b >(i,j)[ 0] =( int)bmpData[TiBlue];
             src.at <Vec3b >(i,j)[ 1] =( int)bmpData[TiGreen];
             src.at <Vec3b >(i,j)[ 2] =( int)bmpData[TiRed];
             bmpData  += bpp;
        }
          bmpData  += offset;
     }
     /////OPENCV具体操作过程////////////////////////
    Mat dst;
    cvtColor(src,dst,COLOR_BGR2YCrCb);;
     /////OPENCV过程结束////////////////////////
    bmpData     = bitmap.GetBmpData();
     for( int i = 0;i <src.rows;i ++){       
         for( int j = 0;j <src.cols;j ++){    
            bmpData[TiBlue] = dst.at <Vec3b >(i,j)[ 0];
            bmpData[TiGreen] = dst.at <Vec3b >(i,j)[ 1];
            bmpData[TiRed] = dst.at <Vec3b >(i,j)[ 2];
            bmpData  += bpp;
        }
        bmpData  += offset;
    }
}
}
完成相应的功能
 





目前方向:图像拼接融合、图像识别 联系方式:jsxyhelu@foxmail.com
目录
相关文章
|
计算机视觉
Opencv学习笔记(十二):图片腐蚀和膨胀操作
这篇文章介绍了图像腐蚀和膨胀的原理、作用以及使用OpenCV实现这些操作的代码示例,并深入解析了开运算和闭运算的概念及其在图像形态学处理中的应用。
1016 1
Opencv学习笔记(十二):图片腐蚀和膨胀操作
|
计算机视觉 Python
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
使用OpenCV库将一个文件夹内的所有彩色图片批量转换为灰度图,并提供了相应的Python代码示例。
265 0
Opencv学习笔记(二):如何将整个文件下的彩色图片全部转换为灰度图
|
计算机视觉 Python
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
这篇博客介绍了如何使用OpenCV库在Python中将图片保存到指定目录,以及如何将文件夹中的所有图片读取并以数组形式输出。
1037 0
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
|
算法 计算机视觉
Opencv学习笔记(六):cv2.resize函数的介绍
这篇文章介绍了OpenCV库中cv2.resize函数的使用方法,包括其参数、插值方式选择以及实际代码示例。
2903 1
Opencv学习笔记(六):cv2.resize函数的介绍
|
计算机视觉
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
在使用OpenCV的cv2模块保存带有中文命名的图片时,直接使用cv2.imwrite()会导致乱码问题,可以通过改用cv2.imencode()方法来解决。
856 0
Opencv错误笔记(一):通过cv2保存图片采用中文命名出现乱码
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
4083 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
计算机视觉 索引
OpenCv实时设置摄像头参数/获得摄像头参数值的方法论
这篇文章提供了一个OpenCV的实例教程,展示了如何使用`createTrackbar()`函数实时设置和获取摄像头参数值,如饱和度、Gamma和亮度,并通过回调函数在程序中连续修改这些参数。
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
2021 1
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
|
Serverless 计算机视觉
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆
这篇文章介绍了如何使用OpenCV库通过mask图像绘制分割对象的外接椭圆。首先,需要加载mask图像,然后使用`cv2.findContours()`寻找轮廓,接着用`cv2.fitEllipse()`拟合外接椭圆,最后用`cv2.ellipse()`绘制椭圆。文章提供了详细的代码示例,展示了从读取图像到显示结果的完整过程。
332 0
语义分割笔记(三):通过opencv对mask图片来画分割对象的外接椭圆