Почему мой цикл for не работает?
Я пытаюсь выполнить небольшой тест, чтобы увидеть, соответствует ли отправленное значение полученному значению. однако, в большинстве случаев полученное значение, кажется, на один шаг позади!
For i As Decimal = 0 To 127
j = Hex(i)
stsResult = PCANBasic.Read(m_PcanHandle, myCANMsg, CANTimeStamp)
CANMsg = New TPCANMsg()
CANMsg.DATA = CType(Array.CreateInstance(GetType(Byte), 8), Byte())
CANMsg.ID = Convert.ToInt32(240, 16)
CANMsg.LEN = Convert.ToByte(8)
CANMsg.MSGTYPE = TPCANMessageType.PCAN_MESSAGE_STANDARD
CANMsg.DATA(3) = Convert.ToByte(10, 16)
CANMsg.DATA(4) = Convert.ToByte(j, 16)
CANMsg.DATA(5) = Convert.ToByte(99, 16)
PCANBasic.Write(m_PcanHandle, CANMsg)
ReadAnalogVal() ' Sents a request message so that the it updates the message about to be read
stsResult = PCANBasic.Read(m_PcanHandle, myCANMsg, CANTimeStamp) 'reads bus and populates var myCANMsg with the data
hiBit = Hex(myCANMsg.DATA(0))
If (stsResult <> TPCANStatus.PCAN_ERROR_QRCVEMPTY) Then
If myCANMsg.ID = 960 And hiBit = j Then
MessageBox.Show("you sent: " & j & " and Recieved: " & hiBit)
Else
MessageBox.Show("Response did NOT match output. Output:" & j & " Recieved: " & hiBit)
End If
End If
Next
CANMsg = New TPCANMsg()
CANMsg.DATA = CType(Array.CreateInstance(GetType(Byte), 8), Byte())
CANMsg.ID = Convert.ToInt32(240, 16)
CANMsg.LEN = Convert.ToByte(8)
CANMsg.MSGTYPE = TPCANMessageType.PCAN_MESSAGE_STANDARD
CANMsg.DATA(3) = Convert.ToByte(0, 16)
CANMsg.DATA(4) = Convert.ToByte(0, 16)
PCANBasic.Write(m_PcanHandle, CANMsg)
iBuffer = PCANBasic.PCAN_FILTER_OPEN
result = PCANBasic.SetValue(PCANBasic.PCAN_USBBUS1, TPCANParameter.PCAN_MESSAGE_FILTER, iBuffer, Convert.ToUInt32(Len(iBuffer)))
If result <> TPCANStatus.PCAN_ERROR_OK Then
' An error occurred, get a text describing the error and show it
'
PCANBasic.GetErrorText(result, 0, strMsg)
MessageBox.Show(strMsg.ToString)
Else
MessageBox.Show("Filter is open again")
End If
End Function
Похоже, что это работает в некоторых случаях, а затем в большинстве случаев это не соответствует, любой совет будет оценен. это мое первое приложение на VB.NET, поэтому я могу сделать любительскую ошибку. Я посмотрел на многопоточность, но я не совсем уверен, как заставить это работать в этом случае.
Вот еще из приложения:
Imports System.Text
' Inclusion of PEAK PCAN-Basic namespace
'
Imports System.Text
Inclusion of PEAK PCAN-Basic namespace
Imports Peak.Can.Basic
Imports TPCANHandle = System.UInt16
Imports TPCANBitrateFD = System.String
Imports TPCANTimestampFD = System.UInt64
Public Class Form1
Public Sub New()
' Initializes Form's component
'
InitializeComponent()
' Initializes specific components
'
InitializeBasicComponents()
End Sub
''' <summary>
''' Message Status structure used to show CAN Messages
''' in a ListView
''' </summary>
Private Class MessageStatus
Private m_Msg As TPCANMsgFD
Private m_TimeStamp As TPCANTimestampFD
Private m_oldTimeStamp As TPCANTimestampFD
Private m_iIndex As Integer
Private m_Count As Integer
Private m_bShowPeriod As Boolean
Private m_bWasChanged As Boolean
Public Sub New(ByVal canMsg As TPCANMsgFD, ByVal canTimestamp As TPCANTimestampFD, ByVal listIndex As Integer)
m_Msg = canMsg
m_TimeStamp = canTimestamp
m_oldTimeStamp = canTimestamp
m_iIndex = listIndex
m_Count = 1
m_bShowPeriod = True
m_bWasChanged = False
End Sub
Public Sub Update(ByVal canMsg As TPCANMsgFD, ByVal canTimestamp As TPCANTimestampFD)
m_Msg = canMsg
m_oldTimeStamp = m_TimeStamp
m_TimeStamp = canTimestamp
m_bWasChanged = True
m_Count += 1
End Sub
Private Function GetMsgTypeString() As String
Dim strTemp As String
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_STATUS) = TPCANMessageType.PCAN_MESSAGE_STATUS Then
Return "STATUS"
End If
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_ERRFRAME) = TPCANMessageType.PCAN_MESSAGE_ERRFRAME Then
Return "ERROR"
End If
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_EXTENDED) = TPCANMessageType.PCAN_MESSAGE_EXTENDED Then
strTemp = "EXT"
Else
strTemp = "STD"
End If
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_RTR) = TPCANMessageType.PCAN_MESSAGE_RTR Then
strTemp += "/RTR"
Else
If (m_Msg.MSGTYPE > TPCANMessageType.PCAN_MESSAGE_EXTENDED) Then
strTemp += " [ "
If ((m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_FD) = TPCANMessageType.PCAN_MESSAGE_FD) Then
strTemp += " FD"
End If
If ((m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_BRS) = TPCANMessageType.PCAN_MESSAGE_BRS) Then
strTemp += " BRS"
End If
If ((m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_ESI) = TPCANMessageType.PCAN_MESSAGE_ESI) Then
strTemp += " ESI"
End If
strTemp += " ]"
End If
End If
Return strTemp
End Function
Private Function GetIdString() As String
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_EXTENDED) = TPCANMessageType.PCAN_MESSAGE_EXTENDED Then
Return String.Format("{0:X8}h", m_Msg.ID)
Else
Return String.Format("{0:X3}h", m_Msg.ID)
End If
End Function
Private Function GetDataString() As String
Dim strTemp As String
strTemp = ""
If (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_RTR) = TPCANMessageType.PCAN_MESSAGE_RTR Then
strTemp = "Remote Request"
Else
For i As Integer = 0 To Form1.GetLengthFromDLC(m_Msg.DLC, (m_Msg.MSGTYPE And TPCANMessageType.PCAN_MESSAGE_FD) = 0) - 1
strTemp += String.Format("{0:X2} ", m_Msg.DATA(i))
Next
End If
Return strTemp
End Function
Private Function GetTimeString() As String
Dim fTime As Double
fTime = (m_TimeStamp / 1000.0R)
If m_bShowPeriod Then
fTime -= (m_oldTimeStamp / 1000.0R)
End If
Return fTime.ToString("F1")
End Function
Public ReadOnly Property CANMsg() As TPCANMsgFD
Get
Return m_Msg
End Get
End Property
Public ReadOnly Property Timestamp() As TPCANTimestampFD
Get
Return m_TimeStamp
End Get
End Property
Public ReadOnly Property Position() As Integer
Get
Return m_iIndex
End Get
End Property
Public ReadOnly Property TypeString() As String
Get
Return GetMsgTypeString()
End Get
End Property
Public ReadOnly Property IdString() As String
Get
Return GetIdString()
End Get
End Property
Public ReadOnly Property DataString() As String
Get
Return GetDataString()
End Get
End Property
Public ReadOnly Property Count() As Integer
Get
Return m_Count
End Get
End Property
Public Property ShowingPeriod() As Boolean
Get
Return m_bShowPeriod
End Get
Set(ByVal value As Boolean)
If m_bShowPeriod Xor value Then
m_bShowPeriod = value
m_bWasChanged = True
End If
End Set
End Property
Public Property MarkedAsUpdated() As Boolean
Get
Return m_bWasChanged
End Get
Set(ByVal value As Boolean)
m_bWasChanged = value
End Set
End Property
Public ReadOnly Property TimeString() As String
Get
Return GetTimeString()
End Get
End Property
End Class
''' <summary>
''' Read-Delegate Handler
''' </summary>
Private Delegate Sub ReadDelegateHandler()
''' <summary>
''' Saves the desired connection mode
''' </summary>
Private m_IsFD As Boolean
''' <summary>
''' Saves the handle of a PCAN hardware
''' </summary>
Private m_PcanHandle As TPCANHandle
''' <summary>
''' Saves the baudrate register for a conenction
''' </summary>
Private m_Baudrate As TPCANBaudrate
''' <summary>
''' Saves the type of a non-plug-and-play hardware
''' </summary>
Private m_HwType As TPCANType
''' <summary>
''' Stores the status of received messages for its display
''' </summary>
Private m_LastMsgsList As System.Collections.ArrayList
''' <summary>
''' Read Delegate for calling the function "ReadMessages"
''' </summary>
Private m_ReadDelegate As ReadDelegateHandler
''' <summary>
''' Receive-Event
''' </summary>
Private m_ReceiveEvent As System.Threading.AutoResetEvent
''' <summary>
''' Thread for message reading (using events)
''' </summary>
Private m_ReadThread As System.Threading.Thread
''' <summary>
''' Handles of the current available PCAN-Hardware
''' </summary>
Private m_HandlesArray As TPCANHandle()