我正在尝试在C#应用程序中使用32feet.NET蓝牙库来检测附近的设备。我的小应用程序的目的是让PC知道谁在房间里使用人们手机的蓝牙功能。
做这样的事情的最好方法是让我想要“跟踪”的设备连接一次,然后不断检查是否可以通过蓝牙检测到它们。
现在我的问题:
我知道所有这些都可能在库文档中,但是对我来说真的很难读,大多数例子似乎都在VB中,我不知道并且很难翻译成C#(特别是当它涉及到AsyncCallbacks之类的)。
如果有人能给我一个正确的方向,我会很高兴的!
这不是答案,但我无法将这么多代码放在评论部分。更改以下代码行:
//continue listening for other broadcasting devices
listener.BeginAcceptBluetoothClient(this.BluetoothListenerAcceptClientCallback, listener);
// create a connection to the device that's just been found
BluetoothClient client = listener.EndAcceptBluetoothClient();
至
// create a connection to the device that's just been found
BluetoothClient client = listener.EndAcceptBluetoothClient();
// continue listening for other broadcasting devices
listener.BeginAcceptBluetoothClient(this.BluetoothListenerAcceptClientCallback, listener);
基本上,改变代码的顺序.. 至于每次调用BeginXXXX方法都必须有下一个EndXXXX。以上所有代码,您正在尝试BeginAcceptBluetoothClient已经开始“BeginAcceptBluetoothClient”。
希望你能理解。
前面有几点需要注意,我假设你没有在这里处理HID设备,它们通常由操作系统处理。我也刚刚开始使用32feet,我正在使用它来创建蓝牙条码扫描器上串口服务的连接,所以可能有更好的方法满足您的需求,但这可能会指出您正确的方向开始。
您需要配对设备,是的。如果你在WinForms应用程序中使用它,那么实际上你可以显示哪些形式处理扫描设备并允许你选择一个,如下所示:
bool PairDevice()
{
using (var discoverForm = new SelectBluetoothDeviceDialog())
{
if (discoverForm.ShowDialog(this) != DialogResult.OK)
{
// no device selected
return false;
}
BluetoothDeviceInfo deviceInfo = discoverForm.SelectedDevice;
if (!deviceInfo.Authenticated) // previously paired?
{
// TODO: show a dialog with a PIN/discover the device PIN
if (!BluetoothSecurity.PairDevice(deviceInfo.DeviceAddress, myPin))
{
// not previously paired and attempt to pair failed
return false;
}
}
// device should now be paired with the OS so make a connection to it asynchronously
var client = new BluetoothClient();
client.BeginConnect(deviceInfo.DeviceAddress, BluetoothService.SerialPort, this.BluetoothClientConnectCallback, client);
return true;
}
}
void BluetoothClientConnectCallback(IAsyncResult result)
{
var client = (BluetoothClient)result.State;
client.EndConnect();
// get the client's stream and do whatever reading/writing you want to do.
// if you want to maintain the connection then calls to Read() on the client's stream should block when awaiting data from the device
// when you're done reading/writing and want to close the connection or the device servers the connection control flow will resume here and you need to tidy up
client.Close();
}
到目前为止,最好的方式,如果你的设备正在广播他们可用于连接,是设置一个BluetoothListener
,将持续听取广播设备,当找到一个,你会得到一个BluetoothClient
实例,你可以使用与第一次配对时相同:
void SetupListener()
{
var listener = new BluetoothListener(BluetoothService.SerialPort);
listener.Start();
listener.BeginAcceptBluetoothClient(this.BluetoothListenerAcceptClientCallback, listener);
}
void BluetoothListenerAcceptClientCallback(IAsyncResult result)
{
var listener = (BluetoothListener)result.State;
// continue listening for other broadcasting devices
listener.BeginAcceptBluetoothClient(this.BluetoothListenerAcceptClientCallback, listener);
// create a connection to the device that's just been found
BluetoothClient client = listener.EndAcceptBluetoothClient();
// the method we're in is already asynchronous and it's already connected to the client (via EndAcceptBluetoothClient) so there's no need to call BeginConnect
// TODO: perform your reading/writing as you did in the first code sample
client.Close();
}
不太吸引人,但如果您的设备没有广播连接,则有用,您可以创建一个新的BluetoothClient
并要求它返回它可以找到的所有设备:
void ScanForBluetoothClients()
{
var client = new BluetoothClient();
BluetoothDeviceInfo[] availableDevices = client.DiscoverDevices(); // I've found this to be SLOW!
foreach (BluetoothDeviceInfo device in availableDevices)
{
if (!device.Authenticated)
{
continue;
}
var peerClient = new BluetoothClient();
peerClient.BeginConnect(deviceInfo.DeviceAddress, BluetoothService.SerialPort, this.BluetoothClientConnectCallback, peerClient);
}
}