Bluetooth связь с Arduino+Android
Я пытаюсь отправить байты с моего андроида на мое Arduino, чтобы он выключил / включил светодиод, который к нему подключен. Когда я открываю свое приложение для Android, оно сразу же переходит к "не отвечающему сообщению" и выключается.
Это код Android:
package com.example.arduino;
import java.io.IOException;
import java.io.OutputStream;
import java.util.UUID;
import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.bluetooth.BluetoothDevice;
import android.bluetooth.BluetoothSocket;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;
public class MainActivity extends Activity {
Button turnOn , turnOff;
BluetoothAdapter btAdapter;
OutputStream outStream;
BluetoothSocket btSocket;
byte one;
byte two;
BluetoothDevice btDevice;
String address = "40:98:4E:37:4E:51";
UUID uuid = UUID.fromString("00001101-0000-1000-8000-00805F9B34FB");
@SuppressWarnings("static-access")
@SuppressLint("ShowToast") @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
turnOn = (Button) findViewById(R.id.On);
turnOff = (Button) findViewById(R.id.Off);
one = 0;
two = 1;
btAdapter = BluetoothAdapter.getDefaultAdapter();
try {
outStream = btSocket.getOutputStream();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
btDevice = btAdapter.getRemoteDevice(address);
try {
btSocket = btDevice.createRfcommSocketToServiceRecord(uuid);
btSocket.connect();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
if(btDevice.ACTION_ACL_CONNECTED != null){ //Suppressed.
Toast.makeText(getBaseContext(), "Connected!", Toast.LENGTH_SHORT).show(); //Suppressed.
}
turnOn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
ledOn();
}
private void ledOn() {
// TODO Auto-generated method stub
try {
outStream.write(one);
outStream.flush();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
outStream.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
turnOff.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
ledOff();
}
private void ledOff() {
// TODO Auto-generated method stub
try {
outStream.write(two);
outStream.flush();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
outStream.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
});
}
@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;
}
}
Logcat:
10-17 23:32:05.269: W/dalvikvm(21770): threadid=1: thread exiting with uncaught exception (group=0x40c7ea08)
10-17 23:32:05.269: E/AndroidRuntime(21770): FATAL EXCEPTION: main
10-17 23:32:05.269: E/AndroidRuntime(21770): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.arduino/com.example.arduino.MainActivity}: java.lang.NullPointerException
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2463)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2520)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread.access$600(ActivityThread.java:162)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1366)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.os.Handler.dispatchMessage(Handler.java:99)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.os.Looper.loop(Looper.java:158)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread.main(ActivityThread.java:5751)
10-17 23:32:05.269: E/AndroidRuntime(21770): at java.lang.reflect.Method.invokeNative(Native Method)
10-17 23:32:05.269: E/AndroidRuntime(21770): at java.lang.reflect.Method.invoke(Method.java:511)
10-17 23:32:05.269: E/AndroidRuntime(21770): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1083)
10-17 23:32:05.269: E/AndroidRuntime(21770): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:850)
10-17 23:32:05.269: E/AndroidRuntime(21770): at dalvik.system.NativeStart.main(Native Method)
10-17 23:32:05.269: E/AndroidRuntime(21770): Caused by: java.lang.NullPointerException
10-17 23:32:05.269: E/AndroidRuntime(21770): at com.example.arduino.MainActivity.onCreate(MainActivity.java:44)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.Activity.performCreate(Activity.java:5165)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1103)
10-17 23:32:05.269: E/AndroidRuntime(21770): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2419)
10-17 23:32:05.269: E/AndroidRuntime(21770): ... 11 more
1 ответ
Решение
Вы используете переменную btSocket до ее инициализации. В вашем методе onCreate попробуйте добавить это:
try {
outStream = btSocket.getOutputStream();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
после этого:
btDevice = btAdapter.getRemoteDevice(address);
try {
btSocket = btDevice.createRfcommSocketToServiceRecord(uuid);
btSocket.connect();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}