VisualBasicのシリアルポートメソッドを使い、RS232-C通信を試そうとしている初心者です。
現在、別のPCからTeratermより文字を送り、自分のPCで受信結果を得ようとしているのですが
別PCから単発で文字を送っても、自分のPCでは反応せず
キーボードを押しっぱなしにすると、自分のPCのウィンドウに受信結果が表示されます。
一体、何が原因なのでしょうか?
さっぱり、わからず途方に暮れています。
下記にソースコードを記載しますので、詳しい方は教えて下さると幸いです。
------------------------------------------------------------------------
Public Delegate Sub MyDelegate(ByVal intData As Integer)
Private Sub AddData(ByVal str As String)
TextBox1.Text = str
End Sub
Private Sub SerialPort1_DataReceived(ByVal sender As Object, ByVal e As System.IO.Ports.SerialDataReceivedEventArgs) Handles SerialPort1.DataReceived
Dim dlgByte As MyDelegate = New MyDelegate(AddressOf AddData)
Dim ByteRead(SerialPort1.BytesToRead - 1) As Byte
SerialPort1.Read(ByteRead, 0, SerialPort1.BytesToRead)
For i As Integer = 0 To ByteRead.Length - 1
Me.Invoke(dlgByte, ByteRead(0))
Next
End Sub
------------------------------------------------------------------------
No.1
- 回答日時:
> TextBox1.Text = str
TextBox1.Text = TextBox1.Text + str
にしないと下のInvokeで常に一文字分で上書きされます。
複数バイトを受信していても、見た目には「常に最後の一文字だけが表示されている」ようにしか見えないでしょう。
> Private Sub SerialPort1_DataReceived(以下略)
このメソッドはシリアルポートのイベントとして正しく登録されていますか?
> Me.Invoke(dlgByte, ByteRead(0))
引数はByteRead(i)でないとせっかく読んだデータの先頭しか渡りません。
あとAddDataの引数型がStringでデリゲートの引数型がIntegerで実際に渡している引数の型がByteという不整合っぷりが問題になっている可能性があります。
デリゲートの引数型をStringにして、Invokeで渡す引数をToString()でString変換してから渡す方が確実そうな……
ご回答ありがとうございます。
初心者なものでわからないもので
>> Private Sub SerialPort1_DataReceived(以下略)
> このメソッドはシリアルポートのイベントとして正しく登録されていますか?
は前に宣言等が必要ということでしょうか?
No.2ベストアンサー
- 回答日時:
SerialPort1がデザイナで配置したSerialPortなら、そのプロパティを見てイベントのDataReceivedのところにその関数名があればOKです。
デザイナで配置した物でないならもちろん「イベントに登録する」というコードを書く必要があります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) 九九の答えの計算 3 2022/12/20 22:13
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
mainメソッドのthrows節で設定...
-
onClickで関数呼出し後に、結果...
-
Labelコントロールに数字を代入...
-
final修飾子を使っているのに、...
-
Excel VBA でExcelを終了したい...
-
引数で日付を2つ与え、その間の...
-
ExcelのxlDialogInsertPictureで。
-
DataGridViewの行追加について。
-
Excel VBA シェイプの原型のサ...
-
Refreshメソッドの使い方
-
javascriptからjavaを呼び出したい
-
c#でVBのcall的役割を果たすコ...
-
エクセルVBAにおけるON TIMEメ...
-
【sendkeysメソッドが動かずに...
-
FEM解析の読み方は?
-
配列のメソッド
-
{}の意味は
-
処理内容がほぼ同じメソッドの...
-
VBAでSaveAs使用し、指定してい...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
Labelコントロールに数字を代入...
-
final修飾子を使っているのに、...
-
エクセルVBAにおけるON TIMEメ...
-
コマンドプロンプト実行後に画...
-
mainメソッドのthrows節で設定...
-
DataGridViewでセルクリックイ...
-
javascriptからjavaを呼び出したい
-
VBPをダブルクリックするとたま...
-
onClickで関数呼出し後に、結果...
-
ExcelのxlDialogInsertPictureで。
-
Refreshメソッドの使い方
-
JSPで<SELECT>の中にDBから持っ...
-
【sendkeysメソッドが動かずに...
-
ウィンドウを最前面にできません
-
(String args[])というメッソ...
-
C# 演算 最大値 最小値 表現の仕方
-
Excel VBA シェイプの原型のサ...
-
VB.netで、シリアル通信のタイ...
-
boolean型のフィールドとゲッタ...
おすすめ情報