/* * This sketch simply repeats data received from remote weather sensors made by Cresta. * * Setup: * - connect digital output of a 433MHz receiver to digital pin 2 of Arduino. * - connect transmitter input of a 433MHz transmitter to digital pin 11 * - An LED on pin 13 will tell you if and when a signal has been received and transmitted. * * Library: * https://github.com/mattwire/arduino-dev/tree/master/libraries/RemoteSensor * https://github.com/LSatan/SmartRC-CC1101-Driver-Lib * */ #include #include #include int LED_PIN; int pinRx; // int for Receive pin. int pinTx; // int for Transmit pin. void setup() { #ifdef ESP32 pinRx = 4; pinTx = 2; // for esp32! Receiver on GPIO pin 4. Transmit on GPIO pin 2. LED_PIN = 32; // set led on GPIO pin 32. #elif ESP8266 pinRx = 4; pinTx = 5; // for esp8266! Receiver on pin 4 = D2. Transmit on pin 5 = D1. LED_PIN = 16; // set led on pin 16 = D0. #else pinRx = 0; pinTx = 6; // for Arduino! Receiver on interrupt 0 => that is pin #2. Transmit on pin 6. LED_PIN = 4; // set led on pin D4. #endif if (ELECHOUSE_cc1101.getCC1101()){ // Check the CC1101 Spi connection. Serial.println("Connection OK"); }else{ Serial.println("Connection Error"); } //CC1101 Settings: (Settings with "//" are optional!) ELECHOUSE_cc1101.Init(); // must be set to initialize the cc1101! //ELECHOUSE_cc1101.setRxBW(812.50); // Set the Receive Bandwidth in kHz. Value from 58.03 to 812.50. Default is 812.50 kHz. //ELECHOUSE_cc1101.setPA(10); // set TxPower. The following settings are possible depending on the frequency band. (-30 -20 -15 -10 -6 0 5 7 10 11 12) Default is max! ELECHOUSE_cc1101.setMHZ(433.92); // Here you can set your basic frequency. The lib calculates the frequency automatically (default = 433.92).The cc1101 can: 300-348 MHZ, 387-464MHZ and 779-928MHZ. Read More info from datasheet. pinMode(LED_PIN, OUTPUT); // Since we're not instantiating SensorTransmitter, but only use the static methods of SensorTransmitter, // the pin mode must be set manually. pinMode(pinTx, OUTPUT); // When no signal has been received, the LED is lit. digitalWrite(LED_PIN, HIGH); // Init the receiver on interrupt pin 0 (digital pin 2). // Set the callback to function "retransmit", which is called // whenever valid sensor data has been received. ELECHOUSE_cc1101.SetRx(); // set Receive on SensorReceiver::init(pinRx, retransmit); } void loop() { } void retransmit(byte *data) { // Data received // Wait a second after a receiving. There's little point for decoding and sending the same signal multiple times. SensorReceiver::disable(); interrupts(); // delay() requires that interrupts are enabled delay(1000); // Flash LED when transmitting. digitalWrite(LED_PIN, HIGH); // Transmit signal. Note: this is a static method, no object required! ELECHOUSE_cc1101.SetTx(); // set Transmit on SensorTransmitter::sendPackage(pinTx, data); digitalWrite(LED_PIN, LOW); noInterrupts(); ELECHOUSE_cc1101.SetRx(); // set Receive on SensorReceiver::enable(); }