iTracker RAK8212
NOTE: The RAK RAK8212 is no longer manufactured and new Espruino binaries are no longer being created. For new designs RAKwireless recommends the RAK5010.
Binaries can be found in:
- the Downloadable zip of firmare (current version)
- the binaries folder (current version)
- the automatic Travis Builds (cutting edge builds)
Contents
Using
Serial connection
When the iTracker powers on, if it detects 3.3v on pin D28
(Serial RX)
then it will enable serial comms at 9600 baud on D28
(RX) and D29
(TX).
For instance if the iTracker is connected to the adaptor board and that board is powered on, you'll be able to use the USB Serial interface to program your iTracker.
However there is just one Serial port on the nRF52. If you then use
GPS or GSM, the connection to D28/D29
will be moved, removing your
communications. If you need to maintain communications during that time,
please connect via Bluetooth instead.
GPS
There is no separate GPS chip on the RAK8212. Instead, it is built into the BG96. Use as follows - this also turns the BG96 on if it wasn't already enabled.
require("iTracker").setGPSOn(true, function(err, gps) {
/* gps contains: {
at : AT command handler
on : function(callback(err)) // turn GPS on (turned on automatically)
off : function(callback(err)) // turn GPS off
get : function(callback(data)) // get GPS data
} */
setInterval(function() {
gps.get(function(data) {
print("GPS", data);
/* returns {error:...} on failure. 'ERROR: 516' means 'no fix'
returns { raw : raw data as <UTC>,<latitude>,<longitude>,<hdop>,<altitude>,<fix>,<cog>,<spkm>,<spkn>,<date>,<nsat>
lat : latitude in degrees,
lon : longitude in degrees,
alt : altitude in m } */
});
}, 10000);
});
Modem testing
The following code will power up the modem and report back the version number. It's a quick, easy way to test it without needing an active SIM.
var at;
console.log("Turning Cell on");
require("iTracker").setCellOn(true, function(usart) {
console.log("Cell now on");
at = require("AT").connect(usart);
at.cmd("AT+GMR\r\n",1000,function cb(d) {
if (d=="AT+GMR") return cb;
if (d!="OK") console.log("Version is "+d);
});
});
You can use the AT Module in this way to send your own custom commands
as well (it's also available as sms.at
and gprs.at
in the examples below.
SMS
See the ATSMS module for full documentation.
var sms;
console.log("Turning Cell on");
require("iTracker").setCellOn(true, function(usart) {
console.log("Connecting SMS");
var ATSMS = require("ATSMS");
sms = new ATSMS(usart);
//Use sms.at.debug(); here if you want debug messages
sms.init(function(err) {
if (err) throw err;
console.log("Initialised!");
sms.list("ALL", function(err,list) {
if (err) throw err;
if (list.length)
console.log(list);
else
console.log("No Messages");
});
// and to send a message:
//sms.send('+441234567890','Hello world!', callback)
});
sms.on('message', function(msgIndex) {
console.log("Got new message, index ", msgIndex);
});
// when done use require("iTracker").setCellOn(false)
});
GSM/GPRS
See the QuectelBG96 module for full documentation.
function connectionReady() {
var http = require("http");
http.get("http://www.pur3.co.uk/hello.txt", function(res) {
res.on('data', function(data) {
console.log(data);
});
});
}
var gprs;
console.log("Turning Cell on");
require("iTracker").setCellOn(true, function(usart) {
console.log("Waiting 30 sec for GPRS connection");
setTimeout(function() {
console.log("Connecting GPRS");
gprs = require('QuectelBG96').connect(usart, {
apn : "",
username : "",
password : ""
}, function(err) {
console.log("Connected!");
if (err) throw err;
connectionReady();
});
}, 30000);
});
NB-IoT
This blog post by Wolfgang Klenk shows how to get connected with Vodafone's NB-IoT in Germany.
Sensors
e=require("iTracker").setEnvOn(true, function() {
console.log(e.getData());
});
// { "temp": 27.05661935425, "pressure": 1007.23205361758, "humidity": 40.728515625 }
m=require("iTracker").setMagOn(true, function() {
console.log(m.read());
});
// { "x": -92, "y": -17, "z": 424 }
a=require("iTracker").setAccelOn(true, function() {
console.log(a.read());
});
// { "x": 0.0263671875, "y": 0.3505859375, "z": -0.3291015625 }
o=require("iTracker").setOptoOn(true, function() {
console.log(o.read());
});
// 2709.76
Reference
iTracker.setGPSOn = function(isOn, callback) { ... }
Return GPS instance. callback is called whenever data is available!
iTracker.setEnvOn = function(isOn, callback) { ... }
Returns BME280 instance. callback when initialised. Call getData
to get the information
iTracker.setMagOn = function(isOn, callback) { ... }
Returns a LIS2MDL instance. callback when initialised. Then use read
to get data
iTracker.setAccelOn = function(isOn, callback) { ... }
Returns a LIS3DH instance. callback when initialised. Then use read
to get data
iTracker.setOptoOn = function(isOn, callback) { ... }
Returns a OPT3001 instance. callback when initialised. Then use read
to get data
iTracker.setCellOn = function(isOn, callback) { ... }
Turn cell connectivity on - will take around 8 seconds. Calls the callback(usart)
when done. You then need to connect either ATSMS or QuectelBG96 to the serial device usart
iTracker.setCharging = function(isCharging) { ... }
Set whether the BQ24210 should charge the battery (default is yes)
Tutorials
First, it's best to check out the Getting Started Guide
Tutorials using Bluetooth LE:
data:image/s3,"s3://crabby-images/be735/be7354f931ea4a72f540449b07aa801e69159c82" alt="BTHome Library BTHome Library"
data:image/s3,"s3://crabby-images/ad9b5/ad9b51975484e12f1719389153c7af7a6476e816" alt="Bluetooth LE Printers Bluetooth LE Printers"
data:image/s3,"s3://crabby-images/b6881/b688124e4d68d9e837b7174d0f67dd674715b29e" alt="Bluetooth LE Emoji Advertising Bluetooth LE Emoji Advertising"
data:image/s3,"s3://crabby-images/38f27/38f27096a4b20d7938fa2e07c6767afd69a1e51e" alt="Battery Monitor Battery Monitor"
data:image/s3,"s3://crabby-images/31616/31616e536dfc1d03311dfc2fa68d0fcabf95950e" alt="LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc) LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc)"
data:image/s3,"s3://crabby-images/4a69b/4a69b1bd38acee5d5fc4f57f6c3a1cf7cd746725" alt="Tilt Hydrometer Repeater Tilt Hydrometer Repeater"
data:image/s3,"s3://crabby-images/4b7cb/4b7cb58e13660f16a93cfc2eb6bc9d9b924f9a67" alt="Quick Start (Bluetooth LE) Quick Start (Bluetooth LE)"
data:image/s3,"s3://crabby-images/9eed1/9eed17234faa8fcda6325eba55773d9baa73d8a8" alt="BLE Advertising with Node.js/Python/C#/Android BLE Advertising with Node.js/Python/C#/Android"
data:image/s3,"s3://crabby-images/c939c/c939ccf1a29f6a110f769389082343a9598b4824" alt="Automatic Data Download Automatic Data Download"
data:image/s3,"s3://crabby-images/130f9/130f9bc6e11c22806cd5a6b5df89aeb5143da6b7" alt="Puck.js to GCP BigQuery & Data Studio Puck.js to GCP BigQuery & Data Studio"
data:image/s3,"s3://crabby-images/ffa61/ffa61ca491e96a273eb2b198cfbe4a52ddba6a71" alt="Stream from Puck.js to AWS IOT Core & SNS Email Stream from Puck.js to AWS IOT Core & SNS Email"
data:image/s3,"s3://crabby-images/e9c5b/e9c5b127cd966b62cd86abbd4a851550954d5410" alt="Bluetooth LE UARTs (NUS) Bluetooth LE UARTs (NUS)"
data:image/s3,"s3://crabby-images/b3109/b31091bc500507fef8f127b5f66db049bfa44d89" alt="Bluetooth LE HID Keyboards Bluetooth LE HID Keyboards"
data:image/s3,"s3://crabby-images/32ed5/32ed54b945d81b5d31309062ae03558a97cedb31" alt="Bluetooth LE Security and Access Control Bluetooth LE Security and Access Control"
data:image/s3,"s3://crabby-images/1f0c3/1f0c34755589101ad02517227b221c0630d7910b" alt="Bluetooth LE MIDI Bluetooth LE MIDI"
data:image/s3,"s3://crabby-images/82f80/82f80f7d72cf1bf9af341d03daff9952ffb50953" alt="Web Bluetooth on Linux Web Bluetooth on Linux"
data:image/s3,"s3://crabby-images/6a9c3/6a9c3fbb1d8f116762786eff85b8d50d7e312331" alt="Bluetooth Time Setter Bluetooth Time Setter"
data:image/s3,"s3://crabby-images/14fa7/14fa7022457705b335118d7789ac58d99e7c8d00" alt="Using Web Bluetooth with Espruino Using Web Bluetooth with Espruino"
data:image/s3,"s3://crabby-images/b1c8d/b1c8d745152cdf49f58f27b2ab67991709c1172b" alt="Bluetooth LE and If This Then That Bluetooth LE and If This Then That"
data:image/s3,"s3://crabby-images/702cf/702cf6d9dd2bdf07de792fe909493d18ef554c06" alt="UART.js Library UART.js Library"
data:image/s3,"s3://crabby-images/70834/7083425cc7604ea1386a856079e0b4e89bdda1cf" alt="iBeacons iBeacons"
data:image/s3,"s3://crabby-images/123de/123de4ed36ea6fb777ca2d49b7b5fd54f58ff276" alt="Eddystone Beacons Eddystone Beacons"
data:image/s3,"s3://crabby-images/ed17c/ed17cd478a971f049e00f7e386b67192f87e7c5f" alt="Bluetooth LE and Node-RED with MQTT Bluetooth LE and Node-RED with MQTT"
data:image/s3,"s3://crabby-images/d13f3/d13f3a1d8e1cc3bec2bbe9ed4a5fe78a382db420" alt="Bluetooth Music Controller Bluetooth Music Controller"
data:image/s3,"s3://crabby-images/8c4ef/8c4efd69e25a4a44f01ba50df50bbc3f8ca7c8eb" alt="Controlling Bluetooth Lights with Puck.js Controlling Bluetooth Lights with Puck.js"
data:image/s3,"s3://crabby-images/0bbcd/0bbcd520593eaee0126a360086c237a7a839bdc2" alt="Bluetooth LE HTTP Proxies Bluetooth LE HTTP Proxies"
data:image/s3,"s3://crabby-images/3f598/3f59837ab4187e9afdd38affcd02345807f8b8a1" alt="Exercise Machine controlled Video Exercise Machine controlled Video"
data:image/s3,"s3://crabby-images/a7b75/a7b75f2c534c59c3c7d87590fd8a92791d826d3a" alt="BLE Communications BLE Communications"
data:image/s3,"s3://crabby-images/8857d/8857d53279cfc8ac2b23b6d2330e7c1d937123ba" alt="About Bluetooth LE (BLE) About Bluetooth LE (BLE)"
data:image/s3,"s3://crabby-images/ab207/ab2077fa1eda376303b20826160caac540fdf08f" alt="Puck.js with SMS control Puck.js with SMS control"
data:image/s3,"s3://crabby-images/15082/15082da1a940849126ed736eb39b87e922b0233b" alt="Pixl.js SMS Remote Monitoring Pixl.js SMS Remote Monitoring"
data:image/s3,"s3://crabby-images/92066/92066ae2ad8e26bfa0c6ac889f85548f7a187486" alt="Web IDE on a Raspberry Pi Web IDE on a Raspberry Pi"
data:image/s3,"s3://crabby-images/25280/25280beb7c2a28141b939f60f2f3eac842c60073" alt="Puck.js Bluetooth with the Graphical Editor Puck.js Bluetooth with the Graphical Editor"
data:image/s3,"s3://crabby-images/16e70/16e706af87fa98a5fc4a3f3469b0142468dcbc0f" alt="Controlling Other BLE Espruino Devices Controlling Other BLE Espruino Devices"
data:image/s3,"s3://crabby-images/4198e/4198e500ffff17897db2dafddc3c53a95b8dbeac" alt="Pixl.js Simple Logger Pixl.js Simple Logger"
data:image/s3,"s3://crabby-images/4d294/4d294c77f3047b04bfb18a4df7bd2d601ad0273f" alt="Pixl.js Multiplayer Pong Game Pixl.js Multiplayer Pong Game"
data:image/s3,"s3://crabby-images/73f76/73f761026b1906216d3f44ce68c04dcbdeda45cb" alt="Pixl.js Bluetooth to Ethernet MQTT Bridge Pixl.js Bluetooth to Ethernet MQTT Bridge"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="BLE Characteristic Scan BLE Characteristic Scan"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="LED BLE Library LED BLE Library"
data:image/s3,"s3://crabby-images/7885f/7885fe8501e2c43764ce281e68e563f5d88ca24e" alt="Bluefruit LE app interface Bluefruit LE app interface"
Tutorials using Bluetooth LE and functionality that may not be part of the iTracker:
data:image/s3,"s3://crabby-images/1f326/1f326f23d21745966b6c1dca5a2a388a92be93f3" alt="Water Level Monitor Water Level Monitor"
data:image/s3,"s3://crabby-images/52d33/52d330238e1949f00872f1ae50a863f356a28fb6" alt="Puck.js Vibration Sensor Puck.js Vibration Sensor"
data:image/s3,"s3://crabby-images/8e199/8e199c99e52f6eb79fe50e2caf891c297f0dcec5" alt="DIY Smart Meter DIY Smart Meter"
data:image/s3,"s3://crabby-images/52a2f/52a2fd04362887edb0908092e887315b97788bd9" alt="BTHome Door Sensor for Home Assistant BTHome Door Sensor for Home Assistant"
data:image/s3,"s3://crabby-images/d642e/d642e612ddc640c18acd2d53f644f39a778ae497" alt="BTHome and Home Assistant Setup BTHome and Home Assistant Setup"
data:image/s3,"s3://crabby-images/c6255/c6255f0627dc83c3b710a16bc61a7d5ccaf46cc5" alt="Pixl.js Wireless Temperature Display Pixl.js Wireless Temperature Display"
data:image/s3,"s3://crabby-images/42287/42287f76b5e839f35f21bd6465b87b1aad3ce0ea" alt="Turning an Espruino Puck.js Into a Universal Presentation Clicker Turning an Espruino Puck.js Into a Universal Presentation Clicker"
data:image/s3,"s3://crabby-images/f07aa/f07aaf7eabbbdc5db2dc436e3c1f312a0abe3e2f" alt="Interfacing to a PC Interfacing to a PC"
data:image/s3,"s3://crabby-images/8ebd9/8ebd9d74a417abb5f8abaa4d29292870bd8f53db" alt="Controlling Espruino from Tensorflow on the Desktop Controlling Espruino from Tensorflow on the Desktop"
data:image/s3,"s3://crabby-images/c5dfa/c5dfaba8d897ea980c038ae307501ebcfa13730a" alt="Bookmarklets with Web Bluetooth Bookmarklets with Web Bluetooth"
data:image/s3,"s3://crabby-images/04bca/04bca813336c121b9218b113dab5c5349ed35289" alt="Bangle.js Data Streaming Bangle.js Data Streaming"
data:image/s3,"s3://crabby-images/3223e/3223e2be616ccf7a07e2203725613cd7909a705c" alt="Puckmote - Universal Remote Control Puckmote - Universal Remote Control"
data:image/s3,"s3://crabby-images/87238/872380342575fad5d3cd7ff8a9044e1db9ae6564" alt="IoT for Kitchen Gardens IoT for Kitchen Gardens"
data:image/s3,"s3://crabby-images/c97ad/c97ad8e935c661adf39a2b01cb17ce9abcb800cb" alt="Time Machine Retro-Inspired Smartwatch Time Machine Retro-Inspired Smartwatch"
data:image/s3,"s3://crabby-images/7ba05/7ba0521117ab56bc97b56a10767a20e48b1140c6" alt="Talos, Keeping You Safe During Your Commute Talos, Keeping You Safe During Your Commute"
data:image/s3,"s3://crabby-images/3a9ed/3a9edcaabb7eac32370db1a35aa5ca1c1a3f9df9" alt="Bluetooth Energy Usage Monitor Bluetooth Energy Usage Monitor"
data:image/s3,"s3://crabby-images/03d3f/03d3f942e46cdc7b6fa892347ebe647803475375" alt="Electric Skateboard Controller Electric Skateboard Controller"
data:image/s3,"s3://crabby-images/f8d95/f8d9533b507efe3615ce5249d1927c2552ff7d9a" alt="Wooden Bluetooth Remote for Lego Duplo Train Wooden Bluetooth Remote for Lego Duplo Train"
data:image/s3,"s3://crabby-images/e185e/e185ef9220dbe537318d2a6ff7fd24c66e6cd715" alt="Puck.js Control from Android using DroidScript Puck.js Control from Android using DroidScript"
data:image/s3,"s3://crabby-images/3daf5/3daf5f902581b6df051b907914ee1dff9e55b474" alt="Ikea Eneby Speaker Controller Ikea Eneby Speaker Controller"
data:image/s3,"s3://crabby-images/e8df4/e8df47287aecb79c64afe8a96ab2b143ce0e6997" alt="Pixl.js Wireless Weather Station Pixl.js Wireless Weather Station"
data:image/s3,"s3://crabby-images/f401b/f401b1a51e56ab99c1a95ce00027630016fc55fd" alt="Temperature Controlled Night Light with Puck.js Temperature Controlled Night Light with Puck.js"
data:image/s3,"s3://crabby-images/14f18/14f1891c721d9bdc0590ba3e3f9b0b1637f97d9b" alt="Infrared Record and Playback with Puck.js Infrared Record and Playback with Puck.js"
data:image/s3,"s3://crabby-images/4c111/4c11195d7157b8b816b38d513b192c402042fcee" alt="Door Controlled Light with Puck.js Door Controlled Light with Puck.js"
data:image/s3,"s3://crabby-images/126e7/126e7b21cc09a46698a12e3875bf7aecb2399b82" alt="Freezer Alarm Freezer Alarm"
Pinout
Hover the mouse over a pin function for more information. Clicking in a function will tell you how to use it in Espruino.
- Purple boxes show pins that are used for other functionality on the board. You should avoid using these unless you know that the marked device is not used.
- ! boxes contain extra information about the pin. Hover your mouse over them to see it.
- 3.3v boxes mark pins that are not 5v tolerant (they only take inputs from 0 - 3.3v, not 0 - 5v).
- GND is ground (0v).
- ADC is an Analog to Digital Converter (for reading analog voltages)
- USART is a 2 wire peripheral for Serial Data.
Firmware Updates
You need to attach a nRF52DK or other SWD programmer to the SWDCLK
and SWDIO
pins, then upload the hex file by copying it to the JLINK
drive
or using nrfjprog
.
This page is auto-generated from GitHub. If you see any mistakes or have suggestions, please let us know.