I have a CubeCell as a Sender and ESP8266 with RFM96W as a Receiver.
The Goal is Sender sends data every 60s and sleeps in low power mode (8uA) as fast as possible.
First, I confirm both settings are correct.
The ESP8266 can get the package and show “Received packet ‘ADC_battery: 3930’ with RSSI -70” in serial port.
However, it always jumps to OnTxTimeout but not OnTxDone. And it never goes low power mode (8uA).
Where I should add Radio.Sleep( );?
or
Where I should add lowPowerHandler(); and run it 6 times?
I hope Heltec can add more descriptions of these sub-function
/* Heltec Automation Ping Pong communication test example
*
- Function:
- CubeCell read battery voltage and transmit via LoRa.
- Description:
- Only hardware layer communicate, no LoRaWAN protocol support;
- This examplese can communicate with other ESP32 LoRa device,
- WiFi LoRa 32, Wireless Stick, Wireless Stick Lite, etc.
- This example is for CubeCell hardware basic test.
- HelTec AutoMation, Chengdu, China
- 成都惠利特自动化科技有限公司
- https://heltec.org
- this project also realess in GitHub:
- https://github.com/HelTecAutomation/ASR650x-Arduino
- */
#include “LoRaWan_APP.h”
#include “Arduino.h”/*
- set LoraWan_RGB to 1,the RGB active in loraWan
- RGB red means sending;
- RGB green means received done;
*/
#ifndef LoraWan_RGB
#define LoraWan_RGB 0
#endif#define RF_FREQUENCY 433000000 // Hz
#define TX_OUTPUT_POWER -10 // dBm
#define LORA_BANDWIDTH 0 // [0: 125 kHz,
// 1: 250 kHz,
// 2: 500 kHz,
// 3: Reserved]
#define LORA_SPREADING_FACTOR 7 // [SF7…SF12]
#define LORA_CODINGRATE 1 // [1: 4/5,
// 2: 4/6,
// 3: 4/7,
// 4: 4/8]
#define LORA_PREAMBLE_LENGTH 8 // Same for Tx and Rx
#define LORA_SYMBOL_TIMEOUT 0 // Symbols
#define LORA_FIX_LENGTH_PAYLOAD_ON false
#define LORA_IQ_INVERSION_ON false#define RX_TIMEOUT_VALUE 1000
#define BUFFER_SIZE 30 // Define the payload size herechar txPacket[BUFFER_SIZE];
static RadioEvents_t RadioEvents;
void OnTxDone( void );
void OnTxTimeout( void );typedef enum
{
LOWPOWER,
ReadVoltage,
TX
}States_t;States_t state;
bool sleepMode = false;
int16_t rssi,rxSize;
uint16_t voltage;void setup() {
boardInitMcu( );
Serial.begin(115200);voltage = 0; rssi=0; RadioEvents.TxDone = OnTxDone; RadioEvents.TxTimeout = OnTxTimeout; Radio.Init( &RadioEvents ); Radio.SetChannel( RF_FREQUENCY ); Radio.SetTxConfig( MODEM_LORA, TX_OUTPUT_POWER, 0, LORA_BANDWIDTH, LORA_SPREADING_FACTOR, LORA_CODINGRATE, LORA_PREAMBLE_LENGTH, LORA_FIX_LENGTH_PAYLOAD_ON, true, 0, 0, LORA_IQ_INVERSION_ON, 3000 ); state=TX;
}
void loop()
{
switch(state)
{
case TX:
{
sprintf(txPacket,"%s",“ADC_battery: “);
sprintf(txPacket+strlen(txPacket),”%d”,voltage);
turnOnRGB(COLOR_SEND,0);
Serial.printf("\r\nsending packet “%s” , length %d\r\n",txPacket, strlen(txPacket));
Radio.Send( (uint8_t *)txPacket, strlen(txPacket) );
state=LOWPOWER;
break;
}
case LOWPOWER:
{
lowPowerHandler();
delay(100);
turnOffRGB();
delay(60000); //LowPower time
state = ReadVoltage;
break;
}
case ReadVoltage:
{
pinMode(VBAT_ADC_CTL,OUTPUT);
digitalWrite(VBAT_ADC_CTL,LOW);
voltage=analogRead(ADC)*2;
digitalWrite(VBAT_ADC_CTL,HIGH);
state = TX;
break;
}
default:
break;
}
}void OnTxDone( void )
{
Serial.print(“TX done!”);
turnOnRGB(0,0);
state=TX;
}void OnTxTimeout( void )
{
Radio.Sleep( );
Serial.print(“TX Timeout…”);
state=TX;
}