-
Notifications
You must be signed in to change notification settings - Fork 69
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add Lilygo LoRa32 documentation (#1365)
* doc: Initial files * doc: Add company * doc: Cleanup * doc: Update images * doc: Additional information * doc: Small fixes
- Loading branch information
Showing
10 changed files
with
127 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
--- | ||
title: "LILYGO LoRa32" | ||
description: "" | ||
weight: | ||
--- | ||
|
||
{{< figure src="lora32.png" alt="" class="float plain" width="80%">}} | ||
|
||
The [LILYGO LoRa32 V2.1_1.6](https://www.lilygo.cc/products/lora3) is a development board with an ESP32 and a Semtech SX1276 transceiver. It features an OLED screen, Micro SD card slot and a JST GH for connecting a Li-Po battery. | ||
|
||
In order to program the board we need to make use of of the [RadioLib](https://github.com/jgromes/RadioLib) library. This is a universal Arduino library created for radio modules (such as LoRa). | ||
|
||
We will set up the Arduino IDE first, after which we will use an example code to connect it to {{% tts %}}. | ||
|
||
<!--more--> | ||
|
||
## Installing libraries | ||
|
||
Download the latest release of the [Arduino Software (IDE)](https://www.arduino.cc/en/Main/Software), [install](https://www.arduino.cc/en/Guide) it on your operating system and run it. | ||
|
||
Open Arduino IDE, and click **File -> Preferences -> Settings** and click the button next to `Additional Boards Manager URLs`. | ||
|
||
{{< figure src="boards-manager-url.png" alt="">}} | ||
|
||
In a new line, enter: `https://espressif.github.io/arduino-esp32/package_esp32_index.json` and click **OK**. | ||
|
||
{{< figure src="esp32-url.png" alt="">}} | ||
|
||
Click the **second icon in the left-hand menu** or select **Tools -> Board: -> Boards Manager...**, then search `esp32` in the search field, select the latest releases and click **install**. | ||
|
||
{{< figure src="esp32-install.png" alt="">}} | ||
|
||
Then go to the **third icon in the left-hand menu** or select **Sketch -> Include Library -> Manage Libraries...**, then search `radiolib` in the search field, select the latest releases and click **install**. | ||
|
||
{{< figure src="radiolib-install.png" alt="">}} | ||
|
||
## Connecting the Device | ||
|
||
Connect the board to your computer with a micro usb cable. | ||
|
||
Click the **Select Board** drop down (or go to the **tools** menu) and select the right COM port and board: | ||
|
||
{{< figure src="lora32-select.png" alt="">}} | ||
|
||
Then, in the **tools** menu, make sure to select the correct **Board Revision** (`TTGO LoRa32 V2.1 (1.6.1)` in our case. You can check on the board itself for which version you have) and the **Upload Speed** (`115200` is recommended). | ||
|
||
Open the example sketch by going to **File -> Examples -> RadioLib -> LoRaWAN -> LoRaWAN_Starter** | ||
|
||
Now we need the credentials to onboard it to {{% tts %}}. | ||
|
||
## Onboarding to {{% tts %}} | ||
|
||
The device has to be onboarded **manually**. | ||
|
||
To onboard **manually**, in the **End device type** section, under **Input Method**, select the **Enter end device specifics manually** option. The [Manually adding devices]({{< ref "/devices/adding-devices/manual/" >}}) and [Over the Air Activation (OTAA)]({{< ref "/devices/adding-devices/manual/otaa/" >}}) guides explain this procedure in detail. Following details are specific to the LoRa32: | ||
|
||
- LoRaWAN version: **LoRaWAN Specification 1.1.0** | ||
- Regional parameters version: **RP001 Regional Parameters 1.1 revision A** | ||
|
||
For the Provisioning information, enter the following details: | ||
- JoinEUI: `0000000000000000` | ||
- DevEUI, AppKey & NwkKey: **Generate by clicking the Generate button.** | ||
|
||
After configuring your device, select the **Register end device** button. | ||
|
||
{{< figure src="manual-register.png" alt="Settings for manual registration" >}} | ||
|
||
## Configuring the code | ||
|
||
Our device is registered with {{% tts %}}, but it still needs the correct info in order to connect. | ||
|
||
Go back to your Arduino IDE, and go to the `config.h` file. There you should see the following: | ||
``` | ||
// the Device EUI & two keys can be generated on the TTN console | ||
#ifndef RADIOLIB_LORAWAN_DEV_EUI // Replace with your Device EUI | ||
#define RADIOLIB_LORAWAN_DEV_EUI 0x--------------- | ||
#endif | ||
#ifndef RADIOLIB_LORAWAN_APP_KEY // Replace with your App Key | ||
#define RADIOLIB_LORAWAN_APP_KEY 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x-- | ||
#endif | ||
#ifndef RADIOLIB_LORAWAN_NWK_KEY // Put your Nwk Key here | ||
#define RADIOLIB_LORAWAN_NWK_KEY 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x--, 0x-- | ||
#endif | ||
``` | ||
|
||
In {{% tts %}}, copy the **DevEUI** and replace the `0x---------------` with the devEUI you copied. | ||
|
||
For the AppKey and NwkKey, click the **eye** icon and then selecting the **</>** icon. Then copy the **AppKey** by clicking the **Copy to clipboard** button and replace the string in the config file. Repeat this for the **NwkKey**. | ||
|
||
{{< figure src="lora32-activ-info.png" alt="" >}} | ||
|
||
A few lines down you will see regional settings. Make sure these match your region: | ||
|
||
```cpp | ||
// regional choices: EU868, US915, AU915, AS923, IN865, KR920, CN780, CN500 | ||
const LoRaWANBand_t Region = EU868; | ||
const uint8_t subBand = 0; // For US915, change this to 2, otherwise leave on 0 | ||
``` | ||
|
||
Now upload the code to your device using the **->** button in the top-left. | ||
|
||
## Monitoring Live Data | ||
|
||
As the device payload comes to {{% tts %}} in a HEX format, you will need to decode it using a [payload formatter](https://www.thethingsindustries.com/docs/integrations/payload-formatters/). To do this, in your application on {{% tts %}}, navigate to **Payload formatters**. | ||
|
||
Select the **Custom Javascript formatter** from the **Formatter type** dropdown. | ||
|
||
Enter the following code in the **Formatter code** field: | ||
|
||
```js | ||
function decodeUplink(input) { | ||
var value1 = input.bytes[0]; | ||
var value2 = (input.bytes[1] << 8) | input.bytes[2]; | ||
|
||
return { | ||
data: { | ||
value1: value1, | ||
value2: value2 | ||
} | ||
}; | ||
} | ||
|
||
``` | ||
|
||
Click **Save changes** at the bottom of the page and go back to the **Live Data** tab to view all messages exchanged between the end device and {{% tts %}}. | ||
|
||
{{< figure src="live-data.png" alt="Live data tab" >}} |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.