mirror of https://github.com/arendst/Tasmota.git
Add Sensor34 commands
Add commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion (#15292)
This commit is contained in:
parent
d63077ab93
commit
ccdd8c9861
|
@ -3,7 +3,11 @@ All notable changes to this project will be documented in this file.
|
||||||
|
|
||||||
## [Unreleased] - Development
|
## [Unreleased] - Development
|
||||||
|
|
||||||
## [11.0.0.5]
|
## [11.0.0.6]
|
||||||
|
### Added
|
||||||
|
- Commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion (#15292)
|
||||||
|
|
||||||
|
## [11.0.0.5] 20220407
|
||||||
### Added
|
### Added
|
||||||
- Support for improv as used by esp-web-tools
|
- Support for improv as used by esp-web-tools
|
||||||
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb
|
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb
|
||||||
|
|
|
@ -103,7 +103,7 @@ The latter links can be used for OTA upgrades too like ``OtaUrl http://ota.tasmo
|
||||||
|
|
||||||
[Complete list](BUILDS.md) of available feature and sensors.
|
[Complete list](BUILDS.md) of available feature and sensors.
|
||||||
|
|
||||||
## Changelog v11.0.0.5
|
## Changelog v11.0.0.6
|
||||||
### Added
|
### Added
|
||||||
- Command ``SetOption135 1`` to disable LVGL splash screen
|
- Command ``SetOption135 1`` to disable LVGL splash screen
|
||||||
- Command ``SetOption136 1`` to disable single sensor reports from Tuya devices while keeping teleperiod reports [#15216](https://github.com/arendst/Tasmota/issues/15216)
|
- Command ``SetOption136 1`` to disable single sensor reports from Tuya devices while keeping teleperiod reports [#15216](https://github.com/arendst/Tasmota/issues/15216)
|
||||||
|
@ -112,6 +112,7 @@ The latter links can be used for OTA upgrades too like ``OtaUrl http://ota.tasmo
|
||||||
- Command ``RfTimeout 100..60000`` to disable duplicate RfReceive. Default 1000 [#15061](https://github.com/arendst/Tasmota/issues/15061)
|
- Command ``RfTimeout 100..60000`` to disable duplicate RfReceive. Default 1000 [#15061](https://github.com/arendst/Tasmota/issues/15061)
|
||||||
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb
|
- Command ``IfxSensor 1`` to send non-teleperiod data to influxdb
|
||||||
- Commands ``Sensor12 D0 .. D5, S0 .. S5`` allowing differential or single-ended modes [#15001](https://github.com/arendst/Tasmota/issues/15001)
|
- Commands ``Sensor12 D0 .. D5, S0 .. S5`` allowing differential or single-ended modes [#15001](https://github.com/arendst/Tasmota/issues/15001)
|
||||||
|
- Commands ``Sensor34 10 <valueA>`` and ``Sensor34 11 <valueB>`` to use HX711 absolute weight conversion [#15292](https://github.com/arendst/Tasmota/issues/15292)
|
||||||
- NeoPool commands ``NPpHMin``, ``NPpHMax``, ``NPpH``, ``NPRedox``, ``NPHydrolysis``, ``NPIonization``, ``NPChlorine`` and ``NPControl`` [#15015](https://github.com/arendst/Tasmota/issues/15015)
|
- NeoPool commands ``NPpHMin``, ``NPpHMax``, ``NPpH``, ``NPRedox``, ``NPHydrolysis``, ``NPIonization``, ``NPChlorine`` and ``NPControl`` [#15015](https://github.com/arendst/Tasmota/issues/15015)
|
||||||
- NeoPool system voltages display
|
- NeoPool system voltages display
|
||||||
- TasmotaSerial implement ``end()``
|
- TasmotaSerial implement ``end()``
|
||||||
|
|
|
@ -627,7 +627,7 @@ void SettingsSave(uint8_t rotate) {
|
||||||
Settings->cfg_size = sizeof(TSettings);
|
Settings->cfg_size = sizeof(TSettings);
|
||||||
Settings->cfg_crc = GetSettingsCrc(); // Keep for backward compatibility in case of fall-back just after upgrade
|
Settings->cfg_crc = GetSettingsCrc(); // Keep for backward compatibility in case of fall-back just after upgrade
|
||||||
Settings->cfg_crc32 = GetSettingsCrc32();
|
Settings->cfg_crc32 = GetSettingsCrc32();
|
||||||
#ifdef USE_COUNTER
|
#ifdef USE_COUNTER
|
||||||
CounterInterruptDisable(true);
|
CounterInterruptDisable(true);
|
||||||
#endif
|
#endif
|
||||||
#ifdef ESP8266
|
#ifdef ESP8266
|
||||||
|
@ -655,7 +655,7 @@ void SettingsSave(uint8_t rotate) {
|
||||||
}
|
}
|
||||||
#endif // FIRMWARE_MINIMAL
|
#endif // FIRMWARE_MINIMAL
|
||||||
RtcSettingsSave();
|
RtcSettingsSave();
|
||||||
#ifdef USE_COUNTER
|
#ifdef USE_COUNTER
|
||||||
CounterInterruptDisable(false);
|
CounterInterruptDisable(false);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -1489,11 +1489,11 @@ void SettingsDelta(void) {
|
||||||
Settings->flag5.disable_referer_chk |= true;
|
Settings->flag5.disable_referer_chk |= true;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
if (Settings->version < 0x09050009) {
|
if (Settings->version < 0x09050009) { // 9.5.0.9
|
||||||
memset(&Settings->energy_kWhtoday_ph, 0, 36);
|
memset(&Settings->energy_kWhtoday_ph, 0, 36);
|
||||||
memset(&RtcSettings.energy_kWhtoday_ph, 0, 24);
|
memset(&RtcSettings.energy_kWhtoday_ph, 0, 24);
|
||||||
}
|
}
|
||||||
if (Settings->version < 0x0A000003) {
|
if (Settings->version < 0x0A000003) { // 10.0.0.3
|
||||||
if (0 == Settings->param[P_ARP_GRATUITOUS]) {
|
if (0 == Settings->param[P_ARP_GRATUITOUS]) {
|
||||||
Settings->param[P_ARP_GRATUITOUS] = WIFI_ARP_INTERVAL;
|
Settings->param[P_ARP_GRATUITOUS] = WIFI_ARP_INTERVAL;
|
||||||
#ifdef USE_TLS
|
#ifdef USE_TLS
|
||||||
|
@ -1506,16 +1506,20 @@ void SettingsDelta(void) {
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Settings->version < 0x0A010003) {
|
if (Settings->version < 0x0A010003) { // 10.1.0.3
|
||||||
Settings->sserial_config = Settings->serial_config;
|
Settings->sserial_config = Settings->serial_config;
|
||||||
}
|
}
|
||||||
if (Settings->version < 0x0A010006) {
|
if (Settings->version < 0x0A010006) { // 10.1.0.6
|
||||||
Settings->web_time_start = 0;
|
Settings->web_time_start = 0;
|
||||||
Settings->web_time_end = 0;
|
Settings->web_time_end = 0;
|
||||||
}
|
}
|
||||||
if (Settings->version < 0x0B000003) { // 11.0.0.3
|
if (Settings->version < 0x0B000003) { // 11.0.0.3
|
||||||
memcpy(Settings->pulse_timer, Settings->ex_pulse_timer, 16);
|
memcpy(Settings->pulse_timer, Settings->ex_pulse_timer, 16);
|
||||||
}
|
}
|
||||||
|
if (Settings->version < 0x0B000006) { // 11.0.0.6
|
||||||
|
Settings->weight_absconv_a = 0;
|
||||||
|
Settings->weight_absconv_b = 0;
|
||||||
|
}
|
||||||
|
|
||||||
Settings->version = VERSION;
|
Settings->version = VERSION;
|
||||||
SettingsSave(1);
|
SettingsSave(1);
|
||||||
|
|
|
@ -20,6 +20,6 @@
|
||||||
#ifndef _TASMOTA_VERSION_H_
|
#ifndef _TASMOTA_VERSION_H_
|
||||||
#define _TASMOTA_VERSION_H_
|
#define _TASMOTA_VERSION_H_
|
||||||
|
|
||||||
const uint32_t VERSION = 0x0B000005; // 11.0.0.5
|
const uint32_t VERSION = 0x0B000006; // 11.0.0.6
|
||||||
|
|
||||||
#endif // _TASMOTA_VERSION_H_
|
#endif // _TASMOTA_VERSION_H_
|
||||||
|
|
|
@ -52,13 +52,15 @@
|
||||||
#define HX_GAIN_32 2 // Channel B, gain factor 32
|
#define HX_GAIN_32 2 // Channel B, gain factor 32
|
||||||
#define HX_GAIN_64 3 // Channel A, gain factor 64
|
#define HX_GAIN_64 3 // Channel A, gain factor 64
|
||||||
|
|
||||||
#define D_JSON_WEIGHT_REF "WeightRef"
|
|
||||||
#define D_JSON_WEIGHT_CAL "WeightCal"
|
|
||||||
#define D_JSON_WEIGHT_MAX "WeightMax"
|
|
||||||
#define D_JSON_WEIGHT_ITEM "WeightItem"
|
|
||||||
#define D_JSON_WEIGHT_CHANGE "WeightChange"
|
|
||||||
#define D_JSON_WEIGHT_RAW "WeightRaw"
|
#define D_JSON_WEIGHT_RAW "WeightRaw"
|
||||||
#define D_JSON_WEIGHT_DELTA "WeightDelta"
|
#define D_JSON_WEIGHT_REF "Ref"
|
||||||
|
#define D_JSON_WEIGHT_CAL "Cal"
|
||||||
|
#define D_JSON_WEIGHT_MAX "Max"
|
||||||
|
#define D_JSON_WEIGHT_ITEM "Item"
|
||||||
|
#define D_JSON_WEIGHT_CHANGE "Change"
|
||||||
|
#define D_JSON_WEIGHT_DELTA "Delta"
|
||||||
|
#define D_JSON_WEIGHT_ABSC_A "AbsConvA"
|
||||||
|
#define D_JSON_WEIGHT_ABSC_B "AbsConvB"
|
||||||
|
|
||||||
enum HxCalibrationSteps { HX_CAL_END, HX_CAL_LIMBO, HX_CAL_FINISH, HX_CAL_FAIL, HX_CAL_DONE, HX_CAL_FIRST, HX_CAL_RESET, HX_CAL_START };
|
enum HxCalibrationSteps { HX_CAL_END, HX_CAL_LIMBO, HX_CAL_FINISH, HX_CAL_FAIL, HX_CAL_DONE, HX_CAL_FIRST, HX_CAL_RESET, HX_CAL_START };
|
||||||
|
|
||||||
|
@ -187,85 +189,83 @@ void SetWeightDelta(void) {
|
||||||
* Sensor34 8 0 - Disable JSON weight change message
|
* Sensor34 8 0 - Disable JSON weight change message
|
||||||
* Sensor34 8 1 - Enable JSON weight change message
|
* Sensor34 8 1 - Enable JSON weight change message
|
||||||
* Sensor34 9 <weight code> - Set minimum delta to trigger JSON message
|
* Sensor34 9 <weight code> - Set minimum delta to trigger JSON message
|
||||||
|
* Sensor34 10 <value A> - Set A = a * 10^9 for raw to absolute weight conversion: y=a*x+b
|
||||||
|
* Sensor34 11 <value B> - Set B = b * 10^6 for raw to absolute weight conversion: y=a*x+b
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
|
||||||
bool HxCommand(void) {
|
bool HxCommand(void) {
|
||||||
bool serviced = true;
|
bool serviced = true;
|
||||||
bool show_parms = false;
|
bool show_parms = true;
|
||||||
char argument[XdrvMailbox.data_len];
|
char argument[XdrvMailbox.data_len];
|
||||||
|
|
||||||
|
long value = 0;
|
||||||
for (uint32_t ca = 0; ca < XdrvMailbox.data_len; ca++) {
|
for (uint32_t ca = 0; ca < XdrvMailbox.data_len; ca++) {
|
||||||
if ((' ' == XdrvMailbox.data[ca]) || ('=' == XdrvMailbox.data[ca])) { XdrvMailbox.data[ca] = ','; }
|
if ((' ' == XdrvMailbox.data[ca]) || ('=' == XdrvMailbox.data[ca])) { XdrvMailbox.data[ca] = ','; }
|
||||||
}
|
}
|
||||||
|
bool any_value = (strchr(XdrvMailbox.data, ',') != nullptr);
|
||||||
|
if (any_value) { value = strtol(ArgV(argument, 2), nullptr, 10); }
|
||||||
|
|
||||||
switch (XdrvMailbox.payload) {
|
switch (XdrvMailbox.payload) {
|
||||||
case 1: // Reset scale
|
case 1: // Reset scale
|
||||||
HxReset();
|
HxReset();
|
||||||
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, "Reset");
|
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, "Reset");
|
||||||
|
show_parms = false;
|
||||||
break;
|
break;
|
||||||
case 2: // Calibrate
|
case 2: // Calibrate
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) { Settings->weight_reference = value; }
|
||||||
Settings->weight_reference = strtol(ArgV(argument, 2), nullptr, 10);
|
|
||||||
}
|
|
||||||
Hx.scale = 1;
|
Hx.scale = 1;
|
||||||
HxReset();
|
HxReset();
|
||||||
Hx.calibrate_step = HX_CAL_START;
|
Hx.calibrate_step = HX_CAL_START;
|
||||||
Hx.calibrate_timer = 1;
|
Hx.calibrate_timer = 1;
|
||||||
HxCalibrationStateTextJson(3);
|
HxCalibrationStateTextJson(3);
|
||||||
|
show_parms = false;
|
||||||
break;
|
break;
|
||||||
case 3: // WeightRef to user reference
|
case 3: // WeightRef to user reference
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) { Settings->weight_reference = value; }
|
||||||
Settings->weight_reference = strtol(ArgV(argument, 2), nullptr, 10);
|
|
||||||
}
|
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
case 4: // WeightCal to user calculated value
|
case 4: // WeightCal to user calculated value
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) {
|
||||||
Settings->weight_calibration = strtol(ArgV(argument, 2), nullptr, 10);
|
Settings->weight_calibration = value;
|
||||||
Hx.scale = Settings->weight_calibration;
|
Hx.scale = Settings->weight_calibration;
|
||||||
}
|
}
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
case 5: // WeightMax
|
case 5: // WeightMax
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) { Settings->weight_max = value; }
|
||||||
Settings->weight_max = strtol(ArgV(argument, 2), nullptr, 10) / 1000;
|
|
||||||
}
|
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
case 6: // WeightItem
|
case 6: // WeightItem
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
||||||
Settings->weight_item = (unsigned long)(CharToFloat(ArgV(argument, 2)) * 10);
|
Settings->weight_item = (unsigned long)(CharToFloat(ArgV(argument, 2)) * 10);
|
||||||
}
|
}
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
case 7: // WeightSave
|
case 7: // WeightSave
|
||||||
Settings->energy_frequency_calibration = Hx.weight;
|
Settings->energy_frequency_calibration = Hx.weight;
|
||||||
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, PSTR(D_JSON_DONE));
|
Response_P(S_JSON_SENSOR_INDEX_SVALUE, XSNS_34, PSTR(D_JSON_DONE));
|
||||||
|
show_parms = false;
|
||||||
break;
|
break;
|
||||||
case 8: // Json on weight change
|
case 8: // Json on weight change
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) { Settings->SensorBits1.hx711_json_weight_change = value &1; }
|
||||||
Settings->SensorBits1.hx711_json_weight_change = strtol(ArgV(argument, 2), nullptr, 10) & 1;
|
|
||||||
}
|
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
case 9: // WeightDelta
|
case 9: // WeightDelta
|
||||||
if (strchr(XdrvMailbox.data, ',') != nullptr) {
|
if (any_value) {
|
||||||
Settings->weight_change = strtol(ArgV(argument, 2), nullptr, 10);
|
Settings->weight_change = value;
|
||||||
SetWeightDelta();
|
SetWeightDelta();
|
||||||
}
|
}
|
||||||
show_parms = true;
|
|
||||||
break;
|
break;
|
||||||
default:
|
case 10: // AbsoluteConversion, A
|
||||||
show_parms = true;
|
if (any_value) { Settings->weight_absconv_a = value; }
|
||||||
|
break;
|
||||||
|
case 11: // AbsoluteConversion, B
|
||||||
|
if (any_value) { Settings->weight_absconv_b = value; }
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (show_parms) {
|
if (show_parms) {
|
||||||
char item[33];
|
|
||||||
dtostrfd((float)Settings->weight_item / 10, 1, item);
|
|
||||||
Response_P(PSTR("{\"Sensor34\":{\"" D_JSON_WEIGHT_REF "\":%d,\"" D_JSON_WEIGHT_CAL "\":%d,\"" D_JSON_WEIGHT_MAX "\":%d,\""
|
Response_P(PSTR("{\"Sensor34\":{\"" D_JSON_WEIGHT_REF "\":%d,\"" D_JSON_WEIGHT_CAL "\":%d,\"" D_JSON_WEIGHT_MAX "\":%d,\""
|
||||||
D_JSON_WEIGHT_ITEM "\":%s,\"" D_JSON_WEIGHT_CHANGE "\":\"%s\",\"" D_JSON_WEIGHT_DELTA "\":%d}}"),
|
D_JSON_WEIGHT_ITEM "\":%1_f,\"" D_JSON_WEIGHT_CHANGE "\":\"%s\",\"" D_JSON_WEIGHT_DELTA "\":%d,\""
|
||||||
|
D_JSON_WEIGHT_ABSC_A "\":%d,\"" D_JSON_WEIGHT_ABSC_B "\":%d}}"),
|
||||||
Settings->weight_reference, Settings->weight_calibration, Settings->weight_max * 1000,
|
Settings->weight_reference, Settings->weight_calibration, Settings->weight_max * 1000,
|
||||||
item, GetStateText(Settings->SensorBits1.hx711_json_weight_change), Settings->weight_change);
|
&Settings->weight_item, GetStateText(Settings->SensorBits1.hx711_json_weight_change), Settings->weight_change,
|
||||||
|
Settings->weight_absconv_a, Settings->weight_absconv_b);
|
||||||
}
|
}
|
||||||
|
|
||||||
return serviced;
|
return serviced;
|
||||||
|
@ -445,13 +445,17 @@ void HxShow(bool json) {
|
||||||
uint16_t count = 0;
|
uint16_t count = 0;
|
||||||
float weight = 0;
|
float weight = 0;
|
||||||
if (Hx.calibrate_step < HX_CAL_FAIL) {
|
if (Hx.calibrate_step < HX_CAL_FAIL) {
|
||||||
if (Hx.weight && Settings->weight_item) {
|
if ((Settings->weight_absconv_a != 0) && (Settings->weight_absconv_b != 0)) {
|
||||||
count = (Hx.weight * 10) / Settings->weight_item;
|
weight = (float)Settings->weight_absconv_a / 1e9 * Hx.raw + (float)Settings->weight_absconv_b / 1e6;
|
||||||
if (count > 1) {
|
} else {
|
||||||
snprintf_P(scount, sizeof(scount), PSTR(",\"" D_JSON_COUNT "\":%d"), count);
|
if (Hx.weight && Settings->weight_item) {
|
||||||
|
count = (Hx.weight * 10) / Settings->weight_item;
|
||||||
|
if (count > 1) {
|
||||||
|
snprintf_P(scount, sizeof(scount), PSTR(",\"" D_JSON_COUNT "\":%d"), count);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
weight = (float)Hx.weight / 1000; // kilograms
|
||||||
}
|
}
|
||||||
weight = (float)Hx.weight / 1000; // kilograms
|
|
||||||
}
|
}
|
||||||
char weight_chr[33];
|
char weight_chr[33];
|
||||||
dtostrfd(weight, Settings->flag2.weight_resolution, weight_chr);
|
dtostrfd(weight, Settings->flag2.weight_resolution, weight_chr);
|
||||||
|
|
Loading…
Reference in New Issue