• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 686
  • Last Modified:

Using MScomm with several serial ports

I have an old VB6 aplication that uses MScomm to with a scanner to scan labels. I need to modify the code so that several scanners can be attached via a multi port system. This system uses two timer controls. I have modified the code to use more timer contrls, but it always seems to go through the loop only once and does not extend to the second or third scanner.
Below is the procedure to which scanner and mscomm parameters are passed. Any ideas?
Private Sub StartScanning(mscomm As mscomm, objTimer As Timer, objTimer2 As Timer)
    Dim bStarted As Boolean
    Dim sInstring As String
    Dim bDone As Boolean
 
    On Error GoTo Errorhandler
 
    bStarted = False
 
    DoEvents
    objTimer.Enabled = True
    sInstring = ""
    txtInput.Text = ""
 
    bDone = False
    bStop = False
 
    'Tell the control to read entire buffer when Input is used
    mscomm.InputLen = 0
 
    If mscomm.PortOpen = False Then
       mscomm.PortOpen = True
    End If
 
    StatusBar1.Panels(1).Text = "Waiting for Scanned Labels ..."
    StatusBar1.Panels(1).Width = StatusBar1.Width - (StatusBar1.Panels(2).Width + StatusBar1.Panels(3).Width)
 
    sInstring = ""
 
    'Do While Not bDone
    Do While bStop = False
       DoEvents
       Do While mscomm.InBufferCount > 0
            StatusBar1.Panels(1).Text = "Reading Scanned Labels ..."
            StatusBar1.Panels(1).Width = StatusBar1.Width - (StatusBar1.Panels(2).Width + StatusBar1.Panels(3).Width)
 
            bStarted = True
            DoEvents
 
            'do not switch to line after to see newly scanned labels first - did not work
            'sInstring$ = MSComm1.Input & sInstring$
 
            'next line is the right order
            sInstring$ = sInstring$ & mscomm.Input
            txtInput.Text = sInstring
 
            objTimer.Interval = 100
            objTimer.Enabled = True
            Do While objTimer2.Enabled = True
               DoEvents
            Loop
       Loop
       If mscomm.InBufferCount = 0 And bStarted = True Then
          bDone = True
       End If
    Loop
 
    txtInput.Text = sInstring
    objTimer.Enabled = False
 
    If mscomm.PortOpen = True Then
       mscomm.PortOpen = False
    End If
 
'    ' * make the call to stop based on the control passed as parameter object
'    If bStop = True Then
'        Select Case mscomm
'        Case MSComm1
'            Call cmdStop_Click
'        Case MSComm2
'            Call cmdStop2_Click
'        Case MSComm3
'            Call cmdStop3_Click
'        End Select
'    End If
 
    Exit Sub
 
Errorhandler:
    If Err = 8005 Then
       MsgBox ("Port Already Open - Change Settings and Select a Different Port Number")
       Err.Clear
       Exit Sub
    End If
    If Err = 8002 Then
       MsgBox ("Invalid Port Number - Change Settings and Select a Different Port Number")
       Err.Clear
       Exit Sub
    End If
 
    Err.Clear
End Sub
 
 Private Sub cmdStop2_Click()
    Call StopScanning(MSComm2, gsScanner2)
 End Sub

Open in new window

0
ochang435
Asked:
ochang435
1 Solution
 
DauheeCommented:
you could get a timer to kick off multiple instances of StartScanning but might be easier in long run (but more coding up front) to put into an activeX control and then place multiple controls on the form - 1 for every scanner

basically you need multi-threading so that is a workaround vb6 style :)
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Get your problem seen by more experts

Be seen. Boost your question’s priority for more expert views and faster solutions

Tackle projects and never again get stuck behind a technical roadblock.
Join Now