Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cujomalainey/antplus-arduino
An Implementation of the ANT+ Network on top of ant-arduino
https://github.com/cujomalainey/antplus-arduino
ant ant-arduino ant-network antplus antplus-arduino antplus-sdk arduino arduino-library mbed profile radio sportsanalytics
Last synced: 4 days ago
JSON representation
An Implementation of the ANT+ Network on top of ant-arduino
- Host: GitHub
- URL: https://github.com/cujomalainey/antplus-arduino
- Owner: cujomalainey
- License: gpl-2.0
- Created: 2017-09-04T18:04:23.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-09-18T23:00:34.000Z (4 months ago)
- Last Synced: 2024-12-29T01:14:11.423Z (11 days ago)
- Topics: ant, ant-arduino, ant-network, antplus, antplus-arduino, antplus-sdk, arduino, arduino-library, mbed, profile, radio, sportsanalytics
- Language: C++
- Homepage:
- Size: 1.05 MB
- Stars: 148
- Watchers: 16
- Forks: 26
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: COPYING
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# antplus-arduino
An Implementation of the Ant+ Network on top of [ant-arduino](https://github.com/cujomalainey/ant-arduino)## Status
[![Build and Tests](https://github.com/cujomalainey/antplus-arduino/workflows/Build%20and%20Tests/badge.svg?branch=master&event=push)](https://github.com/cujomalainey/antplus-arduino/actions)
## Roadmap
* Build support for non-ANT+ channel interfacing
* Adding more profiles[Developer's Guide](https://github.com/cujomalainey/antplus-arduino/wiki/Developer's-Guide)
## Example
I have created several sketches of configuring the radio with the ant-arduino library. You can find these in the examples folder. Here's an example of configuring a channel with a NRF51 radio:```c++
AntWithCallbacks ant = AntWithCallbacks();
AntPlusRouter router = AntPlusRouter();
ProfileHeartRateMonitor hr = ProfileHeartRateMonitor(WILDCARD_DEVICE);void previousHeartBeatDataPageHandler(HeartRatePreviousHeartBeat& dp, uintptr_t data) {
Serial.print("HR: ");
Serial.println(dp.getComputedHeartRate());
}void setup() {
Serial1.begin(BAUD_RATE);
ant.setSerial(Serial1);
delay(10000);router.setDriver(&ant); // never touch ant again
router.setAntPlusNetworkKey(NETWORK_KEY);
router.setProfile(CHANNEL_0, &hr);
// Delay after initial setup to wait for user to connect on serialSerial.begin(BAUD_RATE);
Serial.println("Running");
hr.onHeartRatePreviousHeartBeat(previousHeartBeatDataPageHandler, NULL);
hr.begin();
// wait for pair to complete
hr.waitForPair();
}void loop() {
router.loop();
}
```See the examples folder for the full source. There are more examples in the download.
To add ANT support to a new sketch, add "#include " (without quotes) to the top of your sketch. You can also add it by selecting the "sketch" menu, and choosing "Import Library->ANT+".
## Hardware
See [ant-arduino](https://github.com/cujomalainey/ant-arduino#hardware)
## Support ANT+ Profiles
This library aims to support all ANT+ devices. This goal will take time but its an attainable one. Check out the [wiki](https://github.com/cujomalainey/antplus-arduino/wiki/Profile-Support) for the list of profiles implemented and their versions.
## Installation
**Note: This library depends on [ant-arduino](https://github.com/cujomalainey/ant-arduino). You must have it installed for it to work.** If you are using platformio you don't have to worry about this.
Arduino 1.5 and later
Arduino now includes a library manager for easier library installation. From the Sketch menu select include library->Manage Libraries, then type "antplus-arduino" in the filter and install.
Prior to Arduino 1.5 installation is manual
Download a .zip or .tar.gz release from github. Determine the location of your sketchbook by selecting "preferences" on the Arduino menu. Create a "libraries" folder in your sketchbook and unzip the release file in that location.
If you are using platformio you can install the library by running
``` platformio lib install 1879 ```## Uploading Sketches
Uploading sketches with a Leonardo is as simple as connecting the Arduino to your computer and uploading. When using a single serial port Arduino, such as the Pro Mini (3.3V), the jumpers on the ANT Radio must be disconnected. Then, after upload, reconnect the lines to have access to the serial port. Always remember to power off the Arduino before moving the jumpers.
## Configuration
See [ant-arduino](https://github.com/cujomalainey/ant-arduino#configuration)
## Questions/Feedback
Questions about this project should be posted to Github Discussion. Be sure to provide as much detail as possible (e.g. what radios, firmware versions, configuration and code).
## Consulting/Commercial Licenses
At the current time there is zero support for commercial usage. Contact me via email if you are looking to use this code commercially.If you are looking for commercial support for ANT radios go to thisisant.com
NOTE: This library is not ANT+ certified and does not intend to be. It is meant to be tool to get quick and easy access to sensors in the ANT+ network. There are edge cases where it will fail to meet the spec of the ANT+ protocol.