我有一个支持OBEX对象推送配置文件的设备,此配置文件基于串行端口配置文件。我的猜测是我可以使用Android蓝牙聊天示例将此设备连接到我的Android手机。但是我遇到了一个问题,关于android SDK中的socket.accept()
功能。我尽力去完成我的电话与该设备这样的连接:BluetoothServerSocket接受失败并抛出IOException
adapter = BluetoothAdapter.getDefaultAdapter();
device = adapter.getRemoteDevice("00:1B:DC:0F:EC:7E");
AcceptThread = new AcceptThread(true, adapter, device);
AcceptThread.start();
在AcceptThread构造函数编码是这样的:
public AcceptThread(boolean secure, BluetoothAdapter adapter, BluetoothDevice device) {
BluetoothServerSocket tmp = null;
this.adapter = adapter;
this.device = device;
// Create a new listening server socket
try {
tmp = adapter.listenUsingInsecureRfcommWithServiceRecord(device.getName(), UUID.fromString("00001101-0000-1000-8000-00805F9B34FB"));
} catch (Exception e) {
Log.e(TAG, ".AcceptThread # listen() failed", e);
}
mmServerSocket = tmp;
}
问题是,当我尝试做一个connect()
正如我说的前
public void run() {
BluetoothSocket socket = null;
// Listen to the server socket if we're not connected
while (mState != STATE_CONNECTED) {
try {
// This is a blocking call and will only return on a
// successful connection or an exception
Log.d(TAG, "AcceptThread.run: accepting server socket connection");
socket = mmServerSocket.accept(20000);
Log.d(TAG, ".AcceptThread.run # server socket connection accepted");
} catch (Exception e) {
Log.e(TAG, ".run # accept() failed: "+e);
break;
}
}
}
正如你可以看到的ServerSocket接受20 seconds
或20000 ms.
当时间到了,该应用程序的无线进来的每一个连接会抛出一个IOException像这样
07-11 10:30:08.355: E/SIMPLECONNECT(1301): .run # accept() failed: java.io.IOException: Connection timed out
它告诉我,我的设备无法连接到我的android手机。该设备没有显示器上的连接按钮,只是一个发送功能,它将文件发送到我的手机。我相信这个发送功能也会在后台进行连接,但我不确定。
任何人都可以为我找出任何解决方案吗?我正在运行我的应用Samsung Galaxy SIII
与Android 4.0.4
在三星xcover相同的问题,seemes是一个三星的问题,因为我的其他设备适用于相同的代码。我向三星的支持报告了这个问题,但我并不期待...所以我会开始一个小赏金。 – 2red13 2012-08-06 18:06:40