mirror of https://github.com/arendst/Tasmota.git
Merge remote-tracking branch 'Tasmota/development' into development
This commit is contained in:
commit
27193d8903
|
@ -59,6 +59,7 @@ The following binary downloads have been compiled with ESP8266/Arduino library c
|
||||||
- Change Energy JSON Total field from ``"Total":[33.736,11.717,16.978]`` to ``"Total":33.736,"TotalTariff":[11.717,16.978]``
|
- Change Energy JSON Total field from ``"Total":[33.736,11.717,16.978]`` to ``"Total":33.736,"TotalTariff":[11.717,16.978]``
|
||||||
- Change Energy JSON ExportActive field from ``"ExportActive":[33.736,11.717,16.978]`` to ``"ExportActive":33.736,"ExportTariff":[11.717,16.978]``
|
- Change Energy JSON ExportActive field from ``"ExportActive":[33.736,11.717,16.978]`` to ``"ExportActive":33.736,"ExportTariff":[11.717,16.978]``
|
||||||
- Add command ``Rule0`` to change global rule parameters
|
- Add command ``Rule0`` to change global rule parameters
|
||||||
|
- Add command ``Time 4`` to display timestamp using milliseconds (#8537)
|
||||||
- Add commands ``LedPwmOn 0..255``, ``LedPwmOff 0..255`` and ``LedPwmMode1 0/1`` to control led brightness by George (#8491)
|
- Add commands ``LedPwmOn 0..255``, ``LedPwmOff 0..255`` and ``LedPwmMode1 0/1`` to control led brightness by George (#8491)
|
||||||
- Add more functionality to ``Switchmode`` 11 and 12 (#8450)
|
- Add more functionality to ``Switchmode`` 11 and 12 (#8450)
|
||||||
- Add wildcard pattern ``?`` for JSON matching in rules
|
- Add wildcard pattern ``?`` for JSON matching in rules
|
||||||
|
|
|
@ -109,7 +109,7 @@ float Adafruit_VEML7700::normalize_resolution(float value) {
|
||||||
* @returns Floating point Lux data (ALS multiplied by 0.0576)
|
* @returns Floating point Lux data (ALS multiplied by 0.0576)
|
||||||
*/
|
*/
|
||||||
float Adafruit_VEML7700::readLux() {
|
float Adafruit_VEML7700::readLux() {
|
||||||
return ( normalize_resolution(ALS_Data->read()) * 0.0576); // see app note lux table on page 5
|
return ( normalize_resolution(ALS_Data->read()) * 0.0576f); // see app note lux table on page 5
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -122,7 +122,7 @@ float Adafruit_VEML7700::readLuxNormalized() {
|
||||||
// user-provided correction for non-linearities at high lux/white values:
|
// user-provided correction for non-linearities at high lux/white values:
|
||||||
// https://forums.adafruit.com/viewtopic.php?f=19&t=152997&p=758582#p759346
|
// https://forums.adafruit.com/viewtopic.php?f=19&t=152997&p=758582#p759346
|
||||||
if ((getGain() == VEML7700_GAIN_1_8) && (getIntegrationTime() == VEML7700_IT_25MS)){
|
if ((getGain() == VEML7700_GAIN_1_8) && (getIntegrationTime() == VEML7700_IT_25MS)){
|
||||||
lux = 6.0135e-13*alternate_pow(lux,4) - 9.3924e-9*alternate_pow(lux,3) + 8.1488e-5*alternate_pow(lux,2) + 1.0023*lux;
|
lux = 6.0135e-13f * pow(lux,4) - 9.3924e-9f * pow(lux,3) + 8.1488e-5f * pow(lux,2) + 1.0023f * lux;
|
||||||
}
|
}
|
||||||
|
|
||||||
return lux;
|
return lux;
|
||||||
|
@ -142,7 +142,7 @@ uint16_t Adafruit_VEML7700::readALS() {
|
||||||
*/
|
*/
|
||||||
float Adafruit_VEML7700::readWhite() {
|
float Adafruit_VEML7700::readWhite() {
|
||||||
// white_corrected= 2E-15*pow(VEML_white,4) + 4E-12*pow(VEML_white,3) + 9E-06*pow(VEML_white,)2 + 1.0179*VEML_white - 11.052;
|
// white_corrected= 2E-15*pow(VEML_white,4) + 4E-12*pow(VEML_white,3) + 9E-06*pow(VEML_white,)2 + 1.0179*VEML_white - 11.052;
|
||||||
return normalize_resolution(White_Data->read()) * 0.0576; // Unclear if this is the right multiplier
|
return normalize_resolution(White_Data->read()) * 0.0576f; // Unclear if this is the right multiplier
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -155,7 +155,7 @@ float Adafruit_VEML7700::readWhiteNormalized() {
|
||||||
// user-provided correction for non-linearities at high lux values:
|
// user-provided correction for non-linearities at high lux values:
|
||||||
// https://forums.adafruit.com/viewtopic.php?f=19&t=152997&p=758582#p759346
|
// https://forums.adafruit.com/viewtopic.php?f=19&t=152997&p=758582#p759346
|
||||||
if ((getGain() == VEML7700_GAIN_1_8) && (getIntegrationTime() == VEML7700_IT_25MS)){
|
if ((getGain() == VEML7700_GAIN_1_8) && (getIntegrationTime() == VEML7700_IT_25MS)){
|
||||||
white = 2E-15*alternate_pow(white,4) + 4E-12*alternate_pow(white,3) + 9E-06*alternate_pow(white,2) + 1.0179*white - 11.052;
|
white = 2E-15f * pow(white,4) + 4E-12f * pow(white,3) + 9E-06f * pow(white,2) + 1.0179f * white - 11.052f;
|
||||||
}
|
}
|
||||||
|
|
||||||
return white;
|
return white;
|
||||||
|
|
|
@ -62,6 +62,7 @@
|
||||||
#define VEML7700_POWERSAVE_MODE3 0x02 ///< Power saving mode 3
|
#define VEML7700_POWERSAVE_MODE3 0x02 ///< Power saving mode 3
|
||||||
#define VEML7700_POWERSAVE_MODE4 0x03 ///< Power saving mode 4
|
#define VEML7700_POWERSAVE_MODE4 0x03 ///< Power saving mode 4
|
||||||
|
|
||||||
|
// FastPrecisePowf from tasmota/support_float.ino
|
||||||
extern float FastPrecisePowf(const float x, const float y);
|
extern float FastPrecisePowf(const float x, const float y);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -111,7 +112,7 @@ private:
|
||||||
*PowerSave_Enable, *PowerSave_Mode;
|
*PowerSave_Enable, *PowerSave_Mode;
|
||||||
|
|
||||||
float normalize_resolution(float value);
|
float normalize_resolution(float value);
|
||||||
static inline float alternate_pow(float a, float b) { return FastPrecisePowf(a, b); }
|
static inline float pow(float a, float b) { return FastPrecisePowf(a, b); }
|
||||||
|
|
||||||
Adafruit_I2CDevice *i2c_dev;
|
Adafruit_I2CDevice *i2c_dev;
|
||||||
|
|
||||||
|
|
|
@ -5,8 +5,9 @@
|
||||||
- Change Energy JSON Total field from ``"Total":[33.736,11.717,16.978]`` to ``"Total":33.736,"TotalTariff":[11.717,16.978]``
|
- Change Energy JSON Total field from ``"Total":[33.736,11.717,16.978]`` to ``"Total":33.736,"TotalTariff":[11.717,16.978]``
|
||||||
- Change Energy JSON ExportActive field from ``"ExportActive":[33.736,11.717,16.978]`` to ``"ExportActive":33.736,"ExportTariff":[11.717,16.978]``
|
- Change Energy JSON ExportActive field from ``"ExportActive":[33.736,11.717,16.978]`` to ``"ExportActive":33.736,"ExportTariff":[11.717,16.978]``
|
||||||
- Change Adafruit_SGP30 library from v1.0.3 to v1.2.0 (#8519)
|
- Change Adafruit_SGP30 library from v1.0.3 to v1.2.0 (#8519)
|
||||||
- Add Three Phase Export Active Energy to SDM630 driver
|
- Add command ``Time 4`` to display timestamp using milliseconds (#8537)
|
||||||
- Add commands ``LedPwmOn 0..255``, ``LedPwmOff 0..255`` and ``LedPwmMode1 0/1`` to control led brightness by George (#8491)
|
- Add commands ``LedPwmOn 0..255``, ``LedPwmOff 0..255`` and ``LedPwmMode1 0/1`` to control led brightness by George (#8491)
|
||||||
|
- Add Three Phase Export Active Energy to SDM630 driver
|
||||||
- Add wildcard pattern ``?`` for JSON matching in rules
|
- Add wildcard pattern ``?`` for JSON matching in rules
|
||||||
|
|
||||||
### 8.3.1.1 20200518
|
### 8.3.1.1 20200518
|
||||||
|
|
|
@ -515,7 +515,7 @@ struct {
|
||||||
uint8_t ot_hot_water_setpoint; // E8C
|
uint8_t ot_hot_water_setpoint; // E8C
|
||||||
uint8_t ot_boiler_setpoint; // E8D
|
uint8_t ot_boiler_setpoint; // E8D
|
||||||
uint8_t ot_flags; // E8E
|
uint8_t ot_flags; // E8E
|
||||||
uint8_t ledpwm_mask; // F8F
|
uint8_t ledpwm_mask; // E8F
|
||||||
uint16_t dimmer_hw_min; // E90
|
uint16_t dimmer_hw_min; // E90
|
||||||
uint16_t dimmer_hw_max; // E92
|
uint16_t dimmer_hw_max; // E92
|
||||||
uint32_t deepsleep; // E94
|
uint32_t deepsleep; // E94
|
||||||
|
|
|
@ -996,6 +996,9 @@ char* ResponseGetTime(uint32_t format, char* time_str)
|
||||||
case 2:
|
case 2:
|
||||||
snprintf_P(time_str, TIMESZ, PSTR("{\"" D_JSON_TIME "\":%u"), UtcTime());
|
snprintf_P(time_str, TIMESZ, PSTR("{\"" D_JSON_TIME "\":%u"), UtcTime());
|
||||||
break;
|
break;
|
||||||
|
case 3:
|
||||||
|
snprintf_P(time_str, TIMESZ, PSTR("{\"" D_JSON_TIME "\":\"%s.%d\""), GetDateAndTime(DT_LOCAL).c_str(), RtcMillis());
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
snprintf_P(time_str, TIMESZ, PSTR("{\"" D_JSON_TIME "\":\"%s\""), GetDateAndTime(DT_LOCAL).c_str());
|
snprintf_P(time_str, TIMESZ, PSTR("{\"" D_JSON_TIME "\":\"%s\""), GetDateAndTime(DT_LOCAL).c_str());
|
||||||
}
|
}
|
||||||
|
|
|
@ -1641,12 +1641,12 @@ void CmndTime(void)
|
||||||
// payload 1 = Time format {"Time":"2019-09-04T14:31:29"}
|
// payload 1 = Time format {"Time":"2019-09-04T14:31:29"}
|
||||||
// payload 2 = Time format {"Time":"2019-09-04T14:31:29","Epoch":1567600289}
|
// payload 2 = Time format {"Time":"2019-09-04T14:31:29","Epoch":1567600289}
|
||||||
// payload 3 = Time format {"Time":1567600289}
|
// payload 3 = Time format {"Time":1567600289}
|
||||||
// payload 4 = reserved
|
// payload 4 = Time format {"Time":"2019-09-04T14:31:29.123"}
|
||||||
// payload 1451602800 - disable NTP and set time to epoch
|
// payload 1451602800 - disable NTP and set time to epoch
|
||||||
|
|
||||||
uint32_t format = Settings.flag2.time_format;
|
uint32_t format = Settings.flag2.time_format;
|
||||||
if (XdrvMailbox.data_len > 0) {
|
if (XdrvMailbox.data_len > 0) {
|
||||||
if ((XdrvMailbox.payload > 0) && (XdrvMailbox.payload < 4)) {
|
if ((XdrvMailbox.payload > 0) && (XdrvMailbox.payload < 5)) {
|
||||||
Settings.flag2.time_format = XdrvMailbox.payload -1;
|
Settings.flag2.time_format = XdrvMailbox.payload -1;
|
||||||
format = Settings.flag2.time_format;
|
format = Settings.flag2.time_format;
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -47,6 +47,7 @@ struct RTC {
|
||||||
uint32_t ntp_time = 0;
|
uint32_t ntp_time = 0;
|
||||||
uint32_t midnight = 0;
|
uint32_t midnight = 0;
|
||||||
uint32_t restart_time = 0;
|
uint32_t restart_time = 0;
|
||||||
|
uint32_t millis = 0;
|
||||||
int32_t time_timezone = 0;
|
int32_t time_timezone = 0;
|
||||||
uint8_t ntp_sync_minute = 0;
|
uint8_t ntp_sync_minute = 0;
|
||||||
bool midnight_now = false;
|
bool midnight_now = false;
|
||||||
|
@ -239,6 +240,10 @@ uint32_t MinutesPastMidnight(void)
|
||||||
return minutes;
|
return minutes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t RtcMillis(void) {
|
||||||
|
return (millis() - Rtc.millis) % 1000;
|
||||||
|
}
|
||||||
|
|
||||||
void BreakTime(uint32_t time_input, TIME_T &tm)
|
void BreakTime(uint32_t time_input, TIME_T &tm)
|
||||||
{
|
{
|
||||||
// break the given time_input into time components
|
// break the given time_input into time components
|
||||||
|
@ -362,6 +367,8 @@ void RtcSecond(void)
|
||||||
{
|
{
|
||||||
TIME_T tmpTime;
|
TIME_T tmpTime;
|
||||||
|
|
||||||
|
Rtc.millis = millis();
|
||||||
|
|
||||||
if (!Rtc.user_time_entry && !global_state.wifi_down) {
|
if (!Rtc.user_time_entry && !global_state.wifi_down) {
|
||||||
uint8_t uptime_minute = (uptime / 60) % 60; // 0 .. 59
|
uint8_t uptime_minute = (uptime / 60) % 60; // 0 .. 59
|
||||||
if ((Rtc.ntp_sync_minute > 59) && (uptime_minute > 2)) {
|
if ((Rtc.ntp_sync_minute > 59) && (uptime_minute > 2)) {
|
||||||
|
|
|
@ -1993,12 +1993,13 @@ chknext:
|
||||||
goto exit;
|
goto exit;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(USE_SML_M) && defined (USE_SML_SCRIPT_CMD)
|
#if defined(USE_SML_M) && defined (USE_SML_SCRIPT_CMD)
|
||||||
if (!strncmp(vname,"sml[",4)) {
|
if (!strncmp(vname,"sml[",4)) {
|
||||||
lp+=4;
|
lp+=4;
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&fvar,0);
|
lp=GetNumericResult(lp,OPER_EQU,&fvar,0);
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
fvar=SML_GetVal[fvar];
|
fvar=SML_GetVal(fvar);
|
||||||
lp++;
|
lp++;
|
||||||
len=0;
|
len=0;
|
||||||
goto exit;
|
goto exit;
|
||||||
|
@ -2786,6 +2787,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
|
||||||
if (tasm_cmd_activ && tlen>0) return 0;
|
if (tasm_cmd_activ && tlen>0) return 0;
|
||||||
|
|
||||||
uint8_t vtype=0,sindex,xflg,floop=0,globvindex,fromscriptcmd=0;
|
uint8_t vtype=0,sindex,xflg,floop=0,globvindex,fromscriptcmd=0;
|
||||||
|
char *lp_next;
|
||||||
int8_t globaindex;
|
int8_t globaindex;
|
||||||
struct T_INDEX ind;
|
struct T_INDEX ind;
|
||||||
uint8_t operand,lastop,numeric=1,if_state[IF_NEST],if_exe[IF_NEST],if_result[IF_NEST],and_or,ifstck=0;
|
uint8_t operand,lastop,numeric=1,if_state[IF_NEST],if_exe[IF_NEST],if_result[IF_NEST],and_or,ifstck=0;
|
||||||
|
@ -2925,6 +2927,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
|
||||||
// simple implementation, zero loop count not supported
|
// simple implementation, zero loop count not supported
|
||||||
lp+=3;
|
lp+=3;
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
|
lp_next=0;
|
||||||
lp=isvar(lp,&vtype,&ind,0,0,0);
|
lp=isvar(lp,&vtype,&ind,0,0,0);
|
||||||
if ((vtype!=VAR_NV) && (vtype&STYPE)==0) {
|
if ((vtype!=VAR_NV) && (vtype&STYPE)==0) {
|
||||||
// numeric var
|
// numeric var
|
||||||
|
@ -2947,22 +2950,26 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
|
||||||
// error
|
// error
|
||||||
toLogEOL("for error",lp);
|
toLogEOL("for error",lp);
|
||||||
}
|
}
|
||||||
} else if (!strncmp(lp,"next",4) && floop>0) {
|
} else if (!strncmp(lp,"next",4)) {
|
||||||
// for next loop
|
lp+=4;
|
||||||
*cv_count+=cv_inc;
|
lp_next=lp;
|
||||||
if (floop==1) {
|
if (floop>0) {
|
||||||
if (*cv_count<=cv_max) {
|
// for next loop
|
||||||
lp=cv_ptr;
|
*cv_count+=cv_inc;
|
||||||
|
if (floop==1) {
|
||||||
|
if (*cv_count<=cv_max) {
|
||||||
|
lp=cv_ptr;
|
||||||
|
} else {
|
||||||
|
lp+=4;
|
||||||
|
floop=0;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
lp+=4;
|
if (*cv_count>=cv_max) {
|
||||||
floop=0;
|
lp=cv_ptr;
|
||||||
}
|
} else {
|
||||||
} else {
|
lp+=4;
|
||||||
if (*cv_count>=cv_max) {
|
floop=0;
|
||||||
lp=cv_ptr;
|
}
|
||||||
} else {
|
|
||||||
lp+=4;
|
|
||||||
floop=0;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3022,13 +3029,15 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!strncmp(lp,"break",5)) {
|
if (!strncmp(lp,"break",5)) {
|
||||||
if (floop) {
|
lp+=5;
|
||||||
|
if (floop && lp_next) {
|
||||||
// should break loop
|
// should break loop
|
||||||
|
lp=lp_next;
|
||||||
floop=0;
|
floop=0;
|
||||||
} else {
|
} else {
|
||||||
section=0;
|
section=0;
|
||||||
}
|
}
|
||||||
break;
|
goto next_line;
|
||||||
} else if (!strncmp(lp,"dp",2) && isdigit(*(lp+2))) {
|
} else if (!strncmp(lp,"dp",2) && isdigit(*(lp+2))) {
|
||||||
lp+=2;
|
lp+=2;
|
||||||
// number precision
|
// number precision
|
||||||
|
@ -3357,6 +3366,7 @@ int16_t Run_Scripter(const char *type, int8_t tlen, char *js) {
|
||||||
goto next_line;
|
goto next_line;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
//Serial.printf(">> decode %s\n",lp );
|
||||||
// decode line
|
// decode line
|
||||||
if (*lp=='>' && tlen==1) {
|
if (*lp=='>' && tlen==1) {
|
||||||
// called from cmdline
|
// called from cmdline
|
||||||
|
@ -4998,6 +5008,9 @@ const char SCRIPT_MSG_GTABLEb[] PROGMEM =
|
||||||
const char SCRIPT_MSG_GOPT1[] PROGMEM =
|
const char SCRIPT_MSG_GOPT1[] PROGMEM =
|
||||||
"title:'%s',isStacked:false";
|
"title:'%s',isStacked:false";
|
||||||
|
|
||||||
|
const char SCRIPT_MSG_GAUGEOPT[] PROGMEM =
|
||||||
|
"max:%d,redFrom:%d,redTo:%d,yellowFrom:%d,yellowTo:%d";
|
||||||
|
|
||||||
const char SCRIPT_MSG_GOPT2[] PROGMEM =
|
const char SCRIPT_MSG_GOPT2[] PROGMEM =
|
||||||
"showRowNumber:true,sort:'disable',allowHtml:true,width:'100%%',height:'100%%',cssClassNames:cssc";
|
"showRowNumber:true,sort:'disable',allowHtml:true,width:'100%%',height:'100%%',cssClassNames:cssc";
|
||||||
|
|
||||||
|
@ -5029,7 +5042,8 @@ uint8 entries=0;
|
||||||
while (anum<MAX_GARRAY) {
|
while (anum<MAX_GARRAY) {
|
||||||
if (*lp==')' || *lp==0) break;
|
if (*lp==')' || *lp==0) break;
|
||||||
char *lp1=lp;
|
char *lp1=lp;
|
||||||
lp=isvar(lp,&vtype,&ind,0,0,0);
|
float sysvar;
|
||||||
|
lp=isvar(lp,&vtype,&ind,&sysvar,0,0);
|
||||||
if (vtype!=VAR_NV) {
|
if (vtype!=VAR_NV) {
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
uint8_t index=glob_script_mem.type[ind.index].index;
|
uint8_t index=glob_script_mem.type[ind.index].index;
|
||||||
|
@ -5047,6 +5061,11 @@ uint8 entries=0;
|
||||||
arrays[anum]=fa;
|
arrays[anum]=fa;
|
||||||
anum++;
|
anum++;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// single numeric
|
||||||
|
arrays[anum]=&glob_script_mem.fvars[index];
|
||||||
|
anum++;
|
||||||
|
entries=1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
lp=lp1;
|
lp=lp1;
|
||||||
|
@ -5054,6 +5073,7 @@ uint8 entries=0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//Serial.printf(">> %d - %d - %d\n",anum,entries,(uint32_t)*arrays[0]);
|
||||||
*ranum=anum;
|
*ranum=anum;
|
||||||
*rentries=entries;
|
*rentries=entries;
|
||||||
return lp;
|
return lp;
|
||||||
|
@ -5089,8 +5109,7 @@ uint32_t cnt;
|
||||||
void ScriptWebShow(char mc) {
|
void ScriptWebShow(char mc) {
|
||||||
uint8_t web_script=Run_Scripter(">W",-2,0);
|
uint8_t web_script=Run_Scripter(">W",-2,0);
|
||||||
if (web_script==99) {
|
if (web_script==99) {
|
||||||
char line[128];
|
char tmp[256];
|
||||||
char tmp[128];
|
|
||||||
uint8_t optflg=0;
|
uint8_t optflg=0;
|
||||||
uint8_t chartindex=1;
|
uint8_t chartindex=1;
|
||||||
uint8_t google_libs=0;
|
uint8_t google_libs=0;
|
||||||
|
@ -5104,96 +5123,27 @@ void ScriptWebShow(char mc) {
|
||||||
}
|
}
|
||||||
if (*lp!=';') {
|
if (*lp!=';') {
|
||||||
// send this line to web
|
// send this line to web
|
||||||
memcpy(line,lp,sizeof(line));
|
Replace_Cmd_Vars(lp,1,tmp,sizeof(tmp));
|
||||||
line[sizeof(line)-1]=0;
|
char *lin=tmp;
|
||||||
char *cp=line;
|
if (!mc && (*lin!='$')) {
|
||||||
for (uint32_t i=0; i<sizeof(line); i++) {
|
// normal web section
|
||||||
if (!*cp || *cp=='\n' || *cp=='\r') {
|
if (*lin=='@') {
|
||||||
*cp=0;
|
lin++;
|
||||||
break;
|
optflg=1;
|
||||||
}
|
|
||||||
cp++;
|
|
||||||
}
|
|
||||||
char *lin=line;
|
|
||||||
if (!mc && (*lin!='&')) {
|
|
||||||
|
|
||||||
if (*lin=='@') {
|
|
||||||
lin++;
|
|
||||||
optflg=1;
|
|
||||||
} else {
|
|
||||||
optflg=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// check for input elements
|
|
||||||
if (!strncmp(lin,"sl(",3)) {
|
|
||||||
// insert slider sl(min max var left mid right)
|
|
||||||
char *lp=lin;
|
|
||||||
float min;
|
|
||||||
lp=GetNumericResult(lp+3,OPER_EQU,&min,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
// arg2
|
|
||||||
float max;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&max,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
float val;
|
|
||||||
char *slp=lp;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
|
|
||||||
char vname[16];
|
|
||||||
ScriptGetVarname(vname,slp,sizeof(vname));
|
|
||||||
|
|
||||||
char left[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,left,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
char mid[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,mid,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
char right[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,right,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
|
|
||||||
WSContentSend_PD(SCRIPT_MSG_SLIDER,left,mid,right,(uint32_t)min,(uint32_t)max,(uint32_t)val,vname);
|
|
||||||
|
|
||||||
|
|
||||||
} else if (!strncmp(lin,"ck(",3)) {
|
|
||||||
char *lp=lin+3;
|
|
||||||
char *slp=lp;
|
|
||||||
float val;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
|
|
||||||
char vname[16];
|
|
||||||
ScriptGetVarname(vname,slp,sizeof(vname));
|
|
||||||
|
|
||||||
char label[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,label,0);
|
|
||||||
const char *cp;
|
|
||||||
uint8_t uval;
|
|
||||||
if (val>0) {
|
|
||||||
cp="checked='checked'";
|
|
||||||
uval=0;
|
|
||||||
} else {
|
} else {
|
||||||
cp="";
|
optflg=0;
|
||||||
uval=1;
|
|
||||||
}
|
}
|
||||||
WSContentSend_PD(SCRIPT_MSG_CHKBOX,label,(char*)cp,uval,vname);
|
// check for input elements
|
||||||
|
if (!strncmp(lin,"sl(",3)) {
|
||||||
} else if (!strncmp(lin,"bu(",3)) {
|
// insert slider sl(min max var left mid right)
|
||||||
char *lp=lin+3;
|
char *lp=lin;
|
||||||
uint8_t bcnt=0;
|
float min;
|
||||||
char *found=lin;
|
lp=GetNumericResult(lp+3,OPER_EQU,&min,0);
|
||||||
while (bcnt<4) {
|
SCRIPT_SKIP_SPACES
|
||||||
found=strstr(found,"bu(");
|
// arg2
|
||||||
if (!found) break;
|
float max;
|
||||||
found+=3;
|
lp=GetNumericResult(lp,OPER_EQU,&max,0);
|
||||||
bcnt++;
|
SCRIPT_SKIP_SPACES
|
||||||
}
|
|
||||||
uint8_t proz=100/bcnt;
|
|
||||||
if (!optflg && bcnt>1) proz-=2;
|
|
||||||
if (optflg) WSContentSend_PD(SCRIPT_MSG_BUT_START_TBL);
|
|
||||||
else WSContentSend_PD(SCRIPT_MSG_BUT_START);
|
|
||||||
for (uint32_t cnt=0;cnt<bcnt;cnt++) {
|
|
||||||
float val;
|
float val;
|
||||||
char *slp=lp;
|
char *slp=lp;
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
||||||
|
@ -5202,97 +5152,159 @@ void ScriptWebShow(char mc) {
|
||||||
char vname[16];
|
char vname[16];
|
||||||
ScriptGetVarname(vname,slp,sizeof(vname));
|
ScriptGetVarname(vname,slp,sizeof(vname));
|
||||||
|
|
||||||
|
char left[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,left,0);
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
char ontxt[SCRIPT_MAXSSIZE];
|
char mid[SCRIPT_MAXSSIZE];
|
||||||
lp=GetStringResult(lp,OPER_EQU,ontxt,0);
|
lp=GetStringResult(lp,OPER_EQU,mid,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
char right[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,right,0);
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
char offtxt[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,offtxt,0);
|
|
||||||
|
|
||||||
char *cp;
|
WSContentSend_PD(SCRIPT_MSG_SLIDER,left,mid,right,(uint32_t)min,(uint32_t)max,(uint32_t)val,vname);
|
||||||
|
|
||||||
|
} else if (!strncmp(lin,"ck(",3)) {
|
||||||
|
char *lp=lin+3;
|
||||||
|
char *slp=lp;
|
||||||
|
float val;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
|
||||||
|
char vname[16];
|
||||||
|
ScriptGetVarname(vname,slp,sizeof(vname));
|
||||||
|
|
||||||
|
char label[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,label,0);
|
||||||
|
const char *cp;
|
||||||
uint8_t uval;
|
uint8_t uval;
|
||||||
if (val>0) {
|
if (val>0) {
|
||||||
cp=ontxt;
|
cp="checked='checked'";
|
||||||
uval=0;
|
uval=0;
|
||||||
} else {
|
} else {
|
||||||
cp=offtxt;
|
cp="";
|
||||||
uval=1;
|
uval=1;
|
||||||
}
|
}
|
||||||
if (bcnt>1 && cnt==bcnt-1) {
|
WSContentSend_PD(SCRIPT_MSG_CHKBOX,label,(char*)cp,uval,vname);
|
||||||
if (!optflg) proz+=2;
|
|
||||||
|
} else if (!strncmp(lin,"bu(",3)) {
|
||||||
|
char *lp=lin+3;
|
||||||
|
uint8_t bcnt=0;
|
||||||
|
char *found=lin;
|
||||||
|
while (bcnt<4) {
|
||||||
|
found=strstr(found,"bu(");
|
||||||
|
if (!found) break;
|
||||||
|
found+=3;
|
||||||
|
bcnt++;
|
||||||
}
|
}
|
||||||
if (!optflg) {
|
uint8_t proz=100/bcnt;
|
||||||
WSContentSend_PD(SCRIPT_MSG_BUTTONa,proz,uval,vname,cp);
|
if (!optflg && bcnt>1) proz-=2;
|
||||||
} else {
|
if (optflg) WSContentSend_PD(SCRIPT_MSG_BUT_START_TBL);
|
||||||
WSContentSend_PD(SCRIPT_MSG_BUTTONa_TBL,proz,uval,vname,cp);
|
else WSContentSend_PD(SCRIPT_MSG_BUT_START);
|
||||||
|
for (uint32_t cnt=0;cnt<bcnt;cnt++) {
|
||||||
|
float val;
|
||||||
|
char *slp=lp;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
|
||||||
|
char vname[16];
|
||||||
|
ScriptGetVarname(vname,slp,sizeof(vname));
|
||||||
|
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
char ontxt[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,ontxt,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
char offtxt[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,offtxt,0);
|
||||||
|
|
||||||
|
char *cp;
|
||||||
|
uint8_t uval;
|
||||||
|
if (val>0) {
|
||||||
|
cp=ontxt;
|
||||||
|
uval=0;
|
||||||
|
} else {
|
||||||
|
cp=offtxt;
|
||||||
|
uval=1;
|
||||||
|
}
|
||||||
|
if (bcnt>1 && cnt==bcnt-1) {
|
||||||
|
if (!optflg) proz+=2;
|
||||||
|
}
|
||||||
|
if (!optflg) {
|
||||||
|
WSContentSend_PD(SCRIPT_MSG_BUTTONa,proz,uval,vname,cp);
|
||||||
|
} else {
|
||||||
|
WSContentSend_PD(SCRIPT_MSG_BUTTONa_TBL,proz,uval,vname,cp);
|
||||||
|
}
|
||||||
|
if (bcnt>1 && cnt<bcnt-1) {
|
||||||
|
if (!optflg) WSContentSend_PD(SCRIPT_MSG_BUTTONb,2);
|
||||||
|
}
|
||||||
|
lp+=4;
|
||||||
}
|
}
|
||||||
if (bcnt>1 && cnt<bcnt-1) {
|
if (optflg) WSContentSend_PD(SCRIPT_MSG_BUT_STOP_TBL);
|
||||||
if (!optflg) WSContentSend_PD(SCRIPT_MSG_BUTTONb,2);
|
else WSContentSend_PD(SCRIPT_MSG_BUT_STOP);
|
||||||
}
|
|
||||||
lp+=4;
|
|
||||||
}
|
|
||||||
if (optflg) WSContentSend_PD(SCRIPT_MSG_BUT_STOP_TBL);
|
|
||||||
else WSContentSend_PD(SCRIPT_MSG_BUT_STOP);
|
|
||||||
} else if (!strncmp(lin,"tx(",3)) {
|
|
||||||
char *lp=lin+3;
|
|
||||||
char *slp=lp;
|
|
||||||
char str[SCRIPT_MAXSSIZE];
|
|
||||||
lp=ForceStringVar(lp,str);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
char label[SCRIPT_MAXSSIZE];
|
|
||||||
lp=GetStringResult(lp,OPER_EQU,label,0);
|
|
||||||
|
|
||||||
char vname[16];
|
} else if (!strncmp(lin,"tx(",3)) {
|
||||||
ScriptGetVarname(vname,slp,sizeof(vname));
|
char *lp=lin+3;
|
||||||
|
char *slp=lp;
|
||||||
|
char str[SCRIPT_MAXSSIZE];
|
||||||
|
lp=ForceStringVar(lp,str);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
char label[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,label,0);
|
||||||
|
|
||||||
WSContentSend_PD(SCRIPT_MSG_TEXTINP,label,str,vname);
|
char vname[16];
|
||||||
|
ScriptGetVarname(vname,slp,sizeof(vname));
|
||||||
|
|
||||||
} else if (!strncmp(lin,"nm(",3)) {
|
WSContentSend_PD(SCRIPT_MSG_TEXTINP,label,str,vname);
|
||||||
char *lp=lin;
|
|
||||||
float min;
|
|
||||||
lp=GetNumericResult(lp+3,OPER_EQU,&min,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
float max;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&max,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
float step;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&step,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
float val;
|
|
||||||
char *slp=lp;
|
|
||||||
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
|
||||||
SCRIPT_SKIP_SPACES
|
|
||||||
char vname[16];
|
|
||||||
ScriptGetVarname(vname,slp,sizeof(vname));
|
|
||||||
|
|
||||||
char label[SCRIPT_MAXSSIZE];
|
} else if (!strncmp(lin,"nm(",3)) {
|
||||||
lp=GetStringResult(lp,OPER_EQU,label,0);
|
char *lp=lin;
|
||||||
|
float min;
|
||||||
|
lp=GetNumericResult(lp+3,OPER_EQU,&min,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float max;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&max,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float step;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&step,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float val;
|
||||||
|
char *slp=lp;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&val,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
char vname[16];
|
||||||
|
ScriptGetVarname(vname,slp,sizeof(vname));
|
||||||
|
|
||||||
|
char label[SCRIPT_MAXSSIZE];
|
||||||
|
lp=GetStringResult(lp,OPER_EQU,label,0);
|
||||||
|
|
||||||
|
char vstr[16],minstr[16],maxstr[16],stepstr[16];
|
||||||
|
dtostrfd(val,4,vstr);
|
||||||
|
dtostrfd(min,4,minstr);
|
||||||
|
dtostrfd(max,4,maxstr);
|
||||||
|
dtostrfd(step,4,stepstr);
|
||||||
|
WSContentSend_PD(SCRIPT_MSG_NUMINP,label,minstr,maxstr,stepstr,vstr,vname);
|
||||||
|
|
||||||
char vstr[16],minstr[16],maxstr[16],stepstr[16];
|
|
||||||
dtostrfd(val,4,vstr);
|
|
||||||
dtostrfd(min,4,minstr);
|
|
||||||
dtostrfd(max,4,maxstr);
|
|
||||||
dtostrfd(step,4,stepstr);
|
|
||||||
WSContentSend_PD(SCRIPT_MSG_NUMINP,label,minstr,maxstr,stepstr,vstr,vname);
|
|
||||||
} else {
|
|
||||||
Replace_Cmd_Vars(lin,0,tmp,sizeof(tmp));
|
|
||||||
if (optflg) {
|
|
||||||
WSContentSend_PD(PSTR("<div>%s</div>"),tmp);
|
|
||||||
} else {
|
} else {
|
||||||
WSContentSend_PD(PSTR("{s}%s{e}"),tmp);
|
if (optflg) {
|
||||||
|
WSContentSend_PD(PSTR("<div>%s</div>"),tmp);
|
||||||
|
} else {
|
||||||
|
WSContentSend_PD(PSTR("{s}%s{e}"),tmp);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
// end standard web interface
|
||||||
} else {
|
} else {
|
||||||
|
// main section interface
|
||||||
if (*lin==mc) {
|
if (*lin==mc) {
|
||||||
#ifdef USE_GOOGLE_CHARTS
|
#ifdef USE_GOOGLE_CHARTS
|
||||||
lin++;
|
lin++;
|
||||||
|
char *lp;
|
||||||
if (!strncmp(lin,"gc(",3)) {
|
if (!strncmp(lin,"gc(",3)) {
|
||||||
// get google table
|
// get google table
|
||||||
lp=lin+3;
|
lp=lin+3;
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
const char *type;
|
const char *type;
|
||||||
const char *func;
|
const char *func;
|
||||||
char options[256];
|
char options[312];
|
||||||
uint8_t nanum=MAX_GARRAY;
|
uint8_t nanum=MAX_GARRAY;
|
||||||
uint8_t y2f=0;
|
uint8_t y2f=0;
|
||||||
char ctype;
|
char ctype;
|
||||||
|
@ -5377,18 +5389,9 @@ void ScriptWebShow(char mc) {
|
||||||
char label[SCRIPT_MAXSSIZE];
|
char label[SCRIPT_MAXSSIZE];
|
||||||
lp=GetStringResult(lp,OPER_EQU,label,0);
|
lp=GetStringResult(lp,OPER_EQU,label,0);
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
char *lblp=label;
|
|
||||||
for (uint32_t ind=0; ind<anum; ind++) {
|
for (uint32_t ind=0; ind<anum; ind++) {
|
||||||
char lbl[16];
|
char lbl[16];
|
||||||
strncpy(lbl,lblp,sizeof(lbl));
|
GetTextIndexed(lbl, sizeof(lbl), ind, label);
|
||||||
for (uint32_t i=0; i<strlen(lblp); i++) {
|
|
||||||
if (lblp[i]=='|') {
|
|
||||||
lbl[i]=0;
|
|
||||||
lblp+=i+1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
lbl[i]=lblp[i];
|
|
||||||
}
|
|
||||||
for (uint32_t cnt=0; cnt<entries; cnt+=2) {
|
for (uint32_t cnt=0; cnt<entries; cnt+=2) {
|
||||||
WSContentSend_PD("['%s',",lbl);
|
WSContentSend_PD("['%s',",lbl);
|
||||||
float *fp=arrays[ind];
|
float *fp=arrays[ind];
|
||||||
|
@ -5414,19 +5417,20 @@ void ScriptWebShow(char mc) {
|
||||||
char label[SCRIPT_MAXSSIZE];
|
char label[SCRIPT_MAXSSIZE];
|
||||||
lp=GetStringResult(lp,OPER_EQU,label,0);
|
lp=GetStringResult(lp,OPER_EQU,label,0);
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
char *lblp=label;
|
|
||||||
|
int8_t todflg=-1;
|
||||||
|
if (!strncmp(label,"cnt",3)) {
|
||||||
|
todflg=atoi(&label[3]);
|
||||||
|
}
|
||||||
|
|
||||||
for (uint32_t cnt=0; cnt<entries; cnt++) {
|
for (uint32_t cnt=0; cnt<entries; cnt++) {
|
||||||
WSContentSend_PD("['");
|
WSContentSend_PD("['");
|
||||||
char lbl[16];
|
char lbl[16];
|
||||||
strncpy(lbl,lblp,sizeof(lbl));
|
if (todflg>=0) {
|
||||||
for (uint32_t i=0; i<strlen(lblp); i++) {
|
sprintf(lbl,"%d",todflg);
|
||||||
if (lblp[i]=='|') {
|
todflg++;
|
||||||
lbl[i]=0;
|
} else {
|
||||||
lblp+=i+1;
|
GetTextIndexed(lbl, sizeof(lbl), cnt, label);
|
||||||
break;
|
|
||||||
}
|
|
||||||
lbl[i]=lblp[i];
|
|
||||||
}
|
}
|
||||||
WSContentSend_PD(lbl);
|
WSContentSend_PD(lbl);
|
||||||
WSContentSend_PD("',");
|
WSContentSend_PD("',");
|
||||||
|
@ -5466,17 +5470,31 @@ void ScriptWebShow(char mc) {
|
||||||
SCRIPT_SKIP_SPACES
|
SCRIPT_SKIP_SPACES
|
||||||
snprintf_P(options,sizeof(options),SCRIPT_MSG_GOPT3,header,(uint32_t)max1,(uint32_t)max2,func);
|
snprintf_P(options,sizeof(options),SCRIPT_MSG_GOPT3,header,(uint32_t)max1,(uint32_t)max2,func);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ctype=='g') {
|
||||||
|
float yellowFrom;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&yellowFrom,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float redFrom;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&redFrom,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float maxValue;
|
||||||
|
lp=GetNumericResult(lp,OPER_EQU,&maxValue,0);
|
||||||
|
SCRIPT_SKIP_SPACES
|
||||||
|
float redTo=maxValue;
|
||||||
|
float yellowTo=redFrom;
|
||||||
|
snprintf_P(options,sizeof(options),SCRIPT_MSG_GAUGEOPT,(uint32_t)maxValue,(uint32_t)redFrom,(uint32_t)redTo,
|
||||||
|
(uint32_t)yellowFrom,(uint32_t)yellowTo);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
WSContentSend_PD(SCRIPT_MSG_GTABLEb,options,type,chartindex);
|
WSContentSend_PD(SCRIPT_MSG_GTABLEb,options,type,chartindex);
|
||||||
chartindex++;
|
chartindex++;
|
||||||
} else {
|
} else {
|
||||||
Replace_Cmd_Vars(lin,0,tmp,sizeof(tmp));
|
WSContentSend_PD(PSTR("%s"),lin);
|
||||||
WSContentSend_PD(PSTR("%s"),tmp);
|
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
} else {
|
} else {
|
||||||
Replace_Cmd_Vars(lin,0,tmp,sizeof(tmp));
|
// WSContentSend_PD(PSTR("%s"),lin);
|
||||||
WSContentSend_PD(PSTR("%s"),tmp);
|
|
||||||
#endif //USE_GOOGLE_CHARTS
|
#endif //USE_GOOGLE_CHARTS
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -5809,7 +5827,7 @@ bool Xdrv10(uint8_t function)
|
||||||
#ifdef USE_SCRIPT_WEB_DISPLAY
|
#ifdef USE_SCRIPT_WEB_DISPLAY
|
||||||
case FUNC_WEB_ADD_MAIN_BUTTON:
|
case FUNC_WEB_ADD_MAIN_BUTTON:
|
||||||
if (bitRead(Settings.rule_enabled, 0)) {
|
if (bitRead(Settings.rule_enabled, 0)) {
|
||||||
ScriptWebShow('&');
|
ScriptWebShow('$');
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif // USE_SCRIPT_WEB_DISPLAY
|
#endif // USE_SCRIPT_WEB_DISPLAY
|
||||||
|
|
|
@ -94,14 +94,16 @@ WiFiClient client;
|
||||||
#define HREF_GPIO_NUM 23
|
#define HREF_GPIO_NUM 23
|
||||||
#define PCLK_GPIO_NUM 22
|
#define PCLK_GPIO_NUM 22
|
||||||
|
|
||||||
uint8_t wc_up;
|
struct {
|
||||||
uint16_t wc_width;
|
uint8_t up;
|
||||||
uint16_t wc_height;
|
uint16_t width;
|
||||||
uint8_t wc_stream_active;
|
uint16_t height;
|
||||||
|
uint8_t stream_active;
|
||||||
#ifdef USE_FACE_DETECT
|
#ifdef USE_FACE_DETECT
|
||||||
uint8_t faces;
|
uint8_t faces;
|
||||||
uint16_t face_detect_time;
|
uint16_t face_detect_time;
|
||||||
#endif
|
#endif
|
||||||
|
} Wc;
|
||||||
|
|
||||||
/*********************************************************************************************/
|
/*********************************************************************************************/
|
||||||
|
|
||||||
|
@ -128,18 +130,18 @@ bool WcPinUsed(void) {
|
||||||
uint32_t WcSetup(int32_t fsiz) {
|
uint32_t WcSetup(int32_t fsiz) {
|
||||||
if (fsiz > 10) { fsiz = 10; }
|
if (fsiz > 10) { fsiz = 10; }
|
||||||
|
|
||||||
wc_stream_active = 0;
|
Wc.stream_active = 0;
|
||||||
|
|
||||||
if (fsiz < 0) {
|
if (fsiz < 0) {
|
||||||
esp_camera_deinit();
|
esp_camera_deinit();
|
||||||
wc_up = 0;
|
Wc.up = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (wc_up) {
|
if (Wc.up) {
|
||||||
esp_camera_deinit();
|
esp_camera_deinit();
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Deinit"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Deinit"));
|
||||||
//return wc_up;
|
//return Wc.up;
|
||||||
}
|
}
|
||||||
|
|
||||||
//esp_log_level_set("*", ESP_LOG_VERBOSE);
|
//esp_log_level_set("*", ESP_LOG_VERBOSE);
|
||||||
|
@ -239,8 +241,12 @@ uint32_t WcSetup(int32_t fsiz) {
|
||||||
wc_s->set_framesize(wc_s, (framesize_t)fsiz);
|
wc_s->set_framesize(wc_s, (framesize_t)fsiz);
|
||||||
|
|
||||||
camera_fb_t *wc_fb = esp_camera_fb_get();
|
camera_fb_t *wc_fb = esp_camera_fb_get();
|
||||||
wc_width = wc_fb->width;
|
if (!wc_fb) {
|
||||||
wc_height = wc_fb->height;
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Failed to get the frame on time"));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
Wc.width = wc_fb->width;
|
||||||
|
Wc.height = wc_fb->height;
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
|
|
||||||
#ifdef USE_FACE_DETECT
|
#ifdef USE_FACE_DETECT
|
||||||
|
@ -249,10 +255,10 @@ uint32_t WcSetup(int32_t fsiz) {
|
||||||
|
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Initialized"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Initialized"));
|
||||||
|
|
||||||
wc_up = 1;
|
Wc.up = 1;
|
||||||
if (psram) { wc_up=2; }
|
if (psram) { Wc.up=2; }
|
||||||
|
|
||||||
return wc_up;
|
return Wc.up;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************************************/
|
/*********************************************************************************************/
|
||||||
|
@ -299,17 +305,17 @@ int32_t WcSetOptions(uint32_t sel, int32_t value) {
|
||||||
uint32_t WcGetWidth(void) {
|
uint32_t WcGetWidth(void) {
|
||||||
camera_fb_t *wc_fb = esp_camera_fb_get();
|
camera_fb_t *wc_fb = esp_camera_fb_get();
|
||||||
if (!wc_fb) { return 0; }
|
if (!wc_fb) { return 0; }
|
||||||
wc_width = wc_fb->width;
|
Wc.width = wc_fb->width;
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
return wc_width;
|
return Wc.width;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t WcGetHeight(void) {
|
uint32_t WcGetHeight(void) {
|
||||||
camera_fb_t *wc_fb = esp_camera_fb_get();
|
camera_fb_t *wc_fb = esp_camera_fb_get();
|
||||||
if (!wc_fb) { return 0; }
|
if (!wc_fb) { return 0; }
|
||||||
wc_height = wc_fb->height;
|
Wc.height = wc_fb->height;
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
return wc_height;
|
return Wc.height;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*********************************************************************************************/
|
/*********************************************************************************************/
|
||||||
|
@ -447,8 +453,8 @@ void draw_face_boxes(dl_matrix3du_t *image_matrix, box_array_t *boxes, int face_
|
||||||
#define DL_SPIRAM_SUPPORT
|
#define DL_SPIRAM_SUPPORT
|
||||||
|
|
||||||
uint32_t WcSetFaceDetect(int32_t value) {
|
uint32_t WcSetFaceDetect(int32_t value) {
|
||||||
if (value >= 0) { face_detect_time = value; }
|
if (value >= 0) { Wc.face_detect_time = value; }
|
||||||
return faces;
|
return Wc.faces;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t face_ltime;
|
uint32_t face_ltime;
|
||||||
|
@ -464,7 +470,7 @@ uint32_t WcDetectFace(void) {
|
||||||
int face_id = 0;
|
int face_id = 0;
|
||||||
camera_fb_t *fb;
|
camera_fb_t *fb;
|
||||||
|
|
||||||
if ((millis() - face_ltime) > face_detect_time) {
|
if ((millis() - face_ltime) > Wc.face_detect_time) {
|
||||||
face_ltime = millis();
|
face_ltime = millis();
|
||||||
fb = esp_camera_fb_get();
|
fb = esp_camera_fb_get();
|
||||||
if (!fb) { return ESP_FAIL; }
|
if (!fb) { return ESP_FAIL; }
|
||||||
|
@ -492,7 +498,7 @@ uint32_t WcDetectFace(void) {
|
||||||
box_array_t *net_boxes = face_detect(image_matrix, &mtmn_config);
|
box_array_t *net_boxes = face_detect(image_matrix, &mtmn_config);
|
||||||
if (net_boxes){
|
if (net_boxes){
|
||||||
detected = true;
|
detected = true;
|
||||||
faces = net_boxes->len;
|
Wc.faces = net_boxes->len;
|
||||||
//if(recognition_enabled){
|
//if(recognition_enabled){
|
||||||
// face_id = run_face_recognition(image_matrix, net_boxes);
|
// face_id = run_face_recognition(image_matrix, net_boxes);
|
||||||
//}
|
//}
|
||||||
|
@ -502,10 +508,10 @@ uint32_t WcDetectFace(void) {
|
||||||
free(net_boxes->landmark);
|
free(net_boxes->landmark);
|
||||||
free(net_boxes);
|
free(net_boxes);
|
||||||
} else {
|
} else {
|
||||||
faces = 0;
|
Wc.faces = 0;
|
||||||
}
|
}
|
||||||
dl_matrix3du_free(image_matrix);
|
dl_matrix3du_free(image_matrix);
|
||||||
//Serial.printf("face detected: %d",faces);
|
//Serial.printf("face detected: %d",Wc.faces);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -564,8 +570,8 @@ uint32_t WcGetFrame(int32_t bnum) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (!bnum) {
|
if (!bnum) {
|
||||||
wc_width = wc_fb->width;
|
Wc.width = wc_fb->width;
|
||||||
wc_height = wc_fb->height;
|
Wc.height = wc_fb->height;
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -691,9 +697,9 @@ void HandleImageBasic(void) {
|
||||||
|
|
||||||
void HandleWebcamMjpeg(void) {
|
void HandleWebcamMjpeg(void) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Handle camserver"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Handle camserver"));
|
||||||
// if (!wc_stream_active) {
|
// if (!Wc.stream_active) {
|
||||||
// always restart stream
|
// always restart stream
|
||||||
wc_stream_active = 1;
|
Wc.stream_active = 1;
|
||||||
client = CamServer->client();
|
client = CamServer->client();
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Create client"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Create client"));
|
||||||
// }
|
// }
|
||||||
|
@ -710,25 +716,25 @@ void HandleWebcamMjpegTask(void) {
|
||||||
|
|
||||||
if (!client.connected()) {
|
if (!client.connected()) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Client fail"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Client fail"));
|
||||||
wc_stream_active = 0;
|
Wc.stream_active = 0;
|
||||||
}
|
}
|
||||||
if (1 == wc_stream_active) {
|
if (1 == Wc.stream_active) {
|
||||||
client.flush();
|
client.flush();
|
||||||
client.setTimeout(3);
|
client.setTimeout(3);
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Start stream"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Start stream"));
|
||||||
client.print("HTTP/1.1 200 OK\r\n"
|
client.print("HTTP/1.1 200 OK\r\n"
|
||||||
"Content-Type: multipart/x-mixed-replace;boundary=" BOUNDARY "\r\n"
|
"Content-Type: multipart/x-mixed-replace;boundary=" BOUNDARY "\r\n"
|
||||||
"\r\n");
|
"\r\n");
|
||||||
wc_stream_active = 2;
|
Wc.stream_active = 2;
|
||||||
}
|
}
|
||||||
if (2 == wc_stream_active) {
|
if (2 == Wc.stream_active) {
|
||||||
wc_fb = esp_camera_fb_get();
|
wc_fb = esp_camera_fb_get();
|
||||||
if (!wc_fb) {
|
if (!wc_fb) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Frame fail"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Frame fail"));
|
||||||
wc_stream_active = 0;
|
Wc.stream_active = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (2 == wc_stream_active) {
|
if (2 == Wc.stream_active) {
|
||||||
if (wc_fb->format != PIXFORMAT_JPEG) {
|
if (wc_fb->format != PIXFORMAT_JPEG) {
|
||||||
jpeg_converted = frame2jpg(wc_fb, 80, &_jpg_buf, &_jpg_buf_len);
|
jpeg_converted = frame2jpg(wc_fb, 80, &_jpg_buf, &_jpg_buf_len);
|
||||||
if (!jpeg_converted){
|
if (!jpeg_converted){
|
||||||
|
@ -748,7 +754,7 @@ void HandleWebcamMjpegTask(void) {
|
||||||
/*
|
/*
|
||||||
if (tlen!=_jpg_buf_len) {
|
if (tlen!=_jpg_buf_len) {
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
wc_stream_active=0;
|
Wc.stream_active=0;
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Send fail"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Send fail"));
|
||||||
}*/
|
}*/
|
||||||
client.print("\r\n--" BOUNDARY "\r\n");
|
client.print("\r\n--" BOUNDARY "\r\n");
|
||||||
|
@ -768,7 +774,7 @@ void HandleWebcamMjpegTask(void) {
|
||||||
esp_camera_fb_return(wc_fb);
|
esp_camera_fb_return(wc_fb);
|
||||||
//AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: send frame"));
|
//AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: send frame"));
|
||||||
}
|
}
|
||||||
if (0 == wc_stream_active) {
|
if (0 == Wc.stream_active) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Stream exit"));
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("CAM: Stream exit"));
|
||||||
client.flush();
|
client.flush();
|
||||||
client.stop();
|
client.stop();
|
||||||
|
@ -787,7 +793,7 @@ void HandleWebcamRoot(void) {
|
||||||
uint32_t WcSetStreamserver(uint32_t flag) {
|
uint32_t WcSetStreamserver(uint32_t flag) {
|
||||||
if (global_state.wifi_down) { return 0; }
|
if (global_state.wifi_down) { return 0; }
|
||||||
|
|
||||||
wc_stream_active = 0;
|
Wc.stream_active = 0;
|
||||||
|
|
||||||
if (flag) {
|
if (flag) {
|
||||||
if (!CamServer) {
|
if (!CamServer) {
|
||||||
|
@ -821,11 +827,11 @@ void WcStreamControl() {
|
||||||
void WcLoop(void) {
|
void WcLoop(void) {
|
||||||
if (CamServer) {
|
if (CamServer) {
|
||||||
CamServer->handleClient();
|
CamServer->handleClient();
|
||||||
if (wc_stream_active) { HandleWebcamMjpegTask(); }
|
if (Wc.stream_active) { HandleWebcamMjpegTask(); }
|
||||||
}
|
}
|
||||||
if (motion_detect) { WcDetectMotion(); }
|
if (motion_detect) { WcDetectMotion(); }
|
||||||
#ifdef USE_FACE_DETECT
|
#ifdef USE_FACE_DETECT
|
||||||
if (face_detect_time) { WcDetectFace(); }
|
if (Wc.face_detect_time) { WcDetectFace(); }
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -841,7 +847,7 @@ void WcShowStream(void) {
|
||||||
WcStreamControl();
|
WcStreamControl();
|
||||||
delay(50); // Give the webcam webserver some time to prepare the stream
|
delay(50); // Give the webcam webserver some time to prepare the stream
|
||||||
}
|
}
|
||||||
if (CamServer) {
|
if (CamServer && Wc.up) {
|
||||||
WSContentSend_P(PSTR("<p></p><center><img src='http://%s:81/stream' alt='Webcam stream' style='width:99%%;'></center><p></p>"),
|
WSContentSend_P(PSTR("<p></p><center><img src='http://%s:81/stream' alt='Webcam stream' style='width:99%%;'></center><p></p>"),
|
||||||
WiFi.localIP().toString().c_str());
|
WiFi.localIP().toString().c_str());
|
||||||
}
|
}
|
||||||
|
|
|
@ -239,8 +239,6 @@ void SevensegTime(boolean time_24)
|
||||||
sevenseg.writeDisplay();
|
sevenseg.writeDisplay();
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // USE_DISPLAY_MODES1TO5
|
|
||||||
|
|
||||||
void SevensegRefresh(void) // Every second
|
void SevensegRefresh(void) // Every second
|
||||||
{
|
{
|
||||||
if (disp_power) {
|
if (disp_power) {
|
||||||
|
@ -262,6 +260,8 @@ void SevensegRefresh(void) // Every second
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif // USE_DISPLAY_MODES1TO5
|
||||||
|
|
||||||
/*********************************************************************************************\
|
/*********************************************************************************************\
|
||||||
* Interface
|
* Interface
|
||||||
\*********************************************************************************************/
|
\*********************************************************************************************/
|
||||||
|
@ -286,9 +286,11 @@ bool Xdsp11(uint8_t function)
|
||||||
case FUNC_DISPLAY_CLEAR:
|
case FUNC_DISPLAY_CLEAR:
|
||||||
SevensegClear();
|
SevensegClear();
|
||||||
break;
|
break;
|
||||||
|
#ifdef USE_DISPLAY_MODES1TO5
|
||||||
case FUNC_DISPLAY_EVERY_SECOND:
|
case FUNC_DISPLAY_EVERY_SECOND:
|
||||||
SevensegRefresh();
|
SevensegRefresh();
|
||||||
break;
|
break;
|
||||||
|
#endif // USE_DISPLAY_MODES1TO5
|
||||||
case FUNC_DISPLAY_ONOFF:
|
case FUNC_DISPLAY_ONOFF:
|
||||||
case FUNC_DISPLAY_POWER:
|
case FUNC_DISPLAY_POWER:
|
||||||
SevensegOnOff();
|
SevensegOnOff();
|
||||||
|
|
Loading…
Reference in New Issue