Stub out RTC integration.
This commit is contained in:
parent
bfc43443b4
commit
5f6cfd653c
|
@ -18,5 +18,7 @@ lib_deps =
|
||||||
me-no-dev/ESP Async WebServer@^1.2.3
|
me-no-dev/ESP Async WebServer@^1.2.3
|
||||||
contrem/arduino-timer@^3.0.1
|
contrem/arduino-timer@^3.0.1
|
||||||
kj7rrv/Telegraph@^1.0.0
|
kj7rrv/Telegraph@^1.0.0
|
||||||
;etherkit/Etherkit Morse@^1.1.2
|
|
||||||
jandelgado/JLed@^4.13.0
|
jandelgado/JLed@^4.13.0
|
||||||
|
adafruit/RTClib@^2.1.1
|
||||||
|
adafruit/Adafruit BusIO@^1.14.3
|
||||||
|
;jchristensen/DS3232RTC@^2.0.1
|
||||||
|
|
|
@ -17,18 +17,22 @@
|
||||||
#include <SPIFFS.h>
|
#include <SPIFFS.h>
|
||||||
#include <Preferences.h>
|
#include <Preferences.h>
|
||||||
#include <arduino-timer.h>
|
#include <arduino-timer.h>
|
||||||
#include <Telegraph.h>
|
// #include <Telegraph.h>
|
||||||
//#include <morse.h> //arduino morse
|
//#include <morse.h> //arduino morse
|
||||||
//#include <Morse.h> //etherkit morse
|
//#include <Morse.h> //etherkit morse
|
||||||
#include <jled.h> // jled
|
#include <jled.h> // jled
|
||||||
#include "jled/morse.h" //jled
|
#include "jled/morse.h" //jled
|
||||||
//#include "morse_effect.h" // jled
|
#include <Adafruit_BusIO_Register.h> // for DS3231
|
||||||
|
#include <RTClib.h> // for DS3231
|
||||||
|
//#include <DS3232RTC.h> //for DS3231
|
||||||
|
|
||||||
// download zip from https://github.com/me-no-dev/ESPAsyncWebServer and install.
|
// download zip from https://github.com/me-no-dev/ESPAsyncWebServer and install.
|
||||||
#include <ESPAsyncWebServer.h>
|
#include <ESPAsyncWebServer.h>
|
||||||
|
|
||||||
AsyncWebServer server(80);
|
AsyncWebServer server(80);
|
||||||
|
|
||||||
|
RTC_DS3231 rtc;
|
||||||
|
|
||||||
// Read from config.h
|
// Read from config.h
|
||||||
const char* ssid = WIFI_SSID;
|
const char* ssid = WIFI_SSID;
|
||||||
const char* password = WIFI_PASSWORD;
|
const char* password = WIFI_PASSWORD;
|
||||||
|
@ -38,6 +42,7 @@ const char* PARAM_SEND = "inputSend";
|
||||||
const char* PARAM_WPM = "inputWPM";
|
const char* PARAM_WPM = "inputWPM";
|
||||||
const char* PARAM_MSG = "inputMsg";
|
const char* PARAM_MSG = "inputMsg";
|
||||||
const char* PARAM_FLOAT = "inputFloat";
|
const char* PARAM_FLOAT = "inputFloat";
|
||||||
|
const char* PARAM_TIME = "inputTimeUnix";
|
||||||
|
|
||||||
// Global variables
|
// Global variables
|
||||||
String yourInputString;
|
String yourInputString;
|
||||||
|
@ -46,6 +51,7 @@ int yourInputWPM;
|
||||||
int yourInputMsg;
|
int yourInputMsg;
|
||||||
int yourInputMsg_old; // to save previous state and check changes
|
int yourInputMsg_old; // to save previous state and check changes
|
||||||
float yourInputFloat;
|
float yourInputFloat;
|
||||||
|
String yourInputTime; //to keep time
|
||||||
|
|
||||||
// HTML web page to handle 3 input fields (inputString, inputSend, inputFloat)
|
// HTML web page to handle 3 input fields (inputString, inputSend, inputFloat)
|
||||||
const char index_html[] PROGMEM = R"rawliteral(
|
const char index_html[] PROGMEM = R"rawliteral(
|
||||||
|
@ -80,10 +86,15 @@ const char index_html[] PROGMEM = R"rawliteral(
|
||||||
|
|
||||||
WPM (current value %inputWPM%): <input type="number " name="inputWPM" value = %inputWPM%> (doesn't work yet)<br>
|
WPM (current value %inputWPM%): <input type="number " name="inputWPM" value = %inputWPM%> (doesn't work yet)<br>
|
||||||
|
|
||||||
|
Time Unix: <input type="text" name="inputTimeUnix" id="js_time_unix"><br>
|
||||||
|
|
||||||
inputFloat (current value %inputFloat%): <input type="number " name="inputFloat" value = %inputFloat%><br>
|
inputFloat (current value %inputFloat%): <input type="number " name="inputFloat" value = %inputFloat%><br>
|
||||||
<input type="submit" value="Submit" onclick="submitMessage()">
|
<input type="submit" value="Submit" onclick="submitMessage()">
|
||||||
</form>
|
</form>
|
||||||
<iframe style="display:none" name="hidden-form"></iframe>
|
<iframe style="display:none" name="hidden-form"></iframe>
|
||||||
|
<script>
|
||||||
|
document.getElementById("js_time_unix").value = Date.now();
|
||||||
|
</script>
|
||||||
</body></html>)rawliteral";
|
</body></html>)rawliteral";
|
||||||
|
|
||||||
// Auxiliary variables to store the current output state
|
// Auxiliary variables to store the current output state
|
||||||
|
@ -91,7 +102,7 @@ String output26State = "off";
|
||||||
String output27State = "off";
|
String output27State = "off";
|
||||||
|
|
||||||
// Assign output variables to GPIO pins
|
// Assign output variables to GPIO pins
|
||||||
const int output26 = 26;
|
const int output26 = 32;//26 for LED; //32 for transmitter keyer
|
||||||
const int output27 = 27;
|
const int output27 = 27;
|
||||||
|
|
||||||
// Timers
|
// Timers
|
||||||
|
@ -106,16 +117,16 @@ bool toggle_led(void *) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Toggle GPIO pin (LED or relay)
|
// Toggle GPIO pin (LED or relay)
|
||||||
bool toggle_gpio_26(void *) {
|
// bool toggle_gpio_26(void *) {
|
||||||
if(output26State == "off"){
|
// if(output26State == "off"){
|
||||||
output26State = "on";
|
// output26State = "on";
|
||||||
digitalWrite(output26, HIGH);
|
// digitalWrite(output26, HIGH);
|
||||||
} else {
|
// } else {
|
||||||
output26State = "off";
|
// output26State = "off";
|
||||||
digitalWrite(output26, LOW);
|
// digitalWrite(output26, LOW);
|
||||||
}
|
// }
|
||||||
return true; // keep timer active? true
|
// return true; // keep timer active? true
|
||||||
}
|
// }
|
||||||
|
|
||||||
void notFound(AsyncWebServerRequest *request) {
|
void notFound(AsyncWebServerRequest *request) {
|
||||||
request->send(404, "text/plain", "Not found");
|
request->send(404, "text/plain", "Not found");
|
||||||
|
@ -174,65 +185,65 @@ String processor(const String& var){
|
||||||
return String();
|
return String();
|
||||||
}
|
}
|
||||||
|
|
||||||
// vvvvv Modify some functions from KB1OIQ's controller.
|
// // vvvvv Modify some functions from KB1OIQ's controller.
|
||||||
// This section hasn't been tested on the hardware.
|
// // This section hasn't been tested on the hardware.
|
||||||
|
|
||||||
//int dit_len = 60 ; //milliseconds; https://morsecode.world/international/timing.html
|
// //int dit_len = 60 ; //milliseconds; https://morsecode.world/international/timing.html
|
||||||
|
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
// stop_26(): set GPIO 26 to LOW. Used for dot(), dash().
|
// // stop_26(): set GPIO 26 to LOW. Used for dot(), dash().
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
bool stop_26(void *){
|
// bool stop_26(void *){
|
||||||
output26State = "off";
|
// output26State = "off";
|
||||||
digitalWrite(output26, LOW);
|
// digitalWrite(output26, LOW);
|
||||||
return false; // keep timer active? true
|
// return false; // keep timer active? true
|
||||||
}
|
// }
|
||||||
|
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
// dit(): transmit a single dit
|
// // dit(): transmit a single dit
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
void dit(int dit_len = 1000) {
|
// void dit(int dit_len = 1000) {
|
||||||
output26State = "on";
|
// output26State = "on";
|
||||||
digitalWrite(output26, HIGH);
|
// digitalWrite(output26, HIGH);
|
||||||
timer.in(dit_len, stop_26);
|
// timer.in(dit_len, stop_26);
|
||||||
}
|
// }
|
||||||
|
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
// dah(): transmit a single dah
|
// // dah(): transmit a single dah
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
void dah(int dit_len = 1000) {
|
// void dah(int dit_len = 1000) {
|
||||||
output26State = "on";
|
// output26State = "on";
|
||||||
digitalWrite(output26, HIGH);
|
// digitalWrite(output26, HIGH);
|
||||||
timer.in(dit_len * 3, stop_26);
|
// timer.in(dit_len * 3, stop_26);
|
||||||
}
|
// }
|
||||||
|
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
// char_space()): transmit a character space
|
// // char_space()): transmit a character space
|
||||||
//================================================================================
|
// //================================================================================
|
||||||
// A function that does nothing except (hopefully) block the timer.
|
// // A function that does nothing except (hopefully) block the timer.
|
||||||
bool empty(void *) {
|
// bool empty(void *) {
|
||||||
return false;
|
// return false;
|
||||||
}
|
// }
|
||||||
|
|
||||||
void char_space(int dit_len = 1000) {
|
// void char_space(int dit_len = 1000) {
|
||||||
|
|
||||||
timer.in(dit_len, empty);
|
// timer.in(dit_len, empty);
|
||||||
}
|
// }
|
||||||
|
|
||||||
void k(){
|
// void k(){
|
||||||
Serial.println("K");
|
// Serial.println("K");
|
||||||
dah();
|
// dah();
|
||||||
char_space();
|
// char_space();
|
||||||
dit();
|
// dit();
|
||||||
char_space();
|
// char_space();
|
||||||
dah();
|
// dah();
|
||||||
}
|
// }
|
||||||
|
|
||||||
// ^^^^
|
// // ^^^^
|
||||||
|
|
||||||
//telegraph
|
// //telegraph
|
||||||
//Telegraph telegraph(LED_BUILTIN, 10, HIGH);
|
// //Telegraph telegraph(LED_BUILTIN, 10, HIGH);
|
||||||
Telegraph telegraph26(output26, 10, HIGH);
|
// Telegraph telegraph26(output26, 10, HIGH);
|
||||||
|
|
||||||
//arduinomorse
|
//arduinomorse
|
||||||
//LEDMorseSender sender(LED_BUILTIN);
|
//LEDMorseSender sender(LED_BUILTIN);
|
||||||
|
@ -265,7 +276,7 @@ class MorseEffect : public jled::BrightnessEvaluator {
|
||||||
float wpm = 10;
|
float wpm = 10;
|
||||||
float ms_per_dit = 1000 * (60 / (50 * wpm));
|
float ms_per_dit = 1000 * (60 / (50 * wpm));
|
||||||
int word_space_ms = ms_per_dit * 7;
|
int word_space_ms = ms_per_dit * 7;
|
||||||
// Hardcoding these for now, will come back and make it more flexible.
|
// Hardcoding messages and WPM for now, will come back and make it more flexible.
|
||||||
MorseEffect morseEffectCQ("CQ CQ CQ DE W1CDN", ms_per_dit);
|
MorseEffect morseEffectCQ("CQ CQ CQ DE W1CDN", ms_per_dit);
|
||||||
MorseEffect morseEffectMOE("MOE", ms_per_dit);
|
MorseEffect morseEffectMOE("MOE", ms_per_dit);
|
||||||
MorseEffect morseEffectMOI("MOI", ms_per_dit);
|
MorseEffect morseEffectMOI("MOI", ms_per_dit);
|
||||||
|
@ -287,12 +298,48 @@ auto morseMO5 =
|
||||||
JLed(output26).UserFunc(&morseEffectMO5).DelayAfter(word_space_ms).Forever();
|
JLed(output26).UserFunc(&morseEffectMO5).DelayAfter(word_space_ms).Forever();
|
||||||
auto morseToSend = morseCQ; // set this up to overwrite later
|
auto morseToSend = morseCQ; // set this up to overwrite later
|
||||||
|
|
||||||
|
|
||||||
|
// format and print a time_t value
|
||||||
|
// void printTime(time_t t)
|
||||||
|
// {
|
||||||
|
// char buf[25];
|
||||||
|
// char m[4]; // temporary storage for month string (DateStrings.cpp uses shared buffer)
|
||||||
|
// strcpy(m, monthShortStr(month(t)));
|
||||||
|
// sprintf(buf, "%.2d:%.2d:%.2d %s %.2d %s %d",
|
||||||
|
// hour(t), minute(t), second(t), dayShortStr(weekday(t)), day(t), m, year(t));
|
||||||
|
// Serial.println(buf);
|
||||||
|
// }
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
// setup(): stuff that only gets done once, after power up (KB1OIQ's description)
|
// setup(): stuff that only gets done once, after power up (KB1OIQ's description)
|
||||||
//================================================================================
|
//================================================================================
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(115200);
|
Serial.begin(115200);
|
||||||
|
|
||||||
|
// https://github.com/JChristensen/DS3232RTC/blob/master/examples/TimeRTC/TimeRTC.ino
|
||||||
|
// rtc.begin();
|
||||||
|
// setSyncProvider(rtc.get); // the function to get the time from the RTC
|
||||||
|
// if(timeStatus() != timeSet)
|
||||||
|
// Serial.println("Unable to sync with the RTC");
|
||||||
|
// else
|
||||||
|
// Serial.println("RTC has set the system time");
|
||||||
|
|
||||||
|
if (! rtc.begin()) {
|
||||||
|
Serial.println("Couldn't find RTC");
|
||||||
|
Serial.flush();
|
||||||
|
while (1) delay(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rtc.lostPower()) {
|
||||||
|
Serial.println("RTC lost power, let's set the time!");
|
||||||
|
// When time needs to be set on a new device, or after a power loss, the
|
||||||
|
// following line sets the RTC to the date & time this sketch was compiled
|
||||||
|
rtc.adjust(DateTime(__DATE__, __TIME__));
|
||||||
|
// This line sets the RTC with an explicit date & time, for example to set
|
||||||
|
// January 21, 2014 at 3am you would call:
|
||||||
|
//rtc.adjust(DateTime(2023, 9, 2, 17, 32, 0));
|
||||||
|
}
|
||||||
|
|
||||||
// Timer example, blink main LED
|
// Timer example, blink main LED
|
||||||
pinMode(LED_BUILTIN, OUTPUT); // set LED pin to OUTPUT
|
pinMode(LED_BUILTIN, OUTPUT); // set LED pin to OUTPUT
|
||||||
// call the toggle_led function every 10000 millis (10 second)
|
// call the toggle_led function every 10000 millis (10 second)
|
||||||
|
@ -407,6 +454,12 @@ void setup() {
|
||||||
yourInputMsg_old = yourInputMsg;
|
yourInputMsg_old = yourInputMsg;
|
||||||
yourInputMsg = inputMessage.toInt();
|
yourInputMsg = inputMessage.toInt();
|
||||||
}
|
}
|
||||||
|
// GET inputTimeUnix value on <ESP_IP>/get?inputTimeUnix=<inputMessage>
|
||||||
|
if (request->hasParam(PARAM_TIME)) {
|
||||||
|
inputMessage = request->getParam(PARAM_TIME)->value();
|
||||||
|
yourInputTime = inputMessage;
|
||||||
|
Serial.println(yourInputTime);
|
||||||
|
}
|
||||||
// GET inputFloat value on <ESP_IP>/get?inputFloat=<inputMessage>
|
// GET inputFloat value on <ESP_IP>/get?inputFloat=<inputMessage>
|
||||||
if (request->hasParam(PARAM_FLOAT)) {
|
if (request->hasParam(PARAM_FLOAT)) {
|
||||||
inputMessage = request->getParam(PARAM_FLOAT)->value();
|
inputMessage = request->getParam(PARAM_FLOAT)->value();
|
||||||
|
@ -440,6 +493,23 @@ void loop() {
|
||||||
time_until_start.tick();
|
time_until_start.tick();
|
||||||
timer.tick();
|
timer.tick();
|
||||||
|
|
||||||
|
DateTime now = rtc.now();
|
||||||
|
// Serial.print(now.year(), DEC);
|
||||||
|
// Serial.print('/');
|
||||||
|
// Serial.print(now.month(), DEC);
|
||||||
|
// Serial.print('/');
|
||||||
|
// Serial.print(now.day(), DEC);
|
||||||
|
// Serial.print(" (");
|
||||||
|
// Serial.print(now.dayOfTheWeek());
|
||||||
|
// Serial.print(") ");
|
||||||
|
// Serial.print(now.hour(), DEC);
|
||||||
|
// Serial.print(':');
|
||||||
|
// Serial.print(now.minute(), DEC);
|
||||||
|
// Serial.print(':');
|
||||||
|
// Serial.print(now.second(), DEC);
|
||||||
|
// Serial.println();
|
||||||
|
|
||||||
|
|
||||||
//arduinomorse
|
//arduinomorse
|
||||||
//sender.continueSending();
|
//sender.continueSending();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user