FrmQuickMarkAPIDemo (the form that uses QuickMarkAPI):
Public Class FrmQuickMarkAPIDemo
Private WithEvents aQuickMarkAPI As New QuickMarkAPI(AddressOf GetMsgString)
Public Sub New()
InitializeComponent()
End Sub
Private Sub MnuOK_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MnuOK.Click
aQuickMarkAPI.LaunchQuickMark()
End Sub
Private Sub GetMsgString(ByVal MsgString As String)
MsgBox(MsgString)
End Sub
'Just an alternative receive the message string using an event
'Private Sub aQuickMarkAPI_OnGetMsgString(ByVal MsgString As String) Handles aQuickMarkAPI.OnGetMsgString
' MsgBox(MsgString)
'End Sub
End Class
QuickMarkAPIDemo (The API itself):
Imports System.Diagnostics
Imports System.Runtime.InteropServices
Imports Microsoft.Win32
Imports System.IO
Imports Microsoft.WindowsCE.Forms
'QuickMark
'Flow of QuickMark Messenger
'Open msgapi --> Register a window message for inter-application communication (RegisterWindowMessage)
'-->launch QuickMark (Press OK button) --> send a unique message for inter-application communication(HWND_BROADCAST)
' --> QuickMark recevie the handle of msgapi's window. --> Decoding using QuickMark
' --> QuickMark send result to handle. --> msgapi show the result.
Class QuickMarkAPI
Inherits MessageWindow
<DllImport("coredll.dll")> _
Private Shared Function RegisterWindowMessage(ByVal lpString As String) As UInteger
End Function
<DllImport("coredll.dll", SetLastError:=True, CharSet:=CharSet.Auto)> _
Private Shared Function PostMessageW( _
ByVal hWnd As IntPtr, _
ByVal Msg As UInteger, _
ByVal wParam As IntPtr, _
ByVal lParam As IntPtr) As Boolean
End Function
Friend Shared ReadOnly HWND_BROADCAST As New IntPtr(65535)
'a unique message for inter-application communication
Private RM_QuickMarkMessengerAPIApp As UInt32 = 0
'Handle to the window whose window procedure will receive the decoded result.
Public Delegate Sub OnGetMsgStringHandler(ByVal MsgString As String)
Public DefaultBarcodeType As Integer = 2 'Default is 2D scanning.
Event OnGetMsgString As OnGetMsgStringHandler
Private Const WM_COPYDATA As Integer = 74
Private aGetMsgString As OnGetMsgStringHandler = Nothing
Public Sub LaunchQuickMark()
' Step 1: Get application path of QuickMark from registry.
Dim szQuickMarkApp As String = ""
Dim QuickMarkKey As RegistryKey = Registry.CurrentUser
QuickMarkKey = QuickMarkKey.OpenSubKey("Software\QuickMark", False)
szQuickMarkApp = QuickMarkKey.GetValue("QuickMarkAppPath").ToString()
QuickMarkKey.Close()
' Step 2: Set default path of QuickMark.
If szQuickMarkApp.Length = 0 Then
szQuickMarkApp = "\Program Files\QuickMark\QuickMark.exe"
End If
' Step 3: Launch QuickMark.
If File.Exists(szQuickMarkApp) Then
'Launch application
Dim P As New Process()
P.StartInfo.FileName = szQuickMarkApp
P.StartInfo.Verb = "Open"
P.Start()
P.WaitForExit(1000)
'wait 1 second
'step 4: send RM_QuickMarkMessengerAPIApp to all top windows.
'parameters:
' HWND hWnd : HWND_BROADCAST , all top windows.
' UINT Msg : A unique message for inter-application communication.
' WPARAM wParam : Handle to the window whose window procedure will receive the decoded result.
' LPARAM lParam : Set QuickMark application to 1D or 2D scanning. (1:1D 2:2D)
PostMessageW(HWND_BROADCAST, RM_QuickMarkMessengerAPIApp, Me.Hwnd, DefaultBarcodeType)
Else
MessageBox.Show("QuickMark not found!")
End If
End Sub
'Receive the decoded result.
'STRUCT COPYDATASTRUCT member
'dwData:Data types of data.
' TYPE_CHAR: The data is a Binary data.
' TYPE_WIDECHAR: The data is a Unicode string.
'lpData:Long pointer to data.
'cbData:Specifies the size, in bytes, of the data pointed to by the lpData member.
Public Structure COPYDATASTRUCT
Public dwData As Integer
Public cbData As Integer
Public lpData As IntPtr
End Structure
Public Sub New(ByVal aGetMsgString As OnGetMsgStringHandler)
Me.aGetMsgString = aGetMsgString
'Register a window message for inter-application communication
Me.RM_QuickMarkMessengerAPIApp = RegisterWindowMessage("QuickMarkMessengerAPIApplication")
End Sub
Protected Overloads Overrides Sub WndProc(ByRef msg As Message)
Select Case msg.Msg
Case WM_COPYDATA
Dim str As String = GetMsgString(msg.LParam)
'TODO:Add your code here to process with the str.
'MessageBox.Show(str, "Result")
If aGetMsgString IsNot Nothing Then
aGetMsgString.Invoke(str)
End If
RaiseEvent OnGetMsgString(str)
Exit Select
End Select
MyBase.WndProc(msg)
End Sub
Public Shared Function GetMsgString(ByVal lParam As IntPtr) As String
If lParam <> IntPtr.Zero Then
Dim st As COPYDATASTRUCT = DirectCast(Marshal.PtrToStructure(lParam, GetType(COPYDATASTRUCT)), COPYDATASTRUCT)
Dim str As String = Marshal.PtrToStringUni(st.lpData)
Return str
Else
Return Nothing
End If
End Function
End Class
Skylark Sales Corporation is a leading supplier of Labeling Equipment, Industrial Labels, Printed Labels, Barcode Labels, Food Labels, Security Labels, Packaging Labels, Product Labels, Holograms, Adhesive Tapes etc. In business since 1997, we have the experience necessary to help you with all of your marking and labeling needs.
ReplyDelete