using Emgu.CV;using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Drawing.Imaging;using System.Runtime.InteropServices;using System.Text;using System.Web;using System.Windows.Forms;namespace RollerTest{ public partial class Form1 : Form { // [DllImport("Project6.dll", EntryPoint = "PrintString")] [DllImport("Project6.dll", EntryPoint = "opencvtest")] // [DllImport("test0909.dll", EntryPoint = "main")] public static extern int opencvtest(byte[] hello); public Form1() { InitializeComponent(); } private string pathname = string.Empty; private void button1_Click(object sender, EventArgs e) { OpenFileDialog file = new OpenFileDialog(); file.InitialDirectory = "."; file.Filter = "所有文件(*.*)|*.*"; file.ShowDialog(); if (file.FileName != string.Empty) { try { pathname = file.FileName; //获得文件的绝对路径 this.pictureBox1.Load(pathname); } catch (Exception ex) { MessageBox.Show(ex.Message); } } } private void pictureBox2_Click(object sender, EventArgs e) { try { // string str = "D:/0002.jpg"; // int a = PrintString(Encoding.ASCII.GetBytes(pathname)); // MessageBox.Show(a.ToString()); } catch(Exception ex) { MessageBox.Show(ex.Message); } } private void button2_Click(object sender, EventArgs e) { Application.Exit(); } private void pictureBox4_Click(object sender, EventArgs e) { Bitmap bmp = new Bitmap("1.jpg"); // pictureBox1.Image = bmp; int stride; byte[] source = GetBGRValues(bmp, out stride); int channel = Image.GetPixelFormatSize(bmp.PixelFormat) / 8; opencvtest(source, bmp.Width, bmp.Height, channel); //opencv对内存操作,画了一个圈 pictureBox1.Image = getBitmapByBytes(source, bmp.Width, bmp.Height, stride, bmp.PixelFormat); //从byte[]数组中获取到的图像已经有画圈了,证明传输通信成功 } [DllImport("Project6.dll", EntryPoint = "opencvtest", SetLastError = true, CharSet = CharSet.Ansi)] extern static int opencvtest(byte[] src, int w, int h, int channel); /// <summary> /// 生成灰度图的调色板 /// </summary> /// <returns></returns> public static ColorPalette getGrayPalette() { // 下面的代码是为了修改生成位图的索引表,从伪彩修改为灰度 ColorPalette tempPalette; using (Bitmap tempBmp = new Bitmap(1, 1, System.Drawing.Imaging.PixelFormat.Format8bppIndexed)) { tempPalette = tempBmp.Palette; } for (int i = 0; i < 256; i ) { tempPalette.Entries[i] = System.Drawing.Color.FromArgb(i, i, i); } return tempPalette; } /// <summary> /// 从图像Byte数组获取Bitmap /// </summary> /// <param name="src"></param> /// <param name="w"></param> /// <param name="h"></param> /// <param name="stride"></param> /// <param name="format"></param> /// <returns></returns> public static Bitmap getBitmapByBytes(byte[] src, int w, int h, int stride, PixelFormat format) { IntPtr ptr = getBytesPtr(src); int rowBytes = w * Image.GetPixelFormatSize(format) / 8; byte[] rgbValues = new byte[stride * h]; for (var i = 0; i < h; i ) { //int len = stride - (stride-rowBytes); Marshal.Copy(ptr, rgbValues, i * stride, rowBytes); //对齐 ptr = rowBytes; // next row } //Marshal.FreeHGlobal(ptr); ptr = getBytesPtr(rgbValues); Bitmap bitmap = new Bitmap(w, h, stride, format, ptr); if (format == PixelFormat.Format8bppIndexed) { bitmap.Palette = getGrayPalette(); //如果是单通道灰度图,默认的bitmap调色板不对,需要手动设置 } return bitmap; } /// <summary> /// 获取bytes数组的头指针,非托管 /// </summary> /// <param name="bytes"></param> /// <returns></returns> public static IntPtr getBytesPtr(byte[] bytes) { GCHandle hObject = GCHandle.Alloc(bytes, GCHandleType.Pinned); return hObject.AddrOfPinnedObject(); } /// <summary> /// 获取bitmap的byte数据,并输出stride /// </summary> /// <param name="bmp"></param> /// <param name="stride"></param> /// <returns></returns> public static byte[] GetBGRValues(Bitmap bmp, out int stride) { var rect = new Rectangle(0, 0, bmp.Width, bmp.Height); var bmpData = bmp.LockBits(rect, System.Drawing.Imaging.ImageLockMode.ReadOnly, bmp.PixelFormat); stride = bmpData.Stride; //int channel = bmpData.Stride / bmp.Width; var rowBytes = bmpData.Width * Image.GetPixelFormatSize(bmp.PixelFormat) / 8; var imgBytes = bmp.Height * rowBytes; byte[] rgbValues = new byte[imgBytes]; IntPtr ptr = bmpData.Scan0; for (var i = 0; i < bmp.Height; i ) { Marshal.Copy(ptr, rgbValues, i * rowBytes, rowBytes); //对齐 ptr = bmpData.Stride; // next row } bmp.UnlockBits(bmpData); return rgbValues; } [DllImport("Project6.dll", EntryPoint = "opencvtest", SetLastError = true, CharSet = CharSet.Ansi)] extern static int dlltest(byte[] src, int w, int h, out byte[] img); private void pictureBox3_Click(object sender, EventArgs e) { } }}
下载c#调用c++ DLL(opencv)示例源码用户还喜欢
- 18480 文章数
- 500万+ 热度
作者专栏
编辑推荐
- 淡抹u2引擎,修复内容较多,物有所值
- 界域传说·经典巨作=传世单机(一键安装)
- 丸子版本(175个传世版本大集合)
- GS版本:神话公益服务端+客户端
- 图片放大工具(放大图片不模糊)
- 剪映无限制VIP版
- 传奇世界客户端下载器,史上最全传世客户端
- 传世GS20220920商业引擎注册+登录配置器 解压密码是1
- U2官方排行榜游戏网关 支持元神,支持传家宝
- GS开战传世客户端+服务端
- (淡漠夕阳)u2引擎合区工具
- 传世GS引擎消除“你的游戏客户端版本号过旧,请及时更新”提示
- 传世一机多区双线路配置器--免密码版本
- 传世凤凰登陆器劫持修复软件
- SQLite3 for Navicat
- 传奇世界npc对话框编辑工具
- 传世GS落霞铭文服务器端
- gs_20210409引擎包+注册机(无限制)
- 传奇世界NPC对话封包查看器[支持时长版和极速版]
- 彩虹引擎传世脚本编辑工具1.7版来了,支持函数脚本翻译
评论