From af968f144a34759664987919f5cf1a9bed7656c5 Mon Sep 17 00:00:00 2001
From: Der RC-Modellbauer
Date: Sun, 25 Dec 2022 19:25:57 +0100
Subject: [PATCH] External power supply with voltage measurement
- External power supply with voltage measurement
- EEPROM cells in plain text
---
Servotester_Deluxe/Servotester_Deluxe.ino | 483 +++++++++++++++-------
1 file changed, 334 insertions(+), 149 deletions(-)
diff --git a/Servotester_Deluxe/Servotester_Deluxe.ino b/Servotester_Deluxe/Servotester_Deluxe.ino
index bf6f8f7..be7713a 100644
--- a/Servotester_Deluxe/Servotester_Deluxe.ino
+++ b/Servotester_Deluxe/Servotester_Deluxe.ino
@@ -20,11 +20,16 @@
// ======== Servotester Deluxe =======================================
+/* Boardversion
+ESP32 2.0.5
+ */
+
/* Installierte Bibliotheken
-ESP32Servo 0.12.0
-ESP32Encoder 0.9.1
-Bolder Flight Systems SBUS 8.1.4
-IBusBM 1.1.4
+ESP32Servo 0.12.1
+ESP32Encoder 0.10.1
+Bolder Flight Systems SBUS 8.1.4
+IBusBM 1.1.4
+ESP8266 and ESP OLED driver SSD1306 displays 4.3.0
*/
#include
@@ -37,21 +42,29 @@ IBusBM 1.1.4
#include //1.3 Zoll
#include "SSD1306Wire.h"
-const float Version = 0.51; // Software Version
+const float Version = 0.6; // Software Version
//#define OLED1306 //0.96 Zoll
// EEprom
-#define EEPROM_SIZE 24
+#define EEPROM_SIZE 28
#define adr_eprom_WIFI_ON 0 // WIFI 1 = Ein 0 = Aus
#define adr_eprom_SERVO_STEPS 4 // SERVO Steps für Encoder im Servotester Modus
#define adr_eprom_SERVO_MAX 8 // SERVO µs Max Wert im Servotester Modus
#define adr_eprom_SERVO_MIN 12 // SERVO µs Min Wert im Servotester Modus
#define adr_eprom_SERVO_Mitte 16 // SERVO µs Mitte Wert im Servotester Modus
-#define adr_eprom_SERVO_Hz 20 // SERVO µs Mitte Wert im Servotester Modus
-
-int settings[6]; //Speicher der Einstellungen
+#define adr_eprom_SERVO_Hz 20 // SERVO µs Mitte Wert im Servotester Modus
+#define adr_eprom_POWER_SCALE 24 // SERVO µs Mitte Wert im Servotester Modus
+
+//Speicher der Einstellungen
+int WIFI_ON;
+int SERVO_STEPS;
+int SERVO_MAX;
+int SERVO_MIN;
+int SERVO_Mitte;
+int SERVO_Hz;
+int POWER_SCALE;
//Encoder + Taster
ESP32Encoder encoder;
@@ -84,6 +97,13 @@ bfs::SbusData sbus_data;
// IBUS
IBusBM IBus; // IBus object
+// Externe Spannungsversorgung
+int Power_PIN = 36; // Hardware Pin Externe Spannung in
+bool Power_EN; // Akku vorhanden
+int Power_Zel; // Akkuzellen
+float Power_V; // Akkuspannung in V
+float Power_V_per; // Akkuspannung in Prozent
+
//Menüstruktur
/*
* 1 = Servotester_Auswahl Auswahl -> 10 Servotester_Menu
@@ -132,6 +152,7 @@ bool SetupMenu = false; // Zustand Setupmenu
int Einstellung =0 ; // Aktives Einstellungsmenu
bool Edit = false; // Einstellungen ausgewählt
+//OLED
#ifdef OLED1306
SSD1306Wire display(0x3c, SDA, SCL); // Oled Hardware an SDA 21 und SCL 22
#else
@@ -157,12 +178,20 @@ int pos1 = 0;
int pos2 = 0;
unsigned long currentTime = millis(); // Aktuelle Zeit
-unsigned long currentTimeAuto = millis(); // Aktuelle Zeit
+unsigned long currentTimeAuto = millis(); // Aktuelle Zeit für Auto Modus
+unsigned long currentTimeSpan = millis(); // Aktuelle Zeit für Externe Spannung
unsigned long previousTime = 0; // Previous time
-unsigned long previousTimeAuto = 0; // Previous time
+unsigned long previousTimeAuto = 0; // Previous time für Auto Modus
+unsigned long previousTimeSpan = 0; // Previous time für Externe Spannung
unsigned long TimeAuto = 50; // Auto time
const long timeoutTime = 2000; // Define timeout time in milliseconds (example: 2000ms = 2s)
+//MAP als Float
+float map_float(float x, float in_min, float in_max, float out_min, float out_max)
+{
+ return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min;
+}
+
// ======== Setup =======================================
void setup() {
// Setup Serial
@@ -171,25 +200,29 @@ void setup() {
//EEPROM
EEPROM.begin(EEPROM_SIZE);
EEprom_Load(); // Einstellung laden
- Serial.println(settings[0]);
- Serial.println(settings[1]);
- Serial.println(settings[2]);
- Serial.println(settings[3]);
- Serial.println(settings[4]);
-
- if (settings[3] < 500) { //EEporm int Werte
- settings[0] = 0;
- settings[1] = 10;
- settings[2] = 2000;
- settings[3] = 1000;
- settings[4] = 1500;
- settings[5] = 50;
+ Serial.println(WIFI_ON);
+ Serial.println(SERVO_STEPS);
+ Serial.println(SERVO_MAX);
+ Serial.println(SERVO_MIN);
+ Serial.println(SERVO_Mitte);
+ Serial.println(POWER_SCALE);
+
+ if (SERVO_MIN < 500) { //EEporm int Werte
+ WIFI_ON = 1; //Wifi ein
+ SERVO_STEPS = 10;
+ SERVO_MAX = 2000;
+ SERVO_MIN = 1000;
+ SERVO_Mitte = 1500;
+ SERVO_Hz = 50;
+ POWER_SCALE = 500;
}
// Setup Encoder
ESP32Encoder::useInternalWeakPullResistors=UP;
encoder.attachHalfQuad(encoder_Pin1, encoder_Pin2);
pinMode(button_PIN,INPUT_PULLUP); // Button_PIN = Eingang
+
+ pinMode(Power_PIN,INPUT); //
// Setup OLED
@@ -201,7 +234,7 @@ void setup() {
delay(1000);
- if (settings[0] == 1) { //Wifi Ein
+ if (WIFI_ON == 1) { //Wifi Ein
// Print local IP address and start web server
Serial.print("AP (Zugangspunkt) einstellen…");
WiFi.softAP(ssid, password);
@@ -269,7 +302,9 @@ void loop(){
MenuUpdate();
- if (settings[0] == 1) { //Wifi Ein
+ Extern_Span();
+
+ if (WIFI_ON == 1) { //Wifi Ein
WiFiClient client = server.available(); // Listen for incoming clients
if (client) { // If a new client connects,
@@ -331,28 +366,34 @@ void loop(){
pos1 = header.indexOf('=');
pos2 = header.indexOf('&');
valueString = header.substring(pos1+1, pos2);
- settings[1] = (valueString.toInt());
+ SERVO_STEPS = (valueString.toInt());
}
if(header.indexOf("GET /?Set2=")>=0) {
pos1 = header.indexOf('=');
pos2 = header.indexOf('&');
valueString = header.substring(pos1+1, pos2);
- settings[2] = (valueString.toInt());
+ SERVO_MAX = (valueString.toInt());
}
if(header.indexOf("GET /?Set3=")>=0) {
pos1 = header.indexOf('=');
pos2 = header.indexOf('&');
valueString = header.substring(pos1+1, pos2);
- settings[3] = (valueString.toInt());
+ SERVO_MIN = (valueString.toInt());
}
if(header.indexOf("GET /?Set4=")>=0) {
pos1 = header.indexOf('=');
pos2 = header.indexOf('&');
valueString = header.substring(pos1+1, pos2);
- if (valueString.toInt() > settings[3]){ //Nur übernehmen wenn > MIN
- settings[4] = (valueString.toInt());
+ if (valueString.toInt() > SERVO_MIN){ //Nur übernehmen wenn > MIN
+ SERVO_Mitte = (valueString.toInt());
}
}
+ if(header.indexOf("GET /?Set5=")>=0) {
+ pos1 = header.indexOf('=');
+ pos2 = header.indexOf('&');
+ valueString = header.substring(pos1+1, pos2);
+ SERVO_Hz = (valueString.toInt());
+ }
if(header.indexOf("GET /?Speed=")>=0) {
pos1 = header.indexOf('=');
pos2 = header.indexOf('&');
@@ -361,23 +402,23 @@ void loop(){
}
if (header.indexOf("GET /mitte1/on") >= 0)
{
- servo_pos[0] = settings[4]; //Mitte
+ servo_pos[0] = SERVO_Mitte; //Mitte
}
if (header.indexOf("GET /mitte2/on") >= 0)
{
- servo_pos[1] = settings[4]; //Mitte
+ servo_pos[1] = SERVO_Mitte; //Mitte
}
if (header.indexOf("GET /mitte3/on") >= 0)
{
- servo_pos[2] = settings[4]; //Mitte
+ servo_pos[2] = SERVO_Mitte; //Mitte
}
if (header.indexOf("GET /mitte4/on") >= 0)
{
- servo_pos[3] = settings[4]; //Mitte
+ servo_pos[3] = SERVO_Mitte; //Mitte
}
if (header.indexOf("GET /mitte5/on") >= 0)
{
- servo_pos[4] = settings[4]; //Mitte
+ servo_pos[4] = SERVO_Mitte; //Mitte
}
if (header.indexOf("GET /back/on") >= 0)
{
@@ -450,7 +491,7 @@ void loop(){
client.println("Servo 1 Mikrosekunden : " + valueString + "");
client.println("
");
- client.println("");
+ client.println("");
client.println("");
- valueString = String(settings[2], DEC);
+ valueString = String(SERVO_MAX, DEC);
client.println("Servo MAX : " + valueString + "");
client.println("");
@@ -567,7 +608,7 @@ void loop(){
client.println("xhr.open('GET', \"/?Set2=\" + pos + \"&\", true);");
client.println("xhr.send(); } ");
- valueString = String(settings[3], DEC);
+ valueString = String(SERVO_MIN, DEC);
client.println("
Servo MIN : " + valueString + "");
client.println("");
@@ -579,7 +620,7 @@ void loop(){
client.println("xhr.open('GET', \"/?Set3=\" + pos + \"&\", true);");
client.println("xhr.send(); } ");
- valueString = String(settings[4], DEC);
+ valueString = String(SERVO_Mitte, DEC);
client.println("
Servo Mitte : " + valueString + "");
client.println("");
@@ -591,6 +632,18 @@ void loop(){
client.println("xhr.open('GET', \"/?Set4=\" + pos + \"&\", true);");
client.println("xhr.send(); } ");
+ valueString = String(SERVO_Hz, DEC);
+
+ client.println("
Servo Hz : " + valueString + "");
+ client.println("");
+
+ client.println("");
+
client.println("
");
client.println("
");
@@ -715,6 +768,19 @@ switch (Menu) {
display.drawString(64, 0, " Menu >" );
display.setFont(ArialMT_Plain_16);
display.drawString(64, 25,"Servotester" );
+ if (Power_EN)
+ {
+ display.setFont(ArialMT_Plain_10);
+ display.setTextAlignment(TEXT_ALIGN_RIGHT);
+ display.drawString(30, 50, String(Power_V));
+ display.setTextAlignment(TEXT_ALIGN_LEFT);
+ display.drawString(30, 50, "V");
+ display.setTextAlignment(TEXT_ALIGN_RIGHT);
+ display.drawString(98, 50, String(Power_V_per));
+ display.setTextAlignment(TEXT_ALIGN_LEFT);
+ display.drawString(98, 50, "%");
+ }
+
display.display();
if (encoderState == 1){
@@ -859,23 +925,23 @@ switch (Menu) {
display.setTextAlignment(TEXT_ALIGN_LEFT);
display.setFont(ArialMT_Plain_10);
display.drawString(0, 0, "HZ");
- display.drawString(0, 10, String(settings[5]));
+ display.drawString(0, 10, String(SERVO_Hz));
display.setTextAlignment(TEXT_ALIGN_CENTER);
display.setFont(ArialMT_Plain_24);
display.drawString(64, 0, "Servo" + String(servocount+1));
//display.drawString(64, 25, String(servo_pos[servocount]) + "°");
//display.drawProgressBar(8, 50, 112, 10, ((servo_pos[servocount]*100)/180));
display.drawString(64, 25, String(servo_pos[servocount]) + "µs");
- display.drawProgressBar(8, 50, 112, 10, (((servo_pos[servocount]-settings[3])*100)/(settings[2]-settings[3])));
+ display.drawProgressBar(8, 50, 112, 10, (((servo_pos[servocount]-SERVO_MIN)*100)/(SERVO_MAX-SERVO_MIN)));
display.display();
if (!SetupMenu)
{
- servo[0].attach(servopin[0],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[1].attach(servopin[1],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[2].attach(servopin[2],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[3].attach(servopin[3],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[4].attach(servopin[4],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[0].setPeriodHertz(settings[5]);
+ servo[0].attach(servopin[0],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[1].attach(servopin[1],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[2].attach(servopin[2],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[3].attach(servopin[3],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[4].attach(servopin[4],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[0].setPeriodHertz(SERVO_Hz);
SetupMenu = true;
}
@@ -886,19 +952,19 @@ switch (Menu) {
servo[4].writeMicroseconds(servo_pos[4]);
if (encoderState == 1){
- servo_pos[servocount] = servo_pos[servocount] - settings[1] ;
+ servo_pos[servocount] = servo_pos[servocount] - SERVO_STEPS ;
}
if (encoderState == 2){
- servo_pos[servocount] = servo_pos[servocount] + settings[1] ;
+ servo_pos[servocount] = servo_pos[servocount] + SERVO_STEPS ;
}
- if (servo_pos[servocount] > settings[2]) //Servo MAX
+ if (servo_pos[servocount] > SERVO_MAX) //Servo MAX
{
- servo_pos[servocount] = settings[2];
+ servo_pos[servocount] = SERVO_MAX;
}
- else if (servo_pos[servocount] < settings[3]) //Servo MIN
+ else if (servo_pos[servocount] < SERVO_MIN) //Servo MIN
{
- servo_pos[servocount] = settings[3];
+ servo_pos[servocount] = SERVO_MIN;
}
if(buttonState == 1){
@@ -913,7 +979,7 @@ switch (Menu) {
}
if(buttonState == 2){
- servo_pos[servocount] = settings[4]; //Servo Mitte
+ servo_pos[servocount] = SERVO_Mitte; //Servo Mitte
}
if(buttonState == 3){
@@ -938,16 +1004,16 @@ switch (Menu) {
}
else
{
- display.drawProgressBar(8, 50, 112, 10, (((servo_pos[servocount]-settings[3])*100)/(settings[2]-settings[3])));
+ display.drawProgressBar(8, 50, 112, 10, (((servo_pos[servocount]-SERVO_MIN)*100)/(SERVO_MAX-SERVO_MIN)));
}
display.display();
if (!SetupMenu)
{
- servo[0].attach(servopin[0],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[1].attach(servopin[1],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[2].attach(servopin[2],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[3].attach(servopin[3],settings[3],settings[2]); // ServoPIN, MIN, MAX
- servo[4].attach(servopin[4],settings[3],settings[2]); // ServoPIN, MIN, MAX
+ servo[0].attach(servopin[0],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[1].attach(servopin[1],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[2].attach(servopin[2],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[3].attach(servopin[3],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
+ servo[4].attach(servopin[4],SERVO_MIN,SERVO_MAX); // ServoPIN, MIN, MAX
TimeAuto = 50; //Zeit für SERVO Steps +-
Auto_Pause = false; //Pause aus
SetupMenu = true;
@@ -958,29 +1024,29 @@ switch (Menu) {
if ((currentTimeAuto - previousTimeAuto) > TimeAuto){
previousTimeAuto = currentTimeAuto;
if (Autopos[servocount] > 1500){
- servo_pos[servocount] = servo_pos[servocount] + settings[1];
+ servo_pos[servocount] = servo_pos[servocount] + SERVO_STEPS;
}
else
{
- servo_pos[servocount] = servo_pos[servocount] - settings[1];
+ servo_pos[servocount] = servo_pos[servocount] - SERVO_STEPS;
}
}
}
- if (servo_pos[servocount] < settings[3]){
- Autopos[servocount] = settings[2];
- servo_pos[servocount] = settings[3];
+ if (servo_pos[servocount] < SERVO_MIN){
+ Autopos[servocount] = SERVO_MAX;
+ servo_pos[servocount] = SERVO_MIN;
}
- if (servo_pos[servocount] > settings[2]){
- Autopos[servocount] = settings[3];
- servo_pos[servocount] = settings[2];
+ if (servo_pos[servocount] > SERVO_MAX){
+ Autopos[servocount] = SERVO_MIN;
+ servo_pos[servocount] = SERVO_MAX;
}
servo[servocount].writeMicroseconds(servo_pos[servocount]);
if (encoderState == 1){
if (Auto_Pause){
- servo_pos[servocount] = servo_pos[servocount] - settings[1] ;
+ servo_pos[servocount] = servo_pos[servocount] - SERVO_STEPS ;
}
else
{
@@ -989,7 +1055,7 @@ switch (Menu) {
}
if (encoderState == 2){
if (Auto_Pause){
- servo_pos[servocount] = servo_pos[servocount] + settings[1] ;
+ servo_pos[servocount] = servo_pos[servocount] + SERVO_STEPS ;
}
else
{
@@ -1260,7 +1326,7 @@ switch (Menu) {
switch (Einstellung) {
case 0:
display.drawString(64, 25,"Wifi" );
- if (settings[Einstellung] == 1) {
+ if (WIFI_ON == 1) {
display.drawString(64, 45,"Ein" );
}
else {
@@ -1269,24 +1335,33 @@ switch (Menu) {
break;
case 1:
display.drawString(64, 25,"Servo Steps µs" );
- display.drawString(64, 45,String(settings[Einstellung]));
+ display.drawString(64, 45,String(SERVO_STEPS));
break;
case 2:
display.drawString(64, 25,"Servo MAX µs" );
- display.drawString(64, 45,String(settings[Einstellung]));
+ display.drawString(64, 45,String(SERVO_MAX));
break;
case 3:
display.drawString(64, 25,"Servo MIN µs" );
- display.drawString(64, 45,String(settings[Einstellung]));
+ display.drawString(64, 45,String(SERVO_MIN));
break;
case 4:
display.drawString(64, 25,"Servo Mitte µs" );
- display.drawString(64, 45,String(settings[Einstellung]));
+ display.drawString(64, 45,String(SERVO_Mitte));
break;
case 5:
display.drawString(64, 25,"Servo Hz" );
- display.drawString(64, 45,String(settings[Einstellung]));
- break;
+ display.drawString(64, 45,String(SERVO_Hz));
+ break;
+ case 6:
+ display.drawString(64, 25,"POWER Scale" );
+ display.drawString(64, 45,String(POWER_SCALE));
+ display.setFont(ArialMT_Plain_10);
+ display.setTextAlignment(TEXT_ALIGN_RIGHT);
+ display.drawString(110, 50, String(Power_V));
+ display.setTextAlignment(TEXT_ALIGN_LEFT);
+ display.drawString(110, 50, "V");
+ break;
}
if (Edit) {
display.drawString(10, 45,"->" );
@@ -1304,7 +1379,29 @@ switch (Menu) {
}
else
{
- settings[Einstellung]--;
+ switch (Einstellung) {
+ case 0:
+ WIFI_ON --;
+ break;
+ case 1:
+ SERVO_STEPS --;
+ break;
+ case 2:
+ SERVO_MAX --;
+ break;
+ case 3:
+ SERVO_MIN --;
+ break;
+ case 4:
+ SERVO_Mitte --;
+ break;
+ case 5:
+ SERVO_Hz --;
+ break;
+ case 6:
+ POWER_SCALE --;
+ break;
+ }
}
}
if (encoderState == 2){
@@ -1313,103 +1410,125 @@ switch (Menu) {
}
else
{
- settings[Einstellung]++;
+ switch (Einstellung) {
+ case 0:
+ WIFI_ON ++;
+ break;
+ case 1:
+ SERVO_STEPS ++;
+ break;
+ case 2:
+ SERVO_MAX ++;
+ break;
+ case 3:
+ SERVO_MIN ++;
+ break;
+ case 4:
+ SERVO_Mitte ++;
+ break;
+ case 5:
+ SERVO_Hz ++;
+ break;
+ case 6:
+ POWER_SCALE ++;
+ break;
+ }
}
}
- if (Einstellung > 5)
+ if (Einstellung > 6)
{
Einstellung = 0;
}
else if (Einstellung < 0)
{
- Einstellung = 5;
+ Einstellung = 6;
}
- if (settings[0] < 0) { //Wifi off nicht unter 0
- settings[0] = 0;
+ if (WIFI_ON < 0) { //Wifi off nicht unter 0
+ WIFI_ON = 0;
}
- if (settings[0] > 1) { //Wifi on nicht über 1
- settings[0] = 1;
+ if (WIFI_ON > 1) { //Wifi on nicht über 1
+ WIFI_ON = 1;
}
- if (settings[1] < 0) { //Steps nicht unter 0
- settings[1] = 0;
+ if (SERVO_STEPS < 0) { //Steps nicht unter 0
+ SERVO_STEPS = 0;
}
- if (settings[2] < settings[4]) { //Max nicht unter Mitte
- settings[2] = settings[4] + 1;
+ if (SERVO_MAX < SERVO_Mitte) { //Max nicht unter Mitte
+ SERVO_MAX = SERVO_Mitte + 1;
}
- if (settings[2] > 2500) { //Max nicht über 2500
- settings[2] = 2500;
+ if (SERVO_MAX > 2500) { //Max nicht über 2500
+ SERVO_MAX = 2500;
}
- if (settings[3] > settings[4]) { //Min nicht über Mitte
- settings[3] = settings[4] - 1;
+ if (SERVO_MIN > SERVO_Mitte) { //Min nicht über Mitte
+ SERVO_MIN = SERVO_Mitte - 1;
}
- if (settings[3] < 500) { //Min nicht unter 500
- settings[3] = 500;
+ if (SERVO_MIN < 500) { //Min nicht unter 500
+ SERVO_MIN = 500;
}
- if (settings[4] > settings[2]) { //Mitte nicht über Max
- settings[4] = settings[2] - 1;
+ if (SERVO_Mitte > SERVO_MAX) { //Mitte nicht über Max
+ SERVO_Mitte = SERVO_MAX - 1;
}
- if (settings[4] < settings[3]) { //Mitte nicht unter Min
- settings[4] = settings[3] + 1;
+ if (SERVO_Mitte < SERVO_MIN) { //Mitte nicht unter Min
+ SERVO_Mitte = SERVO_MIN + 1;
}
- if (settings[5] == 51) {
- settings[5] = 200;
+ if (SERVO_Hz == 51) {
+ SERVO_Hz = 200;
}
- if (settings[5] == 201) {
- settings[5] = 333;
+ if (SERVO_Hz == 201) {
+ SERVO_Hz = 333;
}
- if (settings[5] == 334) {
- settings[5] = 560;
- settings[2] = 1000;
- settings[3] = 500;
- settings[4] = 760;
+ if (SERVO_Hz == 334) {
+ SERVO_Hz = 560;
+ SERVO_MAX = 1000;
+ SERVO_MIN = 500;
+ SERVO_Mitte = 760;
}
- if (settings[5] == 561) {
- settings[5] = 50;
- settings[2] = 2000;
- settings[3] = 1000;
- settings[4] = 1500;
+ if (SERVO_Hz == 561) {
+ SERVO_Hz = 50;
+ SERVO_MAX = 2000;
+ SERVO_MIN = 1000;
+ SERVO_Mitte = 1500;
}
- if (settings[5] == 49) {
- settings[5] = 560;
- settings[2] = 1000;
- settings[3] = 500;
- settings[4] = 760;
+ if (SERVO_Hz == 49) {
+ SERVO_Hz = 560;
+ SERVO_MAX = 1000;
+ SERVO_MIN = 500;
+ SERVO_Mitte = 760;
}
- if (settings[5] == 559) {
- settings[5] = 333;
- settings[2] = 2000;
- settings[3] = 1000;
- settings[4] = 1500;
+ if (SERVO_Hz == 559) {
+ SERVO_Hz = 333;
+ SERVO_MAX = 2000;
+ SERVO_MIN = 1000;
+ SERVO_Mitte = 1500;
}
- if (settings[5] == 332) {
- settings[5] = 200;
+ if (SERVO_Hz == 332) {
+ SERVO_Hz = 200;
}
- if (settings[5] == 199) {
- settings[5] = 50;
+ if (SERVO_Hz == 199) {
+ SERVO_Hz = 50;
}
- if (settings[5] == 560) {
- settings[2] = 1000;
- settings[3] = 500;
- settings[4] = 760;
+ if (SERVO_Hz == 560) {
+ SERVO_MAX = 1000;
+ SERVO_MIN = 500;
+ SERVO_Mitte = 760;
}
@@ -1441,24 +1560,90 @@ switch (Menu) {
}
+// ======== Externe Spanunngsversorgung =======================================
+void Extern_Span() {
+
+ currentTimeSpan = millis();
+ if ((currentTimeSpan - previousTimeSpan) > 2000)
+ {
+ previousTimeSpan = currentTimeSpan;
+
+
+ // ADC & DAC calibration https://hackaday.io/project/27511-microfluidics-control-system/log/69406-adc-dac-calibration
+ int val = analogRead(Power_PIN);
+ double x = val;
+ double y = -3e-12*pow(x, 3) - 7e-10*pow(x, 2) + 0.0003*x + 0.0169;
+ int MeasuredValue = std::min(3300, std::max(0, int(round(y*UINT8_MAX))));
+
+ Serial.print("MeasuredValue: ");
+ Serial.println(MeasuredValue);
+
+ // Wert in Volt umrechnen
+ Power_V = MeasuredValue;
+ Power_V = Power_V/100;
+
+ float scale_value = POWER_SCALE;
+ scale_value = scale_value/100;
+
+ Power_V = Power_V * scale_value;
+
+ Serial.print("Spannung: ");
+ Serial.println(Power_V,8);
+
+ Power_EN = 1;
+
+ if (Power_V > 21) //6s Lipo
+ {
+ Power_Zel = 6;
+ }
+ else if (Power_V > 16.8) //5s Lipo
+ {
+ Power_Zel = 5;
+ }
+ else if (Power_V > 12.6) //4s Lipo
+ {
+ Power_Zel = 4;
+ }
+ else if (Power_V > 8.4) //3s Lipo
+ {
+ Power_Zel = 3;
+ }
+ else if (Power_V > 4.2) //2s Lipo
+ {
+ Power_Zel = 2;
+ }
+ else //1s Lipo kein Akku angeschlossen
+ {
+ Power_Zel = 1;
+ Power_EN = 0;
+ }
+
+ Power_V_per = (Power_V/Power_Zel); // Prozentanzeige
+ Power_V_per = map_float(Power_V_per, 3.5, 4.2, 0, 100);
+}
+}
+
+
// ======== EEprom =======================================
void EEprom_Load() {
- settings[0] = EEPROM.readInt(adr_eprom_WIFI_ON);
- settings[1] = EEPROM.readInt(adr_eprom_SERVO_STEPS);
- settings[2] = EEPROM.readInt(adr_eprom_SERVO_MAX);
- settings[3] = EEPROM.readInt(adr_eprom_SERVO_MIN);
- settings[4] = EEPROM.readInt(adr_eprom_SERVO_Mitte);
- settings[5] = EEPROM.readInt(adr_eprom_SERVO_Hz);
+ WIFI_ON = EEPROM.readInt(adr_eprom_WIFI_ON);
+ SERVO_STEPS = EEPROM.readInt(adr_eprom_SERVO_STEPS);
+ SERVO_MAX = EEPROM.readInt(adr_eprom_SERVO_MAX);
+ SERVO_MIN = EEPROM.readInt(adr_eprom_SERVO_MIN);
+ SERVO_Mitte = EEPROM.readInt(adr_eprom_SERVO_Mitte);
+ SERVO_Hz = EEPROM.readInt(adr_eprom_SERVO_Hz);
+ POWER_SCALE = EEPROM.readInt(adr_eprom_POWER_SCALE);
Serial.println("EEPROM gelesen.");
}
void EEprom_Save() {
- EEPROM.writeInt(adr_eprom_WIFI_ON, settings[0]);
- EEPROM.writeInt(adr_eprom_SERVO_STEPS, settings[1]);
- EEPROM.writeInt(adr_eprom_SERVO_MAX, settings[2]);
- EEPROM.writeInt(adr_eprom_SERVO_MIN, settings[3]);
- EEPROM.writeInt(adr_eprom_SERVO_Mitte, settings[4]);
- EEPROM.writeInt(adr_eprom_SERVO_Hz, settings[5]);
+ EEPROM.writeInt(adr_eprom_WIFI_ON, WIFI_ON);
+ EEPROM.writeInt(adr_eprom_SERVO_STEPS, SERVO_STEPS);
+ EEPROM.writeInt(adr_eprom_SERVO_MAX, SERVO_MAX);
+ EEPROM.writeInt(adr_eprom_SERVO_MIN, SERVO_MIN);
+ EEPROM.writeInt(adr_eprom_SERVO_Mitte, SERVO_Mitte);
+ EEPROM.writeInt(adr_eprom_SERVO_Hz, SERVO_Hz);
+ EEPROM.writeInt(adr_eprom_POWER_SCALE, POWER_SCALE);
EEPROM.commit();
Serial.println("EEPROM gespeichert.");
}