Merge remote-tracking branch 'Tasmota/development' into development

This commit is contained in:
Jason2866 2020-05-25 17:26:25 +02:00
commit 27193d8903
11 changed files with 287 additions and 248 deletions

View File

@ -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

View File

@ -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;

View File

@ -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;

View File

@ -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

View File

@ -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

View File

@ -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());
} }

View File

@ -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 {

View File

@ -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)) {

View File

@ -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

View File

@ -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());
} }

View File

@ -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();