Я недавно должен был сделать это. Я использовал API 8, так что только
BluetoothAdapter.listenUsingRfcommWithServiceRecord(String,UUID);
метод официально доступен.
Поскольку Android не обеспечивает постоянную видимость, я работал со списком устройств, сохраненных моим приложением.
Вот упрощение моего кода, который устанавливает Android в качестве сервера с сокетом прослушивания и телефоном j2me (я использовал Nokia N95) в качестве клиента для создания соединения RFCOMM.
Вот материал для Android:
int bytes = 0, offset = 0;
byte[] buffer;
BluetoothServerSocket btServerSocket = btAdapter.listenUsingRfcommWithServiceRecord("serv",myUUID);
BluetoothSocket btSocket = btServerSocket.accept();
OutputStream out = btSocket.getOutputStream();
InputStream in = btSocket.getInputStream();
bytes = in.read();
buffer = new byte[bytes];
out.write(0);
out.flush();
while (true)
{
bytes = in.read(buffer, offset, buffer.length - offset);
offset += bytes;
if (bytes == -1 || offset >= buffer.length)
{
Log.d("MyBT", "message: " + new String(buffer));
break;
}
}
out.close();
in.close();
btSocket.close();
btServerSocket.close();
и вот материал J2ME:
class ARemoteDevice extends javax.bluetooth.RemoteDevice
{
public ARemoteDevice(String btaddr)
{
super(btaddr);
}
}
RemoteDevice targetDevice = new ARemoteDevice("00FF00FF00FF");
String message = "Hello my dear android device";
UUID[] uuidSet = {new UUID("yourUUIDHERE",false)};
Vector URLS = new Vector();
int ENCRYPTMODE = ServiceRecord.AUTHENTICATE_ENCRYPT;
final Object serviceSearchCompletedEvent = new Object();
DiscoveryListener listener = new DiscoveryListener()
{
public void deviceDiscovered(RemoteDevice btDevice, DeviceClass cod) {}
public void inquiryCompleted(int discType) {}
public void servicesDiscovered(int transID, ServiceRecord[] servRecord)
{
for (int i = 0; i < servRecord.length; i++)
{
String connectionURL = servRecord[i].getConnectionURL(ENCRYPTMODE, false);
if (connectionURL != null)
{
URLS.addElement(connectionURL);
}
}
}
public void serviceSearchCompleted(int transID, int respCode) {
synchronized (serviceSearchCompletedEvent) {
serviceSearchCompletedEvent.notifyAll();
}
}
};
synchronized (serviceSearchCompletedEvent) {
discAgent.searchServices(null, uuidSet, targetDevice, listener);
serviceSearchCompletedEvent.wait();
}
if (URLS.isEmpty())
{
System.out.println("no connectionurl found");
return;
}
try {
for (int i = 0; i < URLS.size(); ++i) {
System.out.println("Trying: " + (String) URLS.elementAt(i));
try {
sc = (StreamConnection) Connector.open((String) URLS.elementAt(i));
in = sc.openInputStream();
out = sc.openOutputStream();
out.write(length);
out.flush();
in.read();
try {
Thread.sleep(50);
} catch (Exception e) {
e.printStackTrace();
}
break;
} catch (Exception e) {
sc = null;
System.out.println("Failed BT COnn");
}
} // TODO: handle case if all URLS fail
int bytesSent = 0;
int bytesToSend = 0;
int length=message.length();
int MTU=256;//or whatever..?
while (true) {
if ((length - bytesSent) > MTU) {
bytesToSend = MTU;
} else {
bytesToSend = length - bytesSent;
}
out.write(message.getBytes(), bytesSent, bytesToSend);
out.flush();
bytesSent += bytesToSend;
if (bytesSent >= length) {
Thread.sleep(200);
break;
}
}
if (in != null) {
in.close();
in = null;
}
if (out != null) {
out.close();
out = null;
}
if (sc != null) {
sc.close();
sc = null;
}
}
это заставило мое устройство Android принимать сообщения, отправленные с j2me. Я скопировал важные части из своего кода, так что я не уверен, что все это работает, потому что я не пытался выполнить его встроенным, так как я представляю его здесь, но вы должны быть в состоянии заполнить все ошибки, которые я сделал при копировании, вставляя это.
Удачи!