create faster version of the console text method

master
Cole Deck 6 years ago
parent 3552459ecd
commit 6340186e15

@ -121,6 +121,8 @@ boolean debug = true;
boolean ps3 = false; boolean ps3 = false;
boolean upd; boolean upd;
boolean s1, s2, s3, s4; boolean s1, s2, s3, s4;
String outtext2 = "";
int linecount = 0;
void setup(void) { void setup(void) {
Serial.begin(9600); Serial.begin(9600);
@ -143,49 +145,49 @@ void setup(void) {
//tft.fillRect(0, 0, 320, 23, ILI9341_BLACK); //tft.fillRect(0, 0, 320, 23, ILI9341_BLACK);
} }
printConsoleText("Booting GreenhouseOS...||"); printFastCText("Booting GreenhouseOS...||");
delay(250); delay(250);
if(!didDraw) { if(!didDraw) {
printConsoleText("[FAILED] SD Card not detected!"); printFastCText("[FAILED] SD Card not detected!");
} }
printConsoleText("[ OK ] Enabling powersaving features... "); // 53 characters wide printFastCText("[ OK ] Enabling powersaving features... "); // 53 characters wide example
enablePS(3); enablePS(3);
upd = true; upd = true;
if (!soil1.begin(0x36)) { if (!soil1.begin(0x36)) {
printConsoleText("[ INFO ] Soil sensor 1 unplugged."); printFastCText("[ INFO ] Soil sensor 1 unplugged.");
s1 = false; s1 = false;
} else { } else {
String out = "[ OK ] Soil sensor 1 connected. Version: "; String out = "[ OK ] Soil sensor 1 connected. Version: ";
out += (soil1.getVersion(), HEX); out += (soil1.getVersion(), HEX);
printConsoleText(out); printFastCText(out);
s1 = true; s1 = true;
} }
if (!soil2.begin(0x37)) { if (!soil2.begin(0x37)) {
printConsoleText("[ INFO ] Soil sensor 2 unplugged."); printFastCText("[ INFO ] Soil sensor 2 unplugged.");
s2 = false; s2 = false;
} else { } else {
String out = "[ OK ] Soil sensor 2 connected. Version: "; String out = "[ OK ] Soil sensor 2 connected. Version: ";
out += (soil2.getVersion(), HEX); out += (soil2.getVersion(), HEX);
printConsoleText(out); printFastCText(out);
s2 = true; s2 = true;
} }
if (!soil3.begin(0x38)) { if (!soil3.begin(0x38)) {
printConsoleText("[ INFO ] Soil sensor 3 unplugged."); printFastCText("[ INFO ] Soil sensor 3 unplugged.");
s3 = false; s3 = false;
} else { } else {
String out = "[ OK ] Soil sensor 3 connected. Version: "; String out = "[ OK ] Soil sensor 3 connected. Version: ";
out += (soil3.getVersion(), HEX); out += (soil3.getVersion(), HEX);
printConsoleText(out); printFastCText(out);
s3 = true; s3 = true;
} }
if (!soil4.begin(0x39)) { if (!soil4.begin(0x39)) {
printConsoleText("[ INFO ] Soil sensor 4 unplugged."); printFastCText("[ INFO ] Soil sensor 4 unplugged.");
s4 = false; s4 = false;
} else { } else {
String out = "[ OK ] Soil sensor 4 connected. Version: "; String out = "[ OK ] Soil sensor 4 connected. Version: ";
out += (soil4.getVersion(), HEX); out += (soil4.getVersion(), HEX);
printConsoleText(out); printFastCText(out);
s4 = true; s4 = true;
} }
getMoisture(); getMoisture();
@ -197,7 +199,13 @@ void loop(void) {
} }
if(Serial.available() > 0) { if(Serial.available() > 0) {
String txtin = "Serial: " + Serial.readString(); String txtin = "Serial: " + Serial.readString();
printConsoleText(txtin.substring(0, txtin.length() - 1)); int x = 0;
while(txtin.length() > 53) {
printFastCText(txtin.substring(0, 53);
txtin = txtin.substring(53);
}
printFastCText(txtin.substring(0, txtin.length() - 1));
} }
unsigned long mil = millis(); unsigned long mil = millis();
/*String tmp = "["; /*String tmp = "[";
@ -411,7 +419,7 @@ void getMoisture() {
int sm1 = map(soil1.touchRead(0), 0, 1023, 0, 100); int sm1 = map(soil1.touchRead(0), 0, 1023, 0, 100);
if(sm1 > 6000 && t1 < 1) { if(sm1 > 6000 && t1 < 1) {
s1 = false; s1 = false;
printConsoleText("[ INFO ] Soil sensor 1 unplugged."); printFastCText("[ INFO ] Soil sensor 1 unplugged.");
} else { } else {
printS1(t1, sm1); printS1(t1, sm1);
} }
@ -419,7 +427,7 @@ void getMoisture() {
if (soil1.begin(0x36)) { if (soil1.begin(0x36)) {
clearLog(); clearLog();
s1 = true; s1 = true;
printConsoleText("[ INFO ] Soil sensor 1 connected."); printFastCText("[ INFO ] Soil sensor 1 connected.");
float t1 = soil1.getTemp(); float t1 = soil1.getTemp();
int sm1 = map(soil1.touchRead(0), 0, 1023, 0, 100); int sm1 = map(soil1.touchRead(0), 0, 1023, 0, 100);
printS1(t1, sm1); printS1(t1, sm1);
@ -431,7 +439,7 @@ void getMoisture() {
int sm2 = map(soil2.touchRead(0), 0, 1023, 0, 100); int sm2 = map(soil2.touchRead(0), 0, 1023, 0, 100);
if(sm2 > 6000 && t2 < 1) { if(sm2 > 6000 && t2 < 1) {
s2 = false; s2 = false;
printConsoleText("[ INFO ] Soil sensor 2 unplugged."); printFastCText("[ INFO ] Soil sensor 2 unplugged.");
} else { } else {
printS2(t2, sm2); printS2(t2, sm2);
} }
@ -439,7 +447,7 @@ void getMoisture() {
if (soil2.begin(0x37)) { if (soil2.begin(0x37)) {
clearLog(); clearLog();
s2 = true; s2 = true;
printConsoleText("[ INFO ] Soil sensor 2 connected."); printFastCText("[ INFO ] Soil sensor 2 connected.");
float t2 = soil2.getTemp(); float t2 = soil2.getTemp();
int sm2 = map(soil2.touchRead(0), 0, 1023, 0, 100); int sm2 = map(soil2.touchRead(0), 0, 1023, 0, 100);
printS2(t2, sm2); printS2(t2, sm2);
@ -451,7 +459,7 @@ void getMoisture() {
int sm3 = map(soil3.touchRead(0), 0, 1023, 0, 100); int sm3 = map(soil3.touchRead(0), 0, 1023, 0, 100);
if(sm3 > 6000 && t3 < 1) { if(sm3 > 6000 && t3 < 1) {
s3 = false; s3 = false;
printConsoleText("[ INFO ] Soil sensor 3 unplugged."); printFastCText("[ INFO ] Soil sensor 3 unplugged.");
} else { } else {
printS3(t3, sm3); printS3(t3, sm3);
} }
@ -459,7 +467,7 @@ void getMoisture() {
if (soil3.begin(0x38)) { if (soil3.begin(0x38)) {
clearLog(); clearLog();
s3 = true; s3 = true;
printConsoleText("[ INFO ] Soil sensor 3 connected."); printFastCText("[ INFO ] Soil sensor 3 connected.");
float t3 = soil3.getTemp(); float t3 = soil3.getTemp();
int sm3 = map(soil3.touchRead(0), 0, 1023, 0, 100); int sm3 = map(soil3.touchRead(0), 0, 1023, 0, 100);
printS3(t3, sm3); printS3(t3, sm3);
@ -471,7 +479,7 @@ void getMoisture() {
int sm4 = map(soil4.touchRead(0), 0, 1023, 0, 100); int sm4 = map(soil4.touchRead(0), 0, 1023, 0, 100);
if(sm4 > 6000 && t4 < 1) { if(sm4 > 6000 && t4 < 1) {
s4 = false; s4 = false;
printConsoleText("[ INFO ] Soil sensor 4 unplugged."); printFastCText("[ INFO ] Soil sensor 4 unplugged.");
} else { } else {
printS4(t4, sm4); printS4(t4, sm4);
} }
@ -479,7 +487,7 @@ void getMoisture() {
if (soil4.begin(0x39)) { if (soil4.begin(0x39)) {
clearLog(); clearLog();
s4 = true; s4 = true;
printConsoleText("[ INFO ] Soil sensor 4 connected."); printFastCText("[ INFO ] Soil sensor 4 connected.");
float t4 = soil4.getTemp(); float t4 = soil4.getTemp();
int sm4 = map(soil4.touchRead(0), 0, 1023, 0, 100); int sm4 = map(soil4.touchRead(0), 0, 1023, 0, 100);
printS4(t4, sm4); printS4(t4, sm4);
@ -492,11 +500,13 @@ void printS1(float t, int sm) {
out += t; out += t;
out += " C, "; out += " C, ";
out += (t * 9.0 / 5.0 + 32); out += (t * 9.0 / 5.0 + 32);
out += " F|"; out += " F";
printFastCText(out);
out = "";
out += "[ OK ] Soil sensor 1 moisture: "; out += "[ OK ] Soil sensor 1 moisture: ";
out += sm; out += sm;
out += "%"; out += "%";
printConsoleText(out); printFastCText(out);
} }
void printS2(float t, int sm) { void printS2(float t, int sm) {
@ -504,11 +514,13 @@ void printS2(float t, int sm) {
out += t; out += t;
out += " C, "; out += " C, ";
out += (t * 9.0 / 5.0 + 32); out += (t * 9.0 / 5.0 + 32);
out += " F|"; out += " F";
printFastCText(out);
out = "";
out += "[ OK ] Soil sensor 2 moisture: "; out += "[ OK ] Soil sensor 2 moisture: ";
out += sm; out += sm;
out += "%"; out += "%";
printConsoleText(out); printFastCText(out);
} }
void printS3(float t, int sm) { void printS3(float t, int sm) {
@ -516,11 +528,13 @@ void printS3(float t, int sm) {
out += t; out += t;
out += " C, "; out += " C, ";
out += (t * 9.0 / 5.0 + 32); out += (t * 9.0 / 5.0 + 32);
out += " F|"; out += " F";
printFastCText(out);
out = "";
out += "[ OK ] Soil sensor 3 moisture: "; out += "[ OK ] Soil sensor 3 moisture: ";
out += sm; out += sm;
out += "%"; out += "%";
printConsoleText(out); printFastCText(out);
} }
void printS4(float t, int sm) { void printS4(float t, int sm) {
@ -528,11 +542,13 @@ void printS4(float t, int sm) {
out += t; out += t;
out += " C, "; out += " C, ";
out += (t * 9.0 / 5.0 + 32); out += (t * 9.0 / 5.0 + 32);
out += " F|"; out += " F";
printFastCText(out);
out = "";
out += "[ OK ] Soil sensor 4 moisture: "; out += "[ OK ] Soil sensor 4 moisture: ";
out += sm; out += sm;
out += "%"; out += "%";
printConsoleText(out); printFastCText(out);
} }
@ -546,9 +562,9 @@ void enablePS(int level) {
pinMode(x, OUTPUT); pinMode(x, OUTPUT);
digitalWrite(x, LOW); digitalWrite(x, LOW);
} }
printConsoleText("[ OK ] Enabled Level 1 powersaving."); printFastCText("[ OK ] Enabled Level 1 powersaving.");
} else { } else {
printConsoleText("[FAILED] Powersaving: Argument must be > 0."); printFastCText("[FAILED] Powersaving: Argument must be > 0.");
} }
if(level > 1) { if(level > 1) {
Serial.end(); Serial.end();
@ -563,7 +579,7 @@ void enablePS(int level) {
power_timer4_disable(); power_timer4_disable();
power_timer5_disable(); power_timer5_disable();
//power_twi_disable(); // twi needed for soil sensors / i2c //power_twi_disable(); // twi needed for soil sensors / i2c
printConsoleText("[ OK ] Enabled Level 2 powersaving."); printFastCText("[ OK ] Enabled Level 2 powersaving.");
} }
if(level > 2) { if(level > 2) {
// disable ADC // disable ADC
@ -571,12 +587,15 @@ void enablePS(int level) {
//power_all_disable(); //power_all_disable();
ps3 = true; ps3 = true;
printConsoleText("[ OK ] Enabled Level 3 powersaving.|[ INFO ] All powersaving features enabled."); printFastCText("[ OK ] Enabled Level 3 powersaving.");
printFastCText("[ INFO ] All powersaving features enabled.");
} }
} }
void clearLog() { void clearLog() {
outtext = ""; outtext = "";
outtext2 = "";
linecount = 0;
} }
void printConsoleText(String text) { void printConsoleText(String text) {
@ -652,3 +671,32 @@ String getString(String s, int index) {
} }
return ""; return "";
} }
void printFastCText(String text) { // NOTE: text MUST be under 53 characters long! (this is how the code runs faster)
linecount ++;
if (linecount > 30) {
outtext2 = outtext2.substring(30);
}
if (text.length() < 53) {
outtext2 += text;
for (int x = text.length(); x < 53; x++) {
outtext2 += " ";
}
} else {
outtext2 += text;
}
if (debug) {
//tft.setCursor(0, 0);
//tft.fillScreen(BLACK);
int lc2 = linecount;
tft.setCursor(0, lc2 * 8);
tft.setTextColor(ILI9341_WHITE);
tft.setTextSize(1);
for (int x = count - 1; x >= 0; x--) {
String tmp = outtext2.substring(x * 53, x*53 + 53);
tft.setCursor(0, tft.getCursorY() - 8);
tft.fillRect(0, tft.getCursorY(), 320, 8, BLACK);
tft.print(tmp);
}
}
}
Loading…
Cancel
Save