gpt4 book ai didi

java - Android USB 转串口接收错误

转载 作者:行者123 更新时间:2023-12-01 13:54:00 26 4
gpt4 key购买 nike

我目前正在 Android 上编写一个应用程序来与 Arduino 板交互。我能够很好地向我的 Arduino 发送串行数据,但是当我开始尝试接收数据时,我的应用程序在启动时崩溃了。

我目前已将其设置为文本字段从用户处获取数据,并将其发送到 Arduino,Arduino 执行一个功能。

对于我的接收,我在启动时创建一个新线程来不断监听来自 Arduino 的数据。每当执行该线程中的代码时,它就会崩溃。

我使用这个库作为我的基础:https://github.com/mik3y/usb-serial-for-android

下面是所有相关代码,省略了此应用程序提供的其他功能的代码,这些功能未涉及:

import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;



import com.hoho.android.usbserial.driver.UsbSerialDriver;


import android.hardware.usb.UsbManager;
import android.content.Intent;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import android.content.Context;
import android.util.Log;
import com.hoho.android.usbserial.driver.UsbSerialProber;




public class MainActivity extends Activity implements SensorEventListener, LocationListener{

private EditText sendTextField;
TextView uartRX;

public Handler Handler;


UsbManager manager;



/** Called to create application activity*/
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);



uartRX = (TextView)findViewById(R.id.rxUART);

sendTextField = (EditText) findViewById(R.id.sendTextField);






Handler = new Handler() {
@Override public void handleMessage(Message msg) {
String text = (String)msg.obj;
uartRX.append(text);




}
};


Thread t = new Thread(new Runnable() {
public void run()
{
Message msg = new Message();
msg.obj = "Start Serial Listen\n";
Handler.sendMessage(msg);
rxUART();
}

public void rxUART()
{

manager = (UsbManager) getSystemService(Context.USB_SERVICE);
UsbSerialDriver rxDriver = UsbSerialProber.acquire(manager);
if (rxDriver != null) {
try {
rxDriver.open();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}


int byteSize = 0;
String data = "";
while(true)
{
byte[] arr = null;
try {
rxDriver.setBaudRate(115200);
rxDriver.read(arr, byteSize);
data = new String(arr);
Message msg = new Message();
msg.obj = data;
Handler.sendMessage(msg);

} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

});
t.start();

}


public void sendUART(String data)
{
manager = (UsbManager) getSystemService(Context.USB_SERVICE);
// Find the first available driver.
UsbSerialDriver driver = UsbSerialProber.acquire(manager);
if (driver != null) {
try {
driver.open();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
try {
driver.setBaudRate(115200);

byte buffer[] = new byte[16];
int numBytesRead = driver.read(buffer, 1000);
Log.d(TAG, "Read " + numBytesRead + " bytes.");


byte temp[] = data.getBytes();

driver.write(temp, 16);

} catch (IOException e) {
// Deal with error.
} finally {
try {
driver.close();
} catch (IOException e) {
// TODO Auto-generated catch block

e.printStackTrace();
}
}
}



}
public void onClickSendBtn(View v)
{
String data = "";
data = sendTextField.getText().toString();
sendUART(data);
sendTextField.setText(" ");
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}







}

谁能帮我弄清楚为什么应用程序在线程中创建的代码上崩溃?

注意:代码不在线程中时也会崩溃。代码最初是由 sendUART() 调用的函数,用于检查响应。也没有 while(true)。

日志猫:

   11-02 09:49:22.988: E/AndroidRuntime(22652): FATAL EXCEPTION: Thread-964
11-02 09:49:22.988: E/AndroidRuntime(22652): java.lang.NullPointerException
11-02 09:49:22.988: E/AndroidRuntime(22652): at com.example.sensortest.MainActivity$2.rxUART(MainActivity.java:143)
11-02 09:49:22.988: E/AndroidRuntime(22652): at com.example.sensortest.MainActivity$2.run(MainActivity.java:119)
11-02 09:49:22.988: E/AndroidRuntime(22652): at java.lang.Thread.run(Thread.java:856)

引用的行号是:

           Thread t = new Thread(new Runnable() {
public void run()
{
Message msg = new Message();
msg.obj = "Start Serial Listen\n";
Handler.sendMessage(msg);
rxUART();
}

public void rxUART()
{

manager = (UsbManager) getSystemService(Context.USB_SERVICE);
UsbSerialDriver rxDriver = UsbSerialProber.acquire(manager);
if (rxDriver != null) {
try {
rxDriver.open();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}


int byteSize = 0;
String data = "";
while(true)
{
byte[] arr = null;
try {
rxDriver.setBaudRate(115200);
rxDriver.read(arr, byteSize);
data = new String(arr);
Message msg = new Message();
msg.obj = data;
Handler.sendMessage(msg);

} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}

});
t.start();

最佳答案

您没有正确处理 rxUart() 中的 rxDriver == null 情况。

if() 语句仅跳过 open() 调用,但 while() 循环使用 rxDriver 执行NULL 导致 NPE。顺便说一句,您在 `sendUART() 中也遇到了同样的问题。

关于java - Android USB 转串口接收错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19739058/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com