gFinger 손끝으로 만드는 세상

 

봉신 로드셀 인디게이터의 Data를 rs232 통신으로 읽어서 화면에 출력 하는 예제이다.

 

주요 코드를 소개 하면 …

 

<port open>

If comWeigher.PortOpen = True Then comWeigher.PortOpen = False
comWeigher.CommPort = 1
comWeigher.Settings = "9600,N,8,1"
comWeigher.PortOpen = True  '현재 포트를 연다.

 

<Weigher에서 오는 데이터를 분석 필터링한다>

Do
   DoEvents
   ComBuffer = ComBuffer & comWeigher.Input
   Position = InStr(1, ComBuffer, "#000", vbBinaryCompare)
   If Position > 0 Then
      ComBuffer = Mid(ComBuffer, Position)
      If InStr(1, ComBuffer, "Kg", vbBinaryCompare) Then
         Result1 = Mid$(ComBuffer, 10, 8)
         Result = ""
         For i = 1 To Len(Result1)
            If Mid(Result1, i, 1) >= "0" And Mid(Result1, i, 1) <= "9" Then
               Result = Result + Mid(Result1, i, 1)
            End If
         Next i
         Exit Do
      End If
   End If
   Text1.Text = ComBuffer
Loop While (Timer1.Enabled = True) ' 5 sec 이후에는 timer 가 중지 됨

Program Source

다음은 중량을 측정하는 저울의 무게를 RS-232 통신으로 일정 시간 마다 읽어 Display하는 소스의 핵심 부분이다.

 

If comWeigher.PortOpen = True Then comWeigher.PortOpen = False
comWeigher.CommPort = 1
comWeigher.Settings = "9600,N,8,1"
comWeigher.PortOpen = True  '현재 포트를 연다.
Text2.Text = comWeigher.PortOpen
Timer1.Enabled = True
Timer1.Interval = 5000 ' 5 sec
buffer$ = ""

Do
   DoEvents
   buffer$ = buffer$ & comWeigher.Input
   Position = InStr(1, buffer$, "#0001    ", vbBinaryCompare)
   If Position > 0 Then
      buffer$ = Mid(buffer$, Position)
      If InStr(1, buffer$, "Kg", vbBinaryCompare) Then
         result1 = Mid$(buffer$, 10, 8)
         result = ""
         For i = 1 To Len(result1)
            If Mid(result1, i, 1) >= "0" And Mid(result1, i, 1) <= "9" Then
               result = result + Mid(result1, i, 1)
            End If
         Next i
         Exit Do
      End If
   End If
   Text1.Text = buffer$
Loop While (Timer1.Enabled = True) ' 5 sec 이후에는 timer 가 중지 됨
comWeigher.PortOpen = False  ' 포트를 닫는다.
Text2.Text = comWeigher.PortOpen
Text1.Text = Val(result)
Timer1.Enabled = False