如何在VB程序下生成二维条码

如何在VB程序下生成二维条码,包括PDF417、QrCode、DataMatrix和汉信二维条码,具体步驺如下:

操作方法

  • 01

    创建VB工程,COPY二维条码动态链接库到您的工程中。您需要引用的动态库有:EnCodePdf.dll,EnCodeQr.dll,EnDataMatrix和EnHanxin.dll。 大家可以参照下图放置DLL和INI的目录位置。

  • 02

    '动态链接库引用 (说明:下面是所有四种条码的接口引用申明,读者可以适当剪裁) '串口接口 Private Declare FunctionInitRead Lib "EnCodePdf.dll" (ByVal hcallwnd As Long, ByVal pathnameAs String) As Long Private Declare FunctionCloseRead Lib "EnCodePdf.dll" () As Long '生成PDF417接口 Private Declare SubSetPdfConFile Lib "EnCodePdf.dll" (ByVal confile As String) Private Declare FunctionEnPdfText Lib "EnCodePdf.dll" (ByVal txtData As String, ByVal outfileAs String) As String Private Declare FunctionEnCodePdf Lib "EnCodePdf.dll" (ByVal txtfile As String, ByVal outfileAs String) As String Private Declare FunctionMakePdf417 Lib "EnCodePdf.dll" (ByVal txtfile As String, ByValpictfile As String, ByVal otherfile As String, ByVal outfile As String) AsString '生成QrCode接口 Private Declare SubSetQrConFile Lib "EnCodeQr.dll" (ByVal confile As String) Private Declare FunctionEnQrText Lib "EnCodeQr.dll" (ByVal txtData As String, ByVal outfileAs String) As String Private Declare FunctionEnCodeQr Lib "EnCodeQr.dll" (ByVal txtfile As String, ByVal outfileAs String) As String Private Declare FunctionMakeQrCode Lib "EnCodeQr.dll" (ByVal txtfile As String, ByVal pictfileAs String, ByVal otherfile As String, ByVal outfile As String) As String '生成DataMatrix接口 Private Declare SubSetDmConFile Lib "EnDataMatrix.dll" (ByVal confile As String) Private Declare FunctionEnDmText Lib "EnDataMatrix.dll" (ByVal txtData As String, ByValoutfile As String) As String Private Declare FunctionEnDataMatrix Lib "EnDataMatrix.dll" (ByVal txtfile As String, ByValoutfile As String) As String Private Declare FunctionMakeDataMatrix Lib "EnDataMatrix.dll" (ByVal txtfile As String, ByValpictfile As String, ByVal otherfile As String, ByVal outfile As String) AsString '生成HanXin接口 Private Declare SubSetHxConFile Lib "EnHanXin.dll" (ByVal confile As String) Private Declare FunctionEnHxText Lib "EnHanXin.dll" (ByVal txtData As String, ByVal outfileAs String) As String Private Declare FunctionEnCodeHx Lib "EnHanXin.dll" (ByVal txtfile As String, ByVal outfileAs String) As String Private Declare FunctionMakeHanXin Lib "EnHanXin.dll" (ByVal txtfile As String, ByValpictfile As String, ByVal otherfile As String, ByVal outfile As String) AsString 'WAPI接口 Private Declare FunctionSetCurrentDirectory Lib "kernel32" Alias"SetCurrentDirectoryA" (ByVal lpPathName As String) As Long Private Declare FunctionWritePrivateProfileString Lib "kernel32" Alias"WritePrivateProfileStringA" (ByVal lpApplicationName As String,ByVal lpKeyName As Any, ByVal lpString As Any, ByVal lpFileName As String) AsLong Private Declare FunctionGetPrivateProfileInt Lib "kernel32" Alias"GetPrivateProfileIntA" (ByVal lpApplicationName As String, ByVallpKeyName As String, ByVal nDefault As Long, ByVal lpFileName As String) AsLong Private Declare FunctionGetPrivateProfileString Lib "kernel32" Alias"GetPrivateProfileStringA" (ByVal lpApplicationName As String, ByVallpKeyName As Any, ByVal lpDefault As String, ByVal lpReturnedString As String,ByVal nSize As Long, ByVal lpFileName As String) As Long Private Declare FunctionSetWindowLong Lib "user32" Alias "SetWindowLongA" (ByValhwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long Private Declare FunctionSetParent Lib "user32" (ByVal hWndChild As Long, ByVal hWndNewParentAs Long) As Long '生成图像小波压缩接口 'exports from nlcomp.dll   图像压缩函数 Private Declare FunctionSizeDIB Lib "Wcomp.dll" (ByVal oldmap As String, ByVal BmpHeight AsInteger, ByVal BmpWidth As Integer) As Long Private Declare FunctionWcompress Lib "Wcomp.dll" (ByVal infile As String, ByVal outfile AsString, ByVal budget As Long) As Long Private Declare FunctionWdecompress Lib "Wcomp.dll" (ByVal infile As String, ByVal outfile AsString) As Long

  • 03

    进行条形码制作: 我们在引用API接口后,可以参照下面程序,实现接口调用 程序中txtfile表示文本文件名,binBmpFile表示输入的图像文件名 若需要装载图像可以采用Make开头接口,若不需要则采用En开头接口。 If (txtfile<> "" Or binBmpFile <> "") Then If m_bWorkMode = 1 Then     'PDF417 SetPdfConFile (Edit_ConFileName.Text) If (Edit_ImgFileName.Text <> "") Then strBmpFile = MakePdf417(txtfile, binBmpFile,"", "") Else strBmpFile = EnPdfText(Edit_Source.Text,"") End If ElseIf m_bWorkMode = 2 Then 'Qr_Code SetQrConFile (Edit_ConFileName.Text) If (Edit_ImgFileName.Text <> "") Then strBmpFile = MakeQrCode(txtfile, binBmpFile,"", "") Else strBmpFile = EnQrText(Edit_Source.Text,"") End If ElseIf m_bWorkMode = 3 Then  ' DataMatrix SetDmConFile (Edit_ConFileName.Text) If (Edit_ImgFileName.Text <> "") Then strBmpFile = MakeDataMatrix(txtfile,binBmpFile, "", "") Else strBmpFile = EnDmText(Edit_Source.Text,"") End If Else SetHxConFile (Edit_ConFileName.Text) If (Edit_ImgFileName.Text <> "") Then strBmpFile = MakeHanXin(txtfile, binBmpFile,"", "") Else strBmpFile = EnHxText(Edit_Source.Text,"") End If End If

  • 04

    打开关闭串口: 条码编码控件一般自带串口接收处理接口: InitRead接口是初始化串口 CloseRead接口是关闭串口 If Cmd_OpenComm.Caption = "连接串口" Then Call SetPdfConFile(Edit_ConFileName.Text) If InitRead(Me.hwnd, App.Path + "\") = 1 Then Cmd_OpenComm.Caption = "断开串口" End If Else    '关闭串口 If CloseRead() = 1 Then Cmd_OpenComm.Caption = "连接串口" End If End If

  • 05

    接收条码识读器内容: 串口收到识读器信息后,以键盘消息的形式,触发页面消息。 我们调用FORM下,处理KeyDown事件。 Private Sub Form_KeyDown(KeyCode As Integer, Shift As Integer) Dim FileNo As Integer Dim strTmp As String Dim strBmpFile As String strBmpFile = App.Path & "\temp.bmp" If KeyCode = 255 Then FileNo = FreeFile() Open App.Path & "\temp.txt" For Input As #FileNo Edit_Source.Text = "" Do While Not EOF(FileNo) strTmp = "" Input #FileNo, strTmp Edit_Source.Text = Edit_Source.Text & strTmp & Chr(13) & Chr(10) Loop Close #FileNo If Dir(strBmpFile) <> "" Then Kill (strBmpFile) End If If Dir(App.Path & "\temp.img") <> "" Then If FileLen(App.Path & "\temp.img") > 10 Then Call Wdecompress(App.Path & "\temp.img", strBmpFile) End If End If If Dir(strBmpFile) <> "" Then Image_Bar.Picture = LoadPicture(strBmpFile) Else Image_Bar.Picture = LoadPicture("") End If Cmd_Print.Enabled = False End If End Sub

(0)

相关推荐

  • 微信小程序如何生成二维码?

    大家好,小编在这里教大家微信小程序如何生成二维码,希望能帮助到大家 操作方法 01 首先,大家在桌面上找到"微信"并点击打开 02 接下来,大家点击任何一个主页面的右上角的&quo ...

  • 小程序怎么生成二维码

    今天小编要和大家分享的是小程序怎么生成二维码,希望能够帮助到大家. 操作方法 01 首先在我们的电脑桌面上找到搜狗浏览器并点击它,如下图所示. 02 然后输入草料二维码生成器并点击回车键,如下图所示. ...

  • 如何在IE浏览器中将当前网页网址生成二维码

    现在在我们的网络活动中随时可以见到二维码,二维码确实给我们带来很多方便,用手机一扫即可打开二维码中包含的信息。 当我们在使用浏览器访问网站的时候经常可能会遇到这么一种情况,想把当前浏览的网页放在手机中 ...

  • word怎样生成二维码

    二维码对于我们来说已经是非常熟悉了,我们几乎天天都要和二维码见面,在办公软件中使用二维码也很常见了,那么你知道如何在word中生成二维码吗?今天就是教你如何用word生成二维码. 操作方法 01 这里 ...

  • 如何用手机生成二维码

    如何用手机生成二维码呢?今天小编为大家讲解一下. 操作方法 01 打开手机,进入微信,找到小程序,点击并进入,如图所示. 02 进入之后,在图示位置搜索"二维码生成器",如图所示. ...

  • 如何启用QQ浏览器网址生成二维码功能?QQ浏览器网址生成二维码的使用方法

    经常电脑上的网页没看完,结果下班时间到了,想回家继续看怎么办?电脑上看到喜欢的网页,如何便捷的、不需要帐号登录的、如何快速保存到手机或pad上?为了在这些场景下为大家提供便利,QQ浏览器提供了“网址生 ...

  • EXCEL表格怎么能自动生成二维码

    首先新建一个Excel表格,在A1单元格中输入需要生成二维码的代码信息. 1. 先要下载一个控件,地址:http://bbs.cfan.com.cn/thread-1611874-1-1.html[下 ...

  • 微信小程序怎么制作二维码表白?用微信小程序草料二维码表白的方法介绍

    微信小程序怎么制作二维码表白?最近,很多小伙伴在抖音APP中刷到了一个小视频,主要是教大家表白的,平时不好意思说出“我爱你”,那就让二维码来帮你表白吧.下面我们小编就教大家用微信小程序草料二维码表白的 ...

  • 支付宝app推荐有赏怎么生成二维码分享?

    支付宝所谓的赚钱红包,主要面向小商家,在付款时,商家可以推荐用户扫码领红包,金额在0.1元-99元不等,线下支付时能够自动用于抵扣金额. 普通用户每人每天可以领取一次赚钱红包,金额在0.1元-99元不 ...