将VB.net代码改为VB6代码

美薇 2017-02-20 09:51:29
'最近需要用VB6对别人提供的的人脸识别SDK进行编程,没有VB6例程,只有vb.NET例程和部分说明,本人初学不久,求高人将下面例程改为VB6代码,不胜感激。
'vb.net Module1.vb 代码:
Imports System.Runtime.InteropServices
Imports System.IO
Imports System.Text
Module Module1
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftInitSDK(ByVal ipAddr As String, ByVal port As Long) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftDetectFaces _
(ByVal chn As Integer, ByVal pbyJpgSrcF1() As Byte, ByVal lenF1 As Integer, ByRef outData As IntPtr, ByRef facenum As Integer) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftDetectFaces1 _
(ByVal chn As Integer, ByVal filename As String, ByVal outData() As Integer, ByRef facenum As Integer) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Sub ftUnInitSDK()
End Sub
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftVerifyImage(ByVal pbyJpgSrcF0() As Byte, ByVal lenF0 As Integer, _
ByVal pbyJpgSrcF1() As Byte, ByVal lenF1 As Integer, ByRef score As Single) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftGetImageFeature(ByVal pbyJpgSrcF0() As Byte, ByVal lenF0 As Integer, _
ByVal feature() As Byte, ByRef lenOut As Integer) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftRegistPerson(ByVal regId As Integer, _
ByVal feature() As Byte, ByVal len As Integer) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftDeletePerson(ByVal regId As Integer) As Integer
End Function
<DllImport("FTDetectAPI.dll", CharSet:=CharSet.Ansi, CallingConvention:=CallingConvention.StdCall)> Public Function ftQueryPerson(ByVal feature() As Byte, ByVal len As Integer, _
ByVal maxReturn As Integer, ByVal thresh As Double, ByVal outPersonBuffer() As Byte, ByVal outPersonBufferLen As Integer) As Integer
End Function

Function ReadImageFile(file As String, ByRef Dat() As Byte, ByRef Len As Long)
FileOpen(1, file, OpenMode.Binary)
Len = LOF(1)
ReDim Dat(Len - 1)
FileGet(1, Dat)
FileClose(1)
If (Len > 0) Then
Return 0
End If
Return -1
End Function
Sub Main()
Dim ret As Integer
Console.WriteLine("开始初始化链接")
ret = ftInitSDK("127.0.0.1", 9898)
If (ret >= 0) Then
Console.WriteLine("初始化链接成功!")
ElseIf ret = -1 Then
Console.WriteLine("动态库模块加载失败!")
ElseIf ret = -10 Then
Console.WriteLine("链接人脸识别服务程序失败!")
End If
Dim imgDat0() As Byte
Dim imgLen0 As Long
Dim imgDat1() As Byte
Dim imgLen1 As Long
Dim imgDat2() As Byte
Dim imgLen2 As Long
ReadImageFile("../images/face_00.jpg", imgDat0, imgLen0)
ReadImageFile("../images/face_01.jpg", imgDat1, imgLen1)
ReadImageFile("../images/face_02.jpg", imgDat2, imgLen2)
Console.WriteLine("=========================================================")
Console.WriteLine("开始测试人脸检测函数")
'演示人脸检测功能
'从照片中检测人脸位置坐标

Dim outData As IntPtr
Dim facenum As Integer
Dim detResult(1024) As Integer
ret = ftDetectFaces(0, imgDat0, imgLen0, outData, facenum)
If ret >= 0 And facenum > 0 Then
For i = 0 To facenum - 1
Dim myint As Integer = Marshal.ReadInt32(outData, i * 5)
Dim x As Integer = Marshal.ReadInt32(outData, (i * 5 + 1) * Len(myint))
Dim y As Integer = Marshal.ReadInt32(outData, (i * 5 + 2) * Len(myint))
Dim width As Integer = Marshal.ReadInt32(outData, (i * 5 + 3) * Len(myint))
Dim height As Integer = Marshal.ReadInt32(outData, (i * 5 + 4) * Len(myint))
Dim info As String
Console.WriteLine()
Console.WriteLine("ID编号:" & myint & "位置:" & x & "," & y & "," & width & "," & height)
Next i
End If
Console.WriteLine("=========================================================")
Console.WriteLine("开始测试1:1人脸比对函数")

'演示1:1人脸比对功能
Dim score As Single
ret = ftVerifyImage(imgDat0, imgLen0, imgDat1, imgLen1, score)
If (ret >= 0) Then
Console.WriteLine("两幅图像1;1测试比对结果:" & score)
End If
Console.WriteLine("=========================================================")
Console.WriteLine("开始测试1:N人脸检索函数")
'演示1:N人脸检索功能
'清空人脸
ftDeletePerson(-1)
'提取特征'从照片中提取人脸特征特征
Dim fea0(8000) As Byte
Dim feaLen0 As Integer
Dim fea1(8000) As Byte
Dim feaLen1 As Integer
Dim fea2(8000) As Byte
Dim feaLen2 As Integer
'ret >=0 正常,否则失败
Console.WriteLine("步骤1:提取3张图片的人脸特征")
ret = ftGetImageFeature(imgDat0, imgLen0, fea0, feaLen0)
ret = ftGetImageFeature(imgDat1, imgLen1, fea1, feaLen1)
ret = ftGetImageFeature(imgDat2, imgLen2, fea2, feaLen2)
'注册人脸 注册N张照片
'ret >=0 表示注册成功

Console.WriteLine("步骤2:往库中注册其中2个特征, 假设它们ID分别为101,102")
ret = ftRegistPerson(101, fea0, feaLen0)
ret = ftRegistPerson(102, fea1, feaLen1)
'查找人脸 通过另一张照片查找101 ID是事存在? 假设过滤阈值为0.85,最多返回20个结果
Console.WriteLine("步骤3:通过101 另一张照片查找ID是否存在? 返回格式为 id,value^id,value^id......")
Dim outPersonBuffer(1024) As Byte
Dim outPersonBufferLen As Integer
'每次使用前,初始化
ReDim outPersonBuffer(1024)
outPersonBufferLen = 1024
ret = ftQueryPerson(fea2, feaLen2, 20, 0.85F, outPersonBuffer, outPersonBufferLen)
If (ret >= 0) Then
Dim reStr As String
reStr = Encoding.ASCII.GetString(outPersonBuffer)
Console.WriteLine("识别结果:" & reStr)
End If

Console.WriteLine("=========================================================")
Console.WriteLine("测试结束!")
Console.ReadLine()

'释放资源
ftUnInitSDK()

End Sub

End Module

下面是C语言头文件说明:


#ifndef _FT_DETECT_API_H_
#define _FT_DETECT_API_H_

// DetectAPI.cpp : 定义控制台应用程序的入口点。
//


#include "stdafx.h"

#define IMAGE_SIZE 1024*1024*8

struct SDS_POINT 结构:
{
float x;
float y;
};
struct FaceObject 定义结构:
{
SDS_POINT lefteye; //左眼坐标
SDS_POINT righteye;
SDS_POINT mouth; //嘴巴坐标
float outLight; //明暗程度
float outSynLight; //光线对称性
float outDiffH; //水平偏转
float outDiffV; //俯仰偏转
float outDiffR; //垂直偏转
float outEyeClosed; //
float outEyeGlass; //眼睛清晰度
float outMouthClosed; //闭嘴程度
float qScore;
};
/*
* 函数名:ftInitSDK
*参数:IP-人脸识别服务所在IP地址;PORT-端口
*返回:-10,表示找不到比对服务;-1表示程序加载失败
*/

int WINAPI ftInitSDK(const char* ip, int port);
void WINAPI ftUnInitSDK();
/*
* 函数名:ftDetectFaces 本地函数

*参数:chn,表示检测通道,即1路视频,同时可开启5路。
*参数:pbyJpgSrcF,表示图片流,即JPG文件以内存数组方式存储;
*参数:lenF,内存图像流,数组的长度
*参数:outData,表示检测到的人脸ID与位置,每5个INT值表示1个人脸,格式为 id,x,y,w,h,id,x,y,w,h,id.......
*参数:facenum, 表示outData中包括的有效人脸个数
*返回:-1表示失败,可能图片有问题;-10网络或后台EXE服务有问题。
*/

int WINAPI ftDetectFaces(int chn, char* pbyJpgSrcF, int lenF, int *&outData, int &facenum);
int WINAPI ftDetectFaces2(int chn, char* pbyJpgSrcF, int lenF, int *&outData, int &facenum);
/*
* 函数名:ftVerifyImage 远程函数
*参数:pbyJpgSrcF,表示图片流,即JPG文件以内存数组方式存储;
*参数:lenF,内存图像流,数组的长度
*参数:score, 图片比对结果[0,1.0], -1表示比对失败
*-1表示失败,可能图片有问题;-10网络或后台EXE服务有问题。
*/

int WINAPI ftVerifyImage(char* pbyJpgSrcF0, int lenF0, char* pbyJpgSrcF1, int lenF1, float &score);
/*
* 函数名:ftGetImageFeature 得到图像的特征值 远程函数

*参数:pbyJpgSrcF,表示图片流,即JPG文件以内存数组方式存储;
*参数:lenF,内存图像流,数组的长度
*参数:outFeature, 在外部申请空间,如char outFeature[4096]
*参数:outLen , 返回实际特征大小
*-1表示失败,可能图片有问题;-10网络或后台EXE服务有问题。
*/
int WINAPI ftGetImageFeature(char* pbyJpgSrcF, int lenF, char *outFeature, int &outLen);
/*
* 函数名:ftRegistPerson 1;N往内存注册特征值 远程函数
*参数:id, 该人的唯一ID 定义时必须大于0
*参数:feature,特征值;
*参数:len,特征值长度;
*-1表示失败,可能图片有问题;-10网络或后台EXE服务有问题。
*/

int WINAPI ftRegistPerson(int id, const char *feature, int len);
int WINAPI ftDeletePerson(int id); //-1表示清空所有记录
int WINAPI ftUpdatePerson(int id, const char *feature, int len);//暂未使用
/*
* 函数名:ftQueryPerson 1;N查询与指定特征值相似的人 远程函数
*参数:feature,特征值;
*参数:len,特征值长度;
*参数:maxReturn, 返回相似的最多人数
*参数:threshHold, 返回的人应满足的阈值条件
*参数:outPersonBuffer, 外部申请空间,如char outPersonBuffer[10000]; 返回的人ID与相似度值,格式为 id,value^id,value^id.......
*参数:outPersonBufferLen = 10000, 指明外部空间大小
*-1表示失败,可能图片有问题;-10网络或后台EXE服务有问题。
*/

int WINAPI ftQueryPerson(const char *feature, int len, int maxReturn, double threshHold, char *outPersonBuffer, int outPersonBufferLen);
...全文
5410 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
美薇 2017-02-26
  • 打赏
  • 举报
回复
正在学习,谢谢大家
赵4老师 2017-02-21
  • 打赏
  • 举报
回复
建议楼主抽空学习一下VB.NET
Tiger_Zhao 2017-02-21
  • 打赏
  • 举报
回复
具体工作不想自己做就出钱外包。
ah_2056 2017-02-21
  • 打赏
  • 举报
回复
引用 1 楼 caozhy 的回复:
vb.net编译成dll,comvisible为true,用regasm注册,vb添加工程引用,然后调用。
最好的办法。
threenewbee 2017-02-21
  • 打赏
  • 举报
回复
vb.net编译成dll,comvisible为true,用regasm注册,vb添加工程引用,然后调用。
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)
001、VB串口通讯视频教程源码41个 002、Visual Basic串口通信工程开发实例导航随书源码7个 003、Visual Basic串口通信与测控应用技术实战详解 源代码(15个全) 004、GE PLC串口通讯,VB编制,读取内存单元 005、PC机与51单片机之间的串口通讯,VB编的,分PC和单片机两部分 006、VB6的串口通信程序,还有crc校验 007、VB Modbus RTU源码,其中协议部分已生成DLL,可直接调用 008、VB.net开发的串口调试程序 009、VB.net实现串口编程,希望大家有用 010、VB版串口调试程序,包含VB源码及安装文件,适合调试串口 011、VB编程RS232串口控制DA数模转换 012、VB编程实现的串口调试工具源码 013、VB编写的RS232串口通信测试程序,以txt格式接受,可定义发送字符 014、VB编写的SouthStar串口测试与51串口烧写器V1.0版 015、VB编写的串口调试助手1.0的源码 016、VB编写的串口短信发送程序,需要数据线支持 017、VB编写的串口通信程序,实现多机通信 018、VB编写的串口通信程序,主要用于上位机与下位机间的通信 019、VB编写的串口通信程序界面参考网上的程序较简单 020、VB编写的串口通讯界面,主要面向51单片机的串口通信 021、VB编写的单片机和PC串口通信的调试程序 022、VB编写的仿真实电子琴操作界面,包含与FPGA串口通信的功能 023、VB串口API通讯,附带BAS文件全部源码,实现与饭卡读卡器通讯 024、VB串口编程,关于上位机的应用,特别适合初级学习VB的学员 025、VB串口编程调试精灵源码 026、VB串口编程实现完整的多费率电表读数软件 027、VB串口程序,,是一个串口使用例程,对初学者有用,特别是工控类的 028、VB串口传输文本,实现2台PC间的通信,类似简单的聊天工具 029、VB串口的一个电子称的项目 030、VB串口调试程序,用于通过串口控制松下空调测试 031、VB串口调试程序及源码 032、VB串口调试软件源代码,可以参考修改为其它通讯程序 033、VB串口调试软件源文件 034、VB串口控制步进电机程序完整源码 035、VB串口通信 6路10位AD转换数据采集源程序 036、VB串口通信,API串口通信模块源码 037、VB串口通信,适用简单,适合初学者 038、VB串口通信操作界面,进行数据采集,画实时曲线 039、VB串口通信程序,可以读取串口并显示保存数据,且能显示数据曲线 040、VB串口通信的源码,学习的好资料 041、VB串口通信调试器的源码程序 042、VB串口通信设计视频演示源码 043、VB串口通信示例 044、VB串口通信数据源码 045、VB串口通信之串口接收程序 046、VB串口通讯测试源代码,有文本和图形两种端口数据观察方式 047、VB串口通讯程序,用来跟单片机通讯 048、VB串口通讯代码(部分) 049、VB串口通讯的参考源程序 050、VB串口通讯实例 高精度电压表(24bit) VB源程序 051、vb串口通讯示例 052、VB串口与伺服电机DSP2407通讯完整代码源程序 053、VB串口源码,动力电池检测数据采集,内含电导巡检模块通讯报文,可,读写,保存,备份数据 054、VB串口字节通信程序,包括:1字节发送子程序,n字节接收子程序 055、VB串行口通信测试示例 056、VB串行通信试验程序 057、VB的MODEM通信源代码,智能化水电远端数据读取系统 058、VB的串口源程序,包括串口的配置界面,接收功能和发送功能 059、VB访问串口,并读取电子秤上显示的数据 060、VB和西门子S7-300 PLC串口通讯程序能实现读写功能 061、VB检测串口工作状态 062、VB简单的串口短信收发功能,使用短信猫测试通过 063、VB开发串口通信,关于生物医学工程专业的血氧饱和度的设计 064、VB开发串口通信软件,利用按钮控件控制高清晰数字展示台 065、VB开发的RS232串口图像处理器驱动(摄像头驱动) 066、VB开发的串口通信源码 067、VB开发的串口与三菱FX PLC通讯源码 068、VB控制串口232通讯,对飞利浦M1卡内数据进行处理,支持密码修改等 069、VB利用Mscomm控件编写的通讯终端,可做串口通讯编程参考示例 070、VB平台单片机与PC机串口通信的PC端程序。小巧易用,功能丰富 071、VB嵌入式串口通讯波形分析显示软件 072、VB实现串口调试LED信息显示屏设备主要代码 073、VB实现串口调试工具的完整源码 074、vb实现串口通信 文件传送系统,用vb以及mscomm控件实现 075、VB实现串口通信,发送命令从而接收相应数据 076、VB使用mscom控件实现PC机与单片机串口通信 077、VB通过COM串口读取条形码设备 078、VB通过串口控制单片机读写24C02源代码 079、VB通讯程序,连接串口可在电脑显示来电号码 080、VB下的串口发短信程序,可选择端口,设置短信中心号码 081、VB写的串口通信,发送和接收实例 082、VB写的串口通信分析程序源码 083、VB写的串口通讯,通过串口对单片机进行控制 084、VB写的串口通讯软件,简单易学,适合初学者 085、VB写的通过串口与考勤机连接通讯的程序 086、vb用控件的写的串口程序,是vb的经典之作 087、VB与USB转串口的通讯完整程序,有详细说明,不需要安装驱动 088、vb与串口通信的关于回路测试的小程序很实用 089、vb语言开发的串口通信,可实现拨号传送文件等 090、VB中串口事件处理函数的示例 091、VB中的串口通讯,串口通讯作为一种古老而又灵活的通讯方式,被广泛地应用 092、VB自动枚举系统串口加摄象头图象采集,坐标系变换 093、Visual Basic2005与自动化系统监控(串并行控制)光盘

1,488

社区成员

发帖
与我相关
我的任务
社区描述
VB API
社区管理员
  • API
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧