Compare commits

..

No commits in common. "809b2e6d6496e8f2e733af84fb5c181b5523404a" and "519b95a0f918b5b5b92bdc7f2ff20ce96455c30b" have entirely different histories.

11 changed files with 31 additions and 157 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=40;
fnivelLuz=50;
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,11 +9,12 @@ DomoEspManager::DomoEspManager()
n=0;
tiempo=0;
suscrito=false;
tiempo_sens=0;
SetTimeRefres(15);
}
void DomoEspManager::SetTimeRefres(int seg)
{
timer.set(seg);
incre_tsens=seg*1000;
}
void DomoEspManager::inicia(DomoEspConfig* cnf)
{
@ -69,7 +70,7 @@ void DomoEspManager::loop()
suscrito=true;
}
int tiempoAux=0;
if(timer.onTimerReset())
if(MqttUtiles::pasa_incre(&tiempo_sens, incre_tsens))
{
tiempo=(tiempo+1)%2;

View File

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

View File

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

View File

@ -7,19 +7,14 @@ 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;
@ -27,21 +22,10 @@ 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=val;
if(!espera || MqttUtiles::pasa_incre(&tiempo_sens, incre_tsens))
{
val_ac=digitalRead(pin);
espera=false;
}
int val_ac=digitalRead(pin);
if(val_ac!=val && val_ac!=valDef)
{
@ -52,10 +36,7 @@ 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);
MqttUtiles::reinicia_incre(&tiempo_sens, incre_tsens);
espera=true;
delay(100);
}
val=val_ac;
}

View File

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

View File

@ -47,43 +47,7 @@ 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,20 +13,6 @@ 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,63 +130,6 @@ 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);
}
};
@ -260,7 +203,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",0, 0);
nivelLuz.set(0,"casa/Salon/luz",1, 0);
presencia.set(D5, "casa/Salon/movEven");
presenciaTimer.set("casa/Salon/mov",0,60);
actTimer.set("casa/Salon/movEven", "casa/Salon/mov","1");
@ -378,6 +321,6 @@ class ConfPulSalon: public DomoEspConfig
ConfigSalon ConfiguracionActual;
ConfPulSalon ConfiguracionActual;
#endif