Compare commits

...

3 Commits

Author SHA1 Message Date
Gerardo 809b2e6d64 arreglos varios y configuraciones 2024-10-01 22:17:01 +02:00
Gerardo 07a0f53eb8 añadida clase timer 2024-10-01 09:41:27 +02:00
Gerardo 6dfafd1390 evitar efecto rebote 2024-10-01 09:19:01 +02:00
11 changed files with 157 additions and 31 deletions

View File

@ -48,17 +48,17 @@ class AutomatismoPresencia//automatismo para encender luz con presencia
Actuador presenciaOn;
Actuador presenciaOff;
Actuador nivelLuzOff;
//Actuador nivelLuzOff;
float fnivelLuz;
public:
AutomatismoPresencia()
{
fnivelLuz=50;
fnivelLuz=40;
strcpy(presenciaOn.id, "PresOn");
strcpy(presenciaOff.id, "PresOff");
strcpy(nivelLuzOff.id, "luzOff");
//strcpy(nivelLuzOff.id, "luzOff");
}
@ -81,7 +81,7 @@ class AutomatismoPresencia//automatismo para encender luz con presencia
{
presenciaOff.AddActivador(bloqueo,'>',0);
}
/*
nivelLuzOff.set(nivelluz->topic, out->topic, "0");
nivelLuzOff.AddActivador(out,'>',0, 0);//out encendido
nivelLuzOff.AddActivador(nivelluz,'>',fnivelLuz, 0);//no luz
@ -89,10 +89,10 @@ class AutomatismoPresencia//automatismo para encender luz con presencia
{
nivelLuzOff.AddActivador(bloqueo,'>',0);
}
*/
man->Add(&presenciaOn);
man->Add(&nivelLuzOff);
//man->Add(&nivelLuzOff);
man->Add(&presenciaOff);

View File

@ -9,12 +9,11 @@ DomoEspManager::DomoEspManager()
n=0;
tiempo=0;
suscrito=false;
tiempo_sens=0;
SetTimeRefres(15);
}
void DomoEspManager::SetTimeRefres(int seg)
{
incre_tsens=seg*1000;
timer.set(seg);
}
void DomoEspManager::inicia(DomoEspConfig* cnf)
{
@ -70,7 +69,7 @@ void DomoEspManager::loop()
suscrito=true;
}
int tiempoAux=0;
if(MqttUtiles::pasa_incre(&tiempo_sens, incre_tsens))
if(timer.onTimerReset())
{
tiempo=(tiempo+1)%2;

View File

@ -26,8 +26,7 @@ class DomoEspManager: public MqttReceiver, public IMqttManager, public ISensorMa
int n;
int tiempo;
bool suscrito;
unsigned long tiempo_sens;
unsigned long incre_tsens;
Ctimer timer;
public:

View File

@ -6,16 +6,19 @@ class SensorDin: public DomoEspSensorReceiver
{
bool val;
uint8_t pin;
bool logTiempo2;
public:
virtual float getVal()
{
return (float)val;
}
SensorDin(){}
void set(uint8_t _pin, char* topic_id)
SensorDin(){
logTiempo2=true;
}
void set(uint8_t _pin, char* topic_id, bool _logTiempo2=true)
{
logTiempo2=_logTiempo2;
pin=_pin;
val=0;
strcpy(topic, topic_id);
@ -25,7 +28,7 @@ class SensorDin: public DomoEspSensorReceiver
//mirar para configurar por interrupcion
int val_ac=digitalRead(pin);
if(tiempo==2 || val_ac!=val)
if((logTiempo2 && tiempo==2) || val_ac!=val)
{
val=val_ac;
//loguea------------

View File

@ -66,7 +66,7 @@ bool negado;
val=!val;
else
val=(atoi(payload)==1);
//cambia estado relle
//cambia estado relleH
if(negado)
digitalWrite(pin, val==0);
else

View File

@ -7,14 +7,19 @@ class SensorPulsante: public DomoEspSensorReceiver
bool val;
bool valDef;
uint8_t pin;
unsigned long tiempo_sens;
unsigned long incre_tsens;
bool espera;
public:
virtual float getVal()
{
return (float)val;
}
SensorPulsante()
{}
{
espera=false;
incre_tsens=500;
}
void set(uint8_t _pin, char* topic_id, bool _valDef)
{
pin=_pin;
@ -22,10 +27,21 @@ class SensorPulsante: public DomoEspSensorReceiver
val=valDef;
strcpy(topic, topic_id);
}
void setIncremento(int milis)
{
incre_tsens=milis;
}
virtual void procesa(IMqttManager * man, int tiempo)
{
//mirar para configurar por interrupcion
int val_ac=digitalRead(pin);
int val_ac=val;
if(!espera || MqttUtiles::pasa_incre(&tiempo_sens, incre_tsens))
{
val_ac=digitalRead(pin);
espera=false;
}
if(val_ac!=val && val_ac!=valDef)
{
@ -36,7 +52,10 @@ class SensorPulsante: public DomoEspSensorReceiver
sprintf(buffer_p, "%d", (int)val_ac);
sprintf(buffer_t, "%s/pul",topic);
man->MqttSend(buffer_t, buffer_p);
delay(100);
//delay(100);
MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
espera=true;
}
val=val_ac;
}

View File

@ -6,8 +6,7 @@ class SensorTimer: public DomoEspSensorReceiver
{
bool val;
bool valDef;
unsigned long tiempo_sens;
unsigned long incre_tsens;
Ctimer t;
public:
SensorTimer()
@ -17,8 +16,7 @@ class SensorTimer: public DomoEspSensorReceiver
}
void set(char* topic_id, bool _valdef, int segTime)
{
incre_tsens=1000*segTime;
t.set(segTime);
valDef=_valdef;
val=valDef;
strcpy(topic, topic_id);
@ -31,7 +29,7 @@ class SensorTimer: public DomoEspSensorReceiver
{
if(val!=valDef)
{
if(MqttUtiles::pasa_incre(&tiempo_sens, incre_tsens))
if(t.onTimer())
{
val=valDef;
tiempo=2;
@ -70,8 +68,8 @@ class SensorTimer: public DomoEspSensorReceiver
val=1;
else
val=0;
MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
t.inicia();
//MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
}
else if(tipo==Topic::SET)
{
@ -80,7 +78,8 @@ class SensorTimer: public DomoEspSensorReceiver
else
val=atof(payload);
if(val!=valDef)
MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
t.inicia();
//MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
}
if(valOld!=val)

View File

@ -12,7 +12,7 @@ class SensorVF: public DomoEspSensorReceiver
val=0;
topic[0]=0;
}
void set(char* topic_id, float valdef)
void set(char* topic_id, float valdef=0)
{
val=valdef;
strcpy(topic, topic_id);

View File

@ -47,7 +47,43 @@ void MqttUtiles::resetFunc()
ESP.wdtEnable(1);
while(1){};
}
//**************************************************************************************************************************************************
Ctimer::Ctimer()
{
t=0;
}
void Ctimer::set(int incremento_seg)
{
incre=1000*incremento_seg;
}
void Ctimer::inicia()
{
t=millis();
}
bool Ctimer::onTimer()
{
unsigned long ta=millis();
if(ta<t)
return true;
if((t+incre)>=ta)
return false;
return true;
}
bool Ctimer::onTimerReset()
{
unsigned long ta=millis();
if(ta<t)
{
t=ta;
return true;
}
if((t+incre)>=ta)
return false;
t=ta;
return true;
}
//**************************************************************************************************************************************************
WifiManager::WifiManager()
{

View File

@ -13,6 +13,20 @@ class MqttUtiles
static void resetFunc();
};
class Ctimer
{
unsigned long t;
unsigned long incre;
public:
Ctimer();
void set(int incremento_seg);
void inicia();//inicia contador de incremento
bool onTimer();//devuelve true si ha pasado el tiempo
bool onTimerReset();//pasa incremento y si ha pasado se reinicia
};
class MqttOnVarChangeListenner
{
public:

View File

@ -130,6 +130,63 @@ class ConfActual: public DomoEspConfig
}
};
class ConfCocina: public DomoEspConfig
{
SensorDHT dht;
SensorAin luz;
SensorDout lampara;
SensorPulsante presencia;
SensorTimer tpresencia;
SensorDin interruptor;
SensorVF enable;
AutomatismoPresencia actuador;
AutomatismoPulsador actuadorPul;
Actuador actp1;
public:
ConfCocina()
{
strcpy(ssidWifi,"Idhun");//nombre wifi
strcpy(ideEsp,"Esp8266_cocina");//idenitificador del esp (sera único)
/*
int cociMov= vars->AddInternalVarInt( "casa/cocina/mov");
int cociLuz= vars->AddInternalVarInt( "casa/cocina/luz");
int cociLam= vars->AddInternalVarInt( "casa/cocina/lam");
int cociAuto= vars->AddInternalVarInt("casa/cocina/luzAuto");
*/
dht.set(D4,"casa/cocina");
luz.set(0, "casa/cocina/luz",1,0);
lampara.set(D2, "casa/cocina/lam",0,0);
presencia.set(D5, "casa/cocina/movPul",0);
tpresencia.set("casa/cocina/mov",0, 60);
enable.set("casa/cocina/luzAuto");
interruptor.set( D1, "casa/cocina/inter", false);
actp1.set("casa/cocina/movPul", "casa/cocina/mov","1");
}
virtual void inicia(ISensorManager* man)
{
man->Add(&dht);
man->Add(&luz);
man->Add(&lampara);
man->Add(&presencia);
man->Add(&tpresencia);
man->Add(&enable);
man->Add(&interruptor);
man->Add(&actp1);
actuadorPul.inicia(man, &interruptor, &lampara);
actuador.inicia(man, &tpresencia, &luz, &lampara, &enable);
}
};
@ -203,7 +260,7 @@ class ConfigSalon: public DomoEspConfig
strcpy(ideEsp,"Esp8266_Salon");//idenitificador del esp (sera único)
dht.set(D4, "casa/Salon");
nivelLuz.set(0,"casa/Salon/luz",1, 0);
nivelLuz.set(0,"casa/Salon/luz",0, 0);
presencia.set(D5, "casa/Salon/movEven");
presenciaTimer.set("casa/Salon/mov",0,60);
actTimer.set("casa/Salon/movEven", "casa/Salon/mov","1");
@ -321,6 +378,6 @@ class ConfPulSalon: public DomoEspConfig
ConfPulSalon ConfiguracionActual;
ConfigSalon ConfiguracionActual;
#endif