Implemented multiple remote groups

This commit is contained in:
Kevin Veen-Birkenbach 2020-05-13 14:41:47 +02:00
parent 7a2036384c
commit e0b083276a
2 changed files with 20 additions and 15 deletions

View File

@ -36,7 +36,7 @@ String homepage_template(void){
"<div class=\"form-group row\" >" "<div class=\"form-group row\" >"
"<label for=\""+ parameter +"\" class=\"col-sm-2 col-form-label\">"+ parameter +":</label>" "<label for=\""+ parameter +"\" class=\"col-sm-2 col-form-label\">"+ parameter +":</label>"
"<div class=\"col-sm-10\" >" "<div class=\"col-sm-10\" >"
"<input type=\"" + ((parameter_type=="integer") ? String("number") : String("text")) + "\" class= \"form-control\" id=\""+ parameter +"\" value=\"" + server.arg(parameter) +"\" name=\""+ parameter +"\">" "<input type=\"" + ((parameter_type=="integer" || parameter_type=="long") ? String("number") : String("text")) + "\" class= \"form-control\" id=\""+ parameter +"\" value=\"" + server.arg(parameter) +"\" name=\""+ parameter +"\">"
"</div>" "</div>"
"</div>"; "</div>";
} }

View File

@ -20,15 +20,16 @@
/** /**
* Define constants * Define constants
*/ */
const uint16_t PIN_REMOTE_RECIEVER = 13; const uint16_t PIN_RADIO_TRANSMITTER = 13;
const uint16_t PIN_REMOTE_TRANSMITTER = 15; const uint16_t PIN_RADIO_RECIEVER = 15;
const uint16_t PIN_PIR = 14; const uint16_t PIN_PIR = 14;
const uint16_t PIN_DHT = 12; const uint16_t PIN_DHT = 12;
const uint16_t PIN_IR_RECIEVER = 2; const uint16_t PIN_IR_RECIEVER = 2;
const uint16_t PIN_IR_SEND = 4; const uint16_t PIN_IR_SEND = 4;
const uint16_t PIN_LDR = A0; const uint16_t PIN_LDR = A0;
const uint16_t PIN_ACTIVE_BUZZER = D5; const uint16_t PIN_ACTIVE_BUZZER = D5;
const unsigned long RITTER_STANDART_GROUP_ADDRESS = 13043702;
const char* PARAMETER_PLUG_ADDRESS="plug_address";
const char* PARAMETER_PLUG_ID="plug_id"; const char* PARAMETER_PLUG_ID="plug_id";
const char* PARAMETER_PLUG_STATUS="plug_enabled"; const char* PARAMETER_PLUG_STATUS="plug_enabled";
const char* PARAMETER_IR_TYPE="ir_type"; const char* PARAMETER_IR_TYPE="ir_type";
@ -36,7 +37,7 @@ const char* PARAMETER_IR_CODE="ir_code";
const char* PARAMETER_IR_BITS="ir_bits"; const char* PARAMETER_IR_BITS="ir_bits";
const char* PARAMETER_PRE_DELAY_TIME_IN_MS="pre_delay_time_in_ms"; const char* PARAMETER_PRE_DELAY_TIME_IN_MS="pre_delay_time_in_ms";
const char* PARAMETER_SOUND="sound_enabled"; const char* PARAMETER_SOUND="sound_enabled";
const char* PARAMETER_LIST[]={PARAMETER_PLUG_ID,PARAMETER_PLUG_STATUS,PARAMETER_IR_TYPE,PARAMETER_IR_CODE,PARAMETER_IR_BITS,PARAMETER_PRE_DELAY_TIME_IN_MS,PARAMETER_SOUND}; const char* PARAMETER_LIST[]={PARAMETER_PLUG_ADDRESS,PARAMETER_PLUG_ID,PARAMETER_PLUG_STATUS,PARAMETER_IR_TYPE,PARAMETER_IR_CODE,PARAMETER_IR_BITS,PARAMETER_PRE_DELAY_TIME_IN_MS,PARAMETER_SOUND};
/** /**
* Define variables * Define variables
@ -56,7 +57,6 @@ unsigned long last_recieved_radio_switchType;
*/ */
MDNSResponder mdns; MDNSResponder mdns;
ESP8266WebServer server ( 80 ); ESP8266WebServer server ( 80 );
NewRemoteTransmitter transmitter(RITTER_STANDART_GROUP_ADDRESS, PIN_REMOTE_RECIEVER);
DHT dht(PIN_DHT, DHT11); DHT dht(PIN_DHT, DHT11);
IRrecv irrecv(PIN_IR_RECIEVER); IRrecv irrecv(PIN_IR_RECIEVER);
IRsend irsend(PIN_IR_SEND); IRsend irsend(PIN_IR_SEND);
@ -83,13 +83,13 @@ void setLastRecievedRadio(unsigned int period, unsigned long address, unsigned l
/** /**
* Transmitter functions * Transmitter functions
*/ */
void sendRemoteGroupSignal(boolean state) void sendRemoteGroupSignal(boolean state, NewRemoteTransmitter transmitter)
{ {
transmitter.sendGroup(state); transmitter.sendGroup(state);
Serial.println("The state \"" + String(state,BIN) + "\" was send to the group \"" + String(RITTER_STANDART_GROUP_ADDRESS,DEC) + "\"."); Serial.println("The state \"" + String(state,BIN) + "\" was send to the group.");
} }
void sendRemoteUnitSignal(int unit, boolean state) void sendRemoteUnitSignal(int unit, boolean state, NewRemoteTransmitter transmitter)
{ {
transmitter.sendUnit(unit, state); transmitter.sendUnit(unit, state);
Serial.println("The state \"" + String(state,BIN) + "\" was send to the switch \"" + String(unit,DEC) + "\"."); Serial.println("The state \"" + String(state,BIN) + "\" was send to the switch \"" + String(unit,DEC) + "\".");
@ -138,6 +138,10 @@ String getParameterType(const char* parameter){
return "integer"; return "integer";
} }
if(parameter==PARAMETER_PLUG_ADDRESS){
return "long";
}
if( if(
parameter==PARAMETER_SOUND || parameter==PARAMETER_SOUND ||
parameter==PARAMETER_PLUG_STATUS parameter==PARAMETER_PLUG_STATUS
@ -153,11 +157,12 @@ void controller(void){
sendIrCode(static_cast<decode_type_t>(server.arg(PARAMETER_IR_TYPE).toInt()),server.arg(PARAMETER_IR_CODE).toInt(),server.arg(PARAMETER_IR_BITS).toInt()); sendIrCode(static_cast<decode_type_t>(server.arg(PARAMETER_IR_TYPE).toInt()),server.arg(PARAMETER_IR_CODE).toInt(),server.arg(PARAMETER_IR_BITS).toInt());
} }
if(isParameterDefined(PARAMETER_PLUG_ID)){ if(isParameterDefined(PARAMETER_PLUG_ID)){
if(server.arg(PARAMETER_PLUG_ID).equals("0")){ NewRemoteTransmitter transmitter(server.arg(PARAMETER_PLUG_ADDRESS).toInt(), PIN_RADIO_TRANSMITTER);
sendRemoteGroupSignal(server.arg(PARAMETER_PLUG_STATUS).equals("on")); if(server.arg(PARAMETER_PLUG_ID).equals("0")){
}else if(server.arg(PARAMETER_PLUG_ID).toInt()>0){ sendRemoteGroupSignal(server.arg(PARAMETER_PLUG_STATUS).equals("on"),transmitter);
sendRemoteUnitSignal(server.arg(PARAMETER_PLUG_ID).toInt(),server.arg(PARAMETER_PLUG_STATUS).equals("on")); }else if(server.arg(PARAMETER_PLUG_ID).toInt()>0){
} sendRemoteUnitSignal(server.arg(PARAMETER_PLUG_ID).toInt(),server.arg(PARAMETER_PLUG_STATUS).equals("on"),transmitter);
}
} }
} }
@ -226,7 +231,7 @@ void setup(void)
Serial.println("Enable PIR."); Serial.println("Enable PIR.");
pinMode(PIN_PIR, INPUT); pinMode(PIN_PIR, INPUT);
Serial.println("Enable remote transmitter."); Serial.println("Enable remote transmitter.");
NewRemoteReceiver::init(PIN_REMOTE_TRANSMITTER, 1, setLastRecievedRadio); NewRemoteReceiver::init(PIN_RADIO_RECIEVER, 1, setLastRecievedRadio);
Serial.println("Enable IR-reciever."); Serial.println("Enable IR-reciever.");
irrecv.enableIRIn(); irrecv.enableIRIn();
Serial.println("Enable IR-sender."); Serial.println("Enable IR-sender.");