前提・実現したいこと
Bluetoothを用いて計量器から重量を取得するようなスマホアプリを作成中です。
計量器のMacアドレスはわかりましたので、BluetoothSocketをConnectしたいのですが、エラーとなってしまいます(read failed, socket might closed or timeout, read ret: -1)。
Androidの実機と計量器はすでにペアリング済みです。
Java
1MainActivity 2 3public class MainActivity extends AppCompatActivity { 4 5 private BluetoothAdapter mBluetoothAdapter; // BTアダプタ 6 private String mMacAdress = "**:**:**:**:**:**"; // Macアドレス 7 private BluetoothDevice mBtDevice; // BTデバイス 8 private BluetoothSocket mBtSocket; // BTソケット 9 private BluetoothServerSocket mBtServerSocket; 10 private InputStream mInput; // 入力ストリーム 11 12 @Override 13 protected void onCreate(Bundle savedInstanceState) { 14 super.onCreate(savedInstanceState); 15 setContentView(R.layout.activity_main); 16 17 checkPermission(); 18 19 mBluetoothAdapter = BluetoothAdapter.getDefaultAdapter(); 20 21 mBtDevice = mBluetoothAdapter.getRemoteDevice(mMacAdress); 22 23 // BTソケットのインスタンスを取得 24 try { 25 // 接続に使用するプロファイルを指定 26 mBtSocket = mBtDevice.createRfcommSocketToServiceRecord( 27 UUID.fromString("00001101-0000-1000-8000-00805F9B34FB")); 28 29 } catch (IOException e) { 30 e.printStackTrace(); 31 32 } 33 34 // ソケットを接続する 35 try { 36 mBtSocket.connect(); 37 38 } catch (IOException e) { 39 e.printStackTrace(); 40 Log.e(TAG, "IOException", e); 41 } finally{ 42 try { 43 mBtSocket.close(); 44 Log.e(TAG, "The connect socket was closed"); 45 } catch (IOException e) { 46 Log.e(TAG, "Could not close the connect socket", e); 47 } 48 } 49 } 50 51//permissionがないと動かないので注意 52 private void checkPermission(){ 53 54 final int REQUEST_PERMISSION = 1; 55 String[] PERMISSIONS_COARSE_LOCATION = { 56 Manifest.permission.ACCESS_COARSE_LOCATION 57 }; 58 59 int permission = ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION); 60 if (permission != PackageManager.PERMISSION_GRANTED) { 61 // We don't have permission so prompt the user 62 ActivityCompat.requestPermissions( 63 this, 64 PERMISSIONS_COARSE_LOCATION, 65 REQUEST_PERMISSION 66 ); 67 } else { 68 //何もしない 69 } 70 } 71} 72
xml
1 2AndroidManifest.xml 3 4<?xml version="1.0" encoding="utf-8"?> 5<manifest xmlns:android="http://schemas.android.com/apk/res/android" 6 package="com.example.bluetoothconnecttest"> 7 8 <uses-permission android:name="ANDROID.PERMISSION.INTERNET" /> 9 <uses-permission android:name="android.permission.BLUETOOTH" /> 10 <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" /> <!-- Bluetoothデバイスのスキャン機能を使用するためのパーミッションとして、位置情報のパーミッションがAndroid 6.0から必要になった --> 11 <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> 12 13 14 <application 15 android:allowBackup="true" 16 android:icon="@mipmap/ic_launcher" 17 android:label="@string/app_name" 18 android:roundIcon="@mipmap/ic_launcher_round" 19 android:supportsRtl="true" 20 android:theme="@style/Theme.BluetoothConnectTest"> 21 <activity android:name=".MainActivity"> 22 <intent-filter> 23 <action android:name="android.intent.action.MAIN" /> 24 25 <category android:name="android.intent.category.LAUNCHER" /> 26 </intent-filter> 27 </activity> 28 </application> 29 30</manifest>
発生している問題・エラーメッセージ
Java
12020-11-16 16:45:55.249 12323-12323/com.example.bluetoothconnecttest E/TAG: IOException 2 java.io.IOException: read failed, socket might closed or timeout, read ret: -1 3 at android.bluetooth.BluetoothSocket.readAll(BluetoothSocket.java:762) 4 at android.bluetooth.BluetoothSocket.readInt(BluetoothSocket.java:776) 5 at android.bluetooth.BluetoothSocket.connect(BluetoothSocket.java:399) 6 at com.example.bluetoothconnecttest.MainActivity.onCreate(MainActivity.java:62)
この62行は、mBtSocket.connect();を示します。
試したこと
2種類の方法でmBtSocketの取得を試みましたが、同じエラーが表示されました。
①
Java
1Method m = mBtDevice.getClass().getMethod("createInsecureRfcommSocket", new Class[] {int.class}); 2mBtSocket = (BluetoothSocket) m.invoke(mBtDevice, 1);
②
Java
1mBtSocket = mBtDevice.createInsecureRfcommSocketToServiceRecord( UUID.fromString("00001101-0000-1000-8000-0805F9B34FB"));
また、AndroidStudioでスキャナとBluetoothで接続を参考にBlutoothServerSocketも使用してみましたが、こちらもうまくいきませんでした(この場合はエラーは出ず、ずっと接続を試みているような状態になりました)。
補足情報(FW/ツールのバージョンなど)
Android Studio 4.1
デバック用実機 Lenovo TB-8505F(Android 9)
よろしくお願いいたします。
あなたの回答
tips
プレビュー