-
-
Notifications
You must be signed in to change notification settings - Fork 213
Home
Version 3.7, April 2017
There are generally five ways an application might want to use Bluetooth:
1. Make a direct data connection Where the program connects directly to a Bluetooth RFCOMM service, and sends and receives the raw data for that connection. See section General Bluetooth Data Connections below. The BluetoothClient provides the Stream to read and write on -- there is no need to use virtual COM ports and the System.IO.Ports.SerialPort class. The server side function can also be provided. Our recommendation is that only if you are setting up the connection for a separate program that uses COM ports do you need to use virtual COM ports, see 1b.
1b. Virtual Serial Port If however you have a separate third-party application that needs to use a virtual COM port then it is not quite so simple and direct. See Bluetooth Serial Ports.
Note that RFCOMM/SPP only allows one connection from a remote device to each service. So do not use BluetoothClient and a virtual Serial port to connect to the same service at the same time; the second one will fail to connect.
2. Do an OBEX transfer Where the program is an OBEX client and connects to a server, and sends (PUTs) or GETs a file/object. The server side function can also be provided. See section OBEX below.
3. Have the Bluetooth stack and/or the OS connect to and use a remote service Common services for this case are where the service is Headset/Handsfree/A2DP, or networking for instance. Here we do not want the program to connect directly to those services, as we wouldn’t know what to do with the raw bytes, but instead want the OS to send audio to the headset, or form a network connection with an access-point or similar. See section #Connecting to Bluetooth Services below.
4. Make a direct data connection using the L2CAP protocol Where the program connects directly to a Bluetooth L2CAP service, and sends and receives the raw data for that connection. We have pre-release support for this on some platforms see section #Bluetooth L2CAP below,
5. Check whether a particular device is in range The best way to do this is to attempt to open a connection to a service on the device and see if it succeeds. One service that is always present is SDP so do a fake SDP query, see section #Testing if a device is in range below. If a device comes into range but neither it nor the local device attempt a connection nor are running discovery, then neither will know they are in range.
As noted there, we have support for most of those currently. See Bluetooth Profiles and 32feet.NET.html for information on what services use which method.
For device discovery see the section under #General Bluetooth Data Connections below.
-
Supported Hardware and Software
- Microsoft
- BlueSoleil
-
BlueZ on Linux
- macOS (in-development)
- Stonestreet One Bluetopia
- Android (alpha)
- Feature support table
-
32feet.NET and shells, including PowerShell
32feet.NET - Personal Area Networking for .NET
In The Hand Ltd