Skip to content

A Universal Windows App for the Texas Instruments CC2650SensorTag implementing unpaired Bluetooth Low Energy connectivity as available with Windows 10 Creators Edition.

License

Notifications You must be signed in to change notification settings

mjmeans/CC2650SensorTag-CE

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

74 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CC2650SensorTag-CS-Creators

A C# UWP (Universal Windows Platform) App for the Texas Instruments CC2650SensorTag CC2650STK implementing Unpaired BLE Bluetooth Low Energy connectivity as available with Windows 10 Creators Edition. Targets: IoT-Core, Phone, Desktop

  • See Issues for an images of the app running.

  • The Wiki now includes a HowTo Log and HowTo Read SensorTag values with the app.

Bug Fix 2:

Can now run reliably on on RPI3. See my blog (coming). RPI3 has run for over 15 hours without missing a beat!

Bug Fix 1: Now reads all sensors.

See the Wiki.

Preamble

In the previous version of this project, on GitHub djaus2/CC2650SensorTag-CS, the tag was required to be paired over Bluetooth with the app's host. Bluetooth SIG does not require participants in a BLE exchange to be paired. Windows 10 previously has required devices to be paired in UWP code. You could either pair the devices outside of the app (eg in Settings or Device Portal) or in-app.

The original Bluetooth BLE UWP sample from Microsoft on GitHub ms-iot/samples/.../BluetoothGATT/CS that connected to an (obsolete) TI CC2541 SensorTag implemented in-app pairing. The CC2650SensorTag-CS project is a port (and extension) of the Microsoft sample and so originally used this in-app pairing. This was found to be problematic with IoT-Core as in-app pairing requires a PopUp dialog as the user has to confirm acceptance of pairing and of use of Bluetooth in the app. The PopUp API is not supported with IoT-Core. Whilst there was an XAML UI workaround with the Microsoft code for this, the workaround stopped working (at least in the CC2650SensorTag-CS app) on IoT-Core circa the Anniversary edition of Windows 10. At this point the CC2650SensorTag-CS had pairing removed from the app, requiring the user to do the pairing in IoT-Core using Device Portal.

Both apps made use of known service Guids as documented by TI: CC2650 SensorTag User's Guide. The CC2650SensorTag-CS app also makes use of some standard BLE services as documented by Bluetooth SIG to get Battery level and the SensorTag system information (eg Manufacturer). The SensorTag is an amalgum of various sensors. It can be addressed via its Bluetooth address or through BLE queries searching for its class. Each sensor implements a BLE Service that supports a number of BLE Characteristics. Connectivity with a service is established through a DeviceWatcher class instance that has been queried for its service based upon its (known) Guid. For this to work the tag has to be paired wuth the app host for these two apps. Once this service is found, it can be queried to obtain the relevant characteristics using their (known) Guids. The characteristics Guids are typically a fixed offset from the Service Guid. The service characteristics with the SensorTag are:

  • Data, read sensor values, write actuator values
  • Notification, when enable is written, when sensor values are determine, availability is notified
  • Configuration, when enable is written, sensor performs periodic measurements. Also used for other configuration settings as required.
  • Period, set the period between sensor readings.

The take home with these apps is:
(a) They require the SensorTag to be paired with the app's host
(b) You are not discovering services and characteristics; you are requesting access to known services and their known characteristics.

PS: When the CC2650SensorTag-CS app is built with the Windows 15063 SDK (Target and Min) and run on a Creators desktop, the BLE Watcher doesn't return any services. If though the SDK is reset to the 14393 SDK and the app rebuilt, it will run on a Creators desktop. Actually using Build 16184 (Fast Track towards RS3).

Unpaired BLE Connectvity on Windows 10 Creators Edition

The most recent update for Windows 10, Creator edition (version 1503), including for IoT-Core has implemented unpaired BLE connectivity. Rather that running a DeviceWatcher with an AQS filter for the known device classes (through their Guids), the app looks for Advertisements from the SensorTag using a BluetoothLEAdvertisementWatcher class instance. (A filter can be applied to the the watcher to narrow the BLE classes that the app is receptive to but I haven't figured this out yet. I guess its an equivalent to the AQS fiter used withe the DeviceWatcher when serching for devices.) These advertisments can be noticed when the tag is Advertisment/Pairing mode which is entered by a short press on tag's power button (on the left).

When an advertisment is received and is vetted as being a required device, a request to access it can be made (without being paired, with Creators) and if successful can then be interogated for services which can then be interogated for characteristics. Once access is achieved, the app host IS connected to the SensorTag. Once a sensor's (read, service's) Notification characteritic instance is obtained, the handler for sensor's value updates is set as a property of the characteristic. Notifications are then turned on and then the sensor's periodic data determination is enabled. The sensor then calls the handler periodically (generally ery second) with a value for the sensor as a byte array. Each enabled sensor in the tag makes it own call.

This all works Windows 10 Creators Edition on Desktop and Phone, as well as on the Raspberry Pi 3 (IoT-Core) and Dragonboard 410c (IoT-Core) BOTH WITHOUT the need for pairing. *On earlier (but not too early) builds, advertisements should work with paired devices.

About

A Universal Windows App for the Texas Instruments CC2650SensorTag implementing unpaired Bluetooth Low Energy connectivity as available with Windows 10 Creators Edition.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C# 100.0%