data:image/s3,"s3://crabby-images/095ca/095ca476c78f825b4dd440b833e802751d3a0781" alt="Weight"
data:image/s3,"s3://crabby-images/208e9/208e930755f1c9c7e3ef1443e496717f615ee3e3" alt="CG"
data:image/s3,"s3://crabby-images/ec4aa/ec4aac7ce31c78eec6dff9c33cc30d128c536b88" alt="CG left/right"
data:image/s3,"s3://crabby-images/32b0b/32b0b719a96137af071caa15e75dd95082b2f5b6" alt="Battery"
diff --git a/CG_scale.ino b/CG_scale.ino index 2c5822b..b366014 100644 --- a/CG_scale.ino +++ b/CG_scale.ino @@ -4,7 +4,7 @@ (c) 2019 by M. Lehmann ------------------------------------------------------------------ */ -#define CGSCALE_VERSION "1.0.62" +#define CGSCALE_VERSION "1.0.63" /* ****************************************************************** @@ -204,7 +204,11 @@ char curModelName[MAX_MODELNAME_LENGHT + 1] = ""; // Restart CPU +#if defined(__AVR__) void(* resetCPU) (void) = 0; +#elif defined(ESP8266) +void resetCPU(){} +#endif // save calibration factor @@ -375,61 +379,85 @@ void setup() { oledDisplay.print(F("(c) 2019 M. Lehmann")); } while ( oledDisplay.nextPage() ); - // init Loadcells + // init & tare Loadcells LoadCell_1.begin(); + LoadCell_1.start(STABILISINGTIME); LoadCell_2.begin(); + LoadCell_2.start(STABILISINGTIME); + + if (LoadCell_1.getTareTimeoutFlag()) { + errMsg[++errMsgCnt] = "ERROR: Timeout TARE Lc1\n"; + } + else { + LoadCell_1.setCalFactor(calFactorLoadcell1); + } + + if (LoadCell_2.getTareTimeoutFlag()) { + errMsg[++errMsgCnt] = "ERROR: Timeout TARE Lc2\n"; + } + else { + LoadCell_2.setCalFactor(calFactorLoadcell2); + } + if (nLoadcells > 2) { LoadCell_3.begin(); - } + LoadCell_3.start(STABILISINGTIME); - // tare - byte loadcell_1_rdy = 0; - byte loadcell_2_rdy = 0; - byte loadcell_3_rdy = 0; - lastTimeLoadcell = millis(); - - while ((loadcell_1_rdy + loadcell_2_rdy + loadcell_3_rdy) < 3) { - loadcell_1_rdy = LoadCell_1.startMultiple(STABILISINGTIME); - loadcell_2_rdy = LoadCell_2.startMultiple(STABILISINGTIME); - if (nLoadcells == 3) { - loadcell_3_rdy = LoadCell_3.startMultiple(STABILISINGTIME); - } else { - loadcell_3_rdy = 1; + if (LoadCell_3.getTareTimeoutFlag()) { + errMsg[++errMsgCnt] = "ERROR: Timeout TARE Lc3\n"; } - // timeout - if ((millis() - lastTimeLoadcell) > TARE_TIMEOUT) { - errMsg[++errMsgCnt] = "ERROR: Timeout TARE\n"; - break; + else { + LoadCell_3.setCalFactor(calFactorLoadcell3); } } - // check loadcells if error - if (!loadcell_1_rdy) { - errMsg[++errMsgCnt] = "ERROR: Loadcell 1 not ready\n"; - } - if (!loadcell_2_rdy) { - errMsg[++errMsgCnt] = "ERROR: Loadcell 2 not ready\n"; - } - if (!loadcell_3_rdy) { - errMsg[++errMsgCnt] = "ERROR: Loadcell 3 not ready\n"; - } - - // set calibration factor - LoadCell_1.setCalFactor(calFactorLoadcell1); - LoadCell_2.setCalFactor(calFactorLoadcell2); - if (nLoadcells > 2) { - LoadCell_3.setCalFactor(calFactorLoadcell3); - } - - // stabilize scale values - for (int i = 0; i <= 5; i++) { - LoadCell_1.update(); - LoadCell_2.update(); + /* + // init Loadcells + LoadCell_1.begin(); + LoadCell_2.begin(); if (nLoadcells > 2) { - LoadCell_3.update(); + LoadCell_3.begin(); } - delay(200); - } + + // tare + byte loadcell_1_rdy = 0; + byte loadcell_2_rdy = 0; + byte loadcell_3_rdy = 0; + lastTimeLoadcell = millis(); + + while ((loadcell_1_rdy + loadcell_2_rdy + loadcell_3_rdy) < 3) { + loadcell_1_rdy = LoadCell_1.startMultiple(STABILISINGTIME); + loadcell_2_rdy = LoadCell_2.startMultiple(STABILISINGTIME); + if (nLoadcells == 3) { + loadcell_3_rdy = LoadCell_3.startMultiple(STABILISINGTIME); + } else { + loadcell_3_rdy = 1; + } + // timeout + if ((millis() - lastTimeLoadcell) > TARE_TIMEOUT) { + errMsg[++errMsgCnt] = "ERROR: Timeout TARE\n"; + break; + } + } + + // check loadcells if error + if (!loadcell_1_rdy) { + errMsg[++errMsgCnt] = "ERROR: Loadcell 1 not ready\n"; + } + if (!loadcell_2_rdy) { + errMsg[++errMsgCnt] = "ERROR: Loadcell 2 not ready\n"; + } + if (!loadcell_3_rdy) { + errMsg[++errMsgCnt] = "ERROR: Loadcell 3 not ready\n"; + } + + // set calibration factor + LoadCell_1.setCalFactor(calFactorLoadcell1); + LoadCell_2.setCalFactor(calFactorLoadcell2); + if (nLoadcells > 2) { + LoadCell_3.setCalFactor(calFactorLoadcell3); + } + */ #if defined(ESP8266) while (WiFi.status() != WL_CONNECTED) { @@ -459,7 +487,7 @@ void setup() { oledDisplay.setCursor(0, 64); oledDisplay.print(WiFi.localIP()); } while ( oledDisplay.nextPage() ); - delay(5000); + //delay(5000); } else { // if WiFi not connected, switch to access point mode WiFi.mode(WIFI_AP); @@ -493,6 +521,17 @@ void setup() { server.send(404, "text/plain", "404: Not Found"); }); #endif + + // stabilize scale values + for (int i = 0; i <= 15; i++) { + LoadCell_1.update(); + LoadCell_2.update(); + if (nLoadcells > 2) { + LoadCell_3.update(); + } + delay(200); + } + } @@ -528,6 +567,7 @@ void loop() { // update display and serial menu if ((millis() - lastTimeMenu) > UPDATE_INTERVAL_OLED_MENU) { + lastTimeMenu = millis(); // total model weight diff --git a/data/CG_scale_mechanics.png.gz b/data/CG_scale_mechanics.png.gz index 4e4e5e2..d9e3a56 100644 Binary files a/data/CG_scale_mechanics.png.gz and b/data/CG_scale_mechanics.png.gz differ diff --git a/data/bootstrap.css.map.gz b/data/bootstrap.css.map.gz deleted file mode 100755 index 1ffe194..0000000 Binary files a/data/bootstrap.css.map.gz and /dev/null differ diff --git a/data/bootstrap.min.css.map.gz b/data/bootstrap.min.css.map.gz deleted file mode 100644 index c894b70..0000000 Binary files a/data/bootstrap.min.css.map.gz and /dev/null differ diff --git a/data/bootstrap.min.js.map.gz b/data/bootstrap.min.js.map.gz deleted file mode 100755 index 7ec8159..0000000 Binary files a/data/bootstrap.min.js.map.gz and /dev/null differ diff --git a/data/index.html b/data/index.html deleted file mode 100755 index 304f62b..0000000 --- a/data/index.html +++ /dev/null @@ -1,180 +0,0 @@ - - -
- - - - -Name | -Weight [g] | -CG [mm] | -CG left-right [mm] | -- |
---|