reestructura proyecto: codigo antiguo a rama old
This commit is contained in:
parent
db4800b8c8
commit
d31ad074f8
@ -1,100 +0,0 @@
|
||||
#include <Servo.h>
|
||||
#include <RTClib.h>
|
||||
|
||||
Servo myservo_X;
|
||||
RTC_DS3231 reloj;
|
||||
|
||||
volatile DateTime fecha;
|
||||
unsigned long intervalo_loop=5000;
|
||||
unsigned long previoMillisTermo=0;
|
||||
unsigned long previoMillisLoop=0;
|
||||
unsigned long actualMillis;
|
||||
byte horaON = 5;
|
||||
byte horaOFF = 7;
|
||||
byte cont=0;
|
||||
bool estado_termo;
|
||||
bool espera;
|
||||
bool start;
|
||||
|
||||
void setup() {
|
||||
myservo_X.attach(9);
|
||||
Serial.begin(115200);
|
||||
reloj.begin();
|
||||
start=1;
|
||||
estado_termo = 0;
|
||||
}
|
||||
//reloj.adjust(DateTime(__DATE__, __TIME__));
|
||||
|
||||
void loop() {
|
||||
if(start) {
|
||||
myservo_X.write(30);
|
||||
start=0;
|
||||
fecha = reloj.now();
|
||||
printFecha();
|
||||
}
|
||||
actualMillis = millis();
|
||||
if ((unsigned long)(actualMillis - previoMillisLoop) >= intervalo_loop) {
|
||||
fecha = reloj.now();
|
||||
if((fecha.hour() >= horaON) && (fecha.hour() < horaOFF) && (estado_termo == 0)) {
|
||||
termoON();
|
||||
} else if(((fecha.hour() < horaON) || (fecha.hour() >= horaOFF)) && (estado_termo == 1)) {
|
||||
termoOFF();
|
||||
}
|
||||
previoMillisLoop = millis();
|
||||
}
|
||||
}
|
||||
|
||||
// Secuencia de encendido y apagado de Caldera
|
||||
void termoON() {
|
||||
myservo_X.write(120);
|
||||
espera = 0;
|
||||
cont = 0;
|
||||
previoMillisTermo = millis();
|
||||
do{
|
||||
actualMillis = millis();
|
||||
if(espera == 0) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(110);
|
||||
previoMillisTermo = millis();
|
||||
espera = 1;
|
||||
cont++;
|
||||
}
|
||||
}
|
||||
if(espera == 1) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(120);
|
||||
previoMillisTermo = millis();
|
||||
espera = 0;
|
||||
cont++;
|
||||
}
|
||||
}
|
||||
} while (cont < 4);
|
||||
estado_termo = 1;
|
||||
}
|
||||
|
||||
void termoOFF() {
|
||||
myservo_X.write(45);
|
||||
espera = 0;
|
||||
cont = 0;
|
||||
previoMillisTermo = millis();
|
||||
do{
|
||||
actualMillis = millis();
|
||||
if(espera == 0) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(62);
|
||||
previoMillisTermo = millis();
|
||||
espera = 1;
|
||||
cont++;
|
||||
}
|
||||
}
|
||||
if(espera == 1) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(45);
|
||||
previoMillisTermo = millis();
|
||||
espera = 0;
|
||||
cont++;
|
||||
}
|
||||
}
|
||||
} while (cont < 4);
|
||||
estado_termo = 0;
|
||||
}
|
@ -1,181 +0,0 @@
|
||||
#include <Servo.h>
|
||||
#include <RTClib.h>
|
||||
|
||||
Servo myservo_X;
|
||||
RTC_DS3231 reloj;
|
||||
|
||||
volatile DateTime fecha;
|
||||
unsigned long intervalo_loop=5000;
|
||||
unsigned long previoMillisTermo=0;
|
||||
unsigned long previoMillisLoop=0;
|
||||
unsigned long actualMillis;
|
||||
byte horaON = 5;
|
||||
byte horaOFF = 35;
|
||||
byte cont=0;
|
||||
bool estado_termo;
|
||||
bool espera;
|
||||
bool start;
|
||||
|
||||
void setup() {
|
||||
myservo_X.attach(9);
|
||||
Serial.begin(115200); // COMENTAR ******
|
||||
reloj.begin();
|
||||
start=1;
|
||||
estado_termo = 0;
|
||||
}
|
||||
//reloj.adjust(DateTime(__DATE__, __TIME__));
|
||||
|
||||
void loop() {
|
||||
if(start) {
|
||||
myservo_X.write(30);
|
||||
Serial.print("Servo a CERO");
|
||||
start=0;
|
||||
}
|
||||
actualMillis = millis();
|
||||
if ((unsigned long)(actualMillis - previoMillisLoop) >= intervalo_loop) {
|
||||
Serial.println("LOOP"); // COMENTAR ******
|
||||
Serial.println("Consulta RTC"); // COMENTAR ******
|
||||
fecha = reloj.now(); // COMENTAR ******
|
||||
mostrarFechaSerie(); // COMENTAR ******
|
||||
Serial.print("Estado Termo en LOOP = ");
|
||||
Serial.println(estado_termo);
|
||||
if((fecha.second() >= horaON) && (fecha.second() < horaOFF) && (estado_termo == 0)) {
|
||||
termoON();
|
||||
Serial.print("Termo = ");
|
||||
Serial.println(estado_termo);
|
||||
} else if(((fecha.second() < horaON) || (fecha.second() >= horaOFF)) && (estado_termo == 1)) {
|
||||
termoOFF();
|
||||
Serial.print("Termo = ");
|
||||
Serial.println(estado_termo);
|
||||
}
|
||||
previoMillisLoop = millis();
|
||||
}
|
||||
}
|
||||
|
||||
// Secuencia de encendido y apagado de Caldera
|
||||
void termoON() {
|
||||
Serial.println("termoON() :");
|
||||
myservo_X.write(120);
|
||||
Serial.println(" S120 ");
|
||||
espera = 0;
|
||||
cont = 0;
|
||||
previoMillisTermo = millis();
|
||||
Serial.print("do while -> contador y posicion servo : ");
|
||||
do{
|
||||
actualMillis = millis();
|
||||
if(espera == 0) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(110);
|
||||
previoMillisTermo = millis();
|
||||
espera = 1;
|
||||
cont++;
|
||||
Serial.print(" Servo=110 - cont=");
|
||||
Serial.print(cont);
|
||||
}
|
||||
}
|
||||
if(espera == 1) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(120);
|
||||
previoMillisTermo = millis();
|
||||
espera = 0;
|
||||
cont++;
|
||||
Serial.print(" Servo=120 - cont=");
|
||||
Serial.print(cont);
|
||||
}
|
||||
}
|
||||
} while (cont < 4);
|
||||
Serial.println("");
|
||||
estado_termo = 1;
|
||||
}
|
||||
|
||||
void termoOFF() {
|
||||
Serial.println("termoOFF() :");
|
||||
myservo_X.write(45);
|
||||
Serial.println(" S45 ");
|
||||
espera = 0;
|
||||
cont = 0;
|
||||
previoMillisTermo = millis();
|
||||
Serial.print("do while -> contador y posicion servo : ");
|
||||
do{
|
||||
actualMillis = millis();
|
||||
if(espera == 0) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(62);
|
||||
previoMillisTermo = millis();
|
||||
espera = 1;
|
||||
cont++;
|
||||
Serial.print(" Servo=62 - cont=");
|
||||
Serial.print(cont);
|
||||
}
|
||||
}
|
||||
if(espera == 1) {
|
||||
if ((unsigned long)(actualMillis - previoMillisTermo) >= 500) {
|
||||
myservo_X.write(45);
|
||||
previoMillisTermo = millis();
|
||||
espera = 0;
|
||||
cont++;
|
||||
Serial.print(" Servo=145 - cont=");
|
||||
Serial.print(cont);
|
||||
}
|
||||
}
|
||||
} while (cont < 4);
|
||||
Serial.println("");
|
||||
estado_termo = 0;
|
||||
}
|
||||
|
||||
//En caso de ser necesario mostrar hora, este codigo añade un 0 a los valores menores a 10
|
||||
String getHora(char var) {
|
||||
switch (var) {
|
||||
case 'h':
|
||||
if(fecha.hour() < 10) {
|
||||
return ('0'+(String)fecha.hour()); break;
|
||||
} else {
|
||||
return (String)fecha.hour();break;
|
||||
}
|
||||
case 'm':
|
||||
if(fecha.minute() <10) {
|
||||
return ('0'+(String)fecha.minute()); break;
|
||||
} else {
|
||||
return (String)fecha.minute();break;
|
||||
}
|
||||
case 's':
|
||||
if(fecha.second() <10) {
|
||||
return ('0'+(String)fecha.second()); break;
|
||||
} else {
|
||||
return (String)fecha.second();break;
|
||||
}
|
||||
case 'd':
|
||||
if(fecha.day() <10) {
|
||||
return ('0'+(String)fecha.day()); break;
|
||||
} else {
|
||||
return (String)fecha.day();break;
|
||||
}
|
||||
case 'n':
|
||||
if(fecha.month() <10) {
|
||||
return ('0'+(String)fecha.month()); break;
|
||||
} else {
|
||||
return (String)fecha.month();break;
|
||||
}
|
||||
case 'a':
|
||||
if(fecha.year() <10) {
|
||||
return ('0'+(String)fecha.year()); break;
|
||||
} else {
|
||||
return (String)fecha.year();break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Enviar hora y fecha por puerto serie
|
||||
void mostrarFechaSerie() {
|
||||
Serial.print(getHora('d'));
|
||||
Serial.print("/");
|
||||
Serial.print(getHora('n'));
|
||||
Serial.print("/");
|
||||
Serial.print(getHora('a'));
|
||||
Serial.print(" ");
|
||||
Serial.print(getHora('h'));
|
||||
Serial.print(":");
|
||||
Serial.print(getHora('m'));
|
||||
Serial.print(":");
|
||||
Serial.println(getHora('s'));
|
||||
}
|
Loading…
Reference in New Issue
Block a user