mirror of
https://github.com/kevinveenbirkenbach/physical-interface.git
synced 2024-11-14 14:21:04 +01:00
Implemented setSound
This commit is contained in:
parent
6a81630826
commit
95e4889c73
@ -24,20 +24,22 @@
|
|||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
|
||||||
// Define Constants
|
// Define Constants
|
||||||
const int pin_ritter = 13;
|
const uint16_t pin_ritter = 13;
|
||||||
const int pin_pir = 14;
|
const uint16_t pin_pir = 14;
|
||||||
const int pin_tmp = 12;
|
const uint16_t pin_tmp = 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 unsigned long ritter_group_address = 13043702;
|
const unsigned long ritter_group_address = 13043702;
|
||||||
const char* parameter_plug_id="plug_id";
|
const char* parameter_plug_id="plug_id";
|
||||||
const char* parameter_plug_status="plug_status";
|
const char* parameter_plug_status="plug_status";
|
||||||
const char* parameter_ir_type="ir_type";
|
const char* parameter_ir_type="ir_type";
|
||||||
const char* parameter_ir_data="ir_data";
|
const char* parameter_ir_data="ir_code";
|
||||||
const char* parameter_ir_bits="ir_bits";
|
const char* parameter_ir_bits="ir_bits";
|
||||||
const char* parameter_delay_time_in_ms="delay_time_in_ms";
|
const char* parameter_delay_time_in_ms="delay_time_in_ms";
|
||||||
const char* parameter_list[]={parameter_plug_id,parameter_plug_status,parameter_ir_type,parameter_ir_data,parameter_ir_bits,parameter_delay_time_in_ms};
|
const char* parameter_sound_time_in_ms="sound_time_in_ms";
|
||||||
|
const char* parameter_list[]={parameter_plug_id,parameter_plug_status,parameter_ir_type,parameter_ir_data,parameter_ir_bits,parameter_delay_time_in_ms,parameter_sound_time_in_ms};
|
||||||
|
|
||||||
// Define variables
|
// Define variables
|
||||||
decode_results results;
|
decode_results results;
|
||||||
@ -53,39 +55,6 @@ DHT dht(pin_tmp, DHT11);
|
|||||||
IRrecv irrecv(pin_ir_reciever);
|
IRrecv irrecv(pin_ir_reciever);
|
||||||
IRsend irsend(pin_ir_send);
|
IRsend irsend(pin_ir_send);
|
||||||
|
|
||||||
/**
|
|
||||||
* Associative Arrays aren't possible in C++ because of Memory.
|
|
||||||
* For this reason it's necessary to implement the function like this.
|
|
||||||
* If you get the return value "UNKNOWN", adapt the return values to the ones in decode_type_t defined in IRremoteESP8266.h
|
|
||||||
**/
|
|
||||||
String getDecodeType(decode_type_t decode_type){
|
|
||||||
switch(decode_type){
|
|
||||||
case NEC:
|
|
||||||
return String("NEC");
|
|
||||||
case SONY:
|
|
||||||
return String("SONY");
|
|
||||||
case RC5:
|
|
||||||
return String("RC5");
|
|
||||||
case RC5X:
|
|
||||||
return String("RC5X");
|
|
||||||
case RC6:
|
|
||||||
return String("RC6");
|
|
||||||
case RCMM:
|
|
||||||
return String("RCMM");
|
|
||||||
case PANASONIC:
|
|
||||||
return String("PANASONIC");
|
|
||||||
case LG:
|
|
||||||
return String("LG");
|
|
||||||
case JVC:
|
|
||||||
return String("JVC");
|
|
||||||
case AIWA_RC_T501:
|
|
||||||
return String("AIWA_RC_T501");
|
|
||||||
case WHYNTER:
|
|
||||||
return String("WHYNTER");
|
|
||||||
}
|
|
||||||
return String("UNKNOWN");
|
|
||||||
}
|
|
||||||
|
|
||||||
void dump(decode_results *results) {
|
void dump(decode_results *results) {
|
||||||
last_recieved_ir_type = results->decode_type;
|
last_recieved_ir_type = results->decode_type;
|
||||||
last_recieved_ir_data = results->value;
|
last_recieved_ir_data = results->value;
|
||||||
@ -97,19 +66,28 @@ void dump(decode_results *results) {
|
|||||||
void setRitterGroup(int state)
|
void setRitterGroup(int state)
|
||||||
{
|
{
|
||||||
transmitter.sendGroup(state);
|
transmitter.sendGroup(state);
|
||||||
Serial.print("The state \"" + String(state,BIN) + "\" was send to the group \"" + String(ritter_group_address,DEC) + "\".");
|
Serial.println("The state \"" + String(state,BIN) + "\" was send to the group \"" + String(ritter_group_address,DEC) + "\".");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Switchs one plug on
|
// Switchs one plug on
|
||||||
void setRitterSwitch(int unit, int state)
|
void setRitterSwitch(int unit, int state)
|
||||||
{
|
{
|
||||||
transmitter.sendUnit(unit, state);
|
transmitter.sendUnit(unit, state);
|
||||||
Serial.print("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) + "\".");
|
||||||
}
|
}
|
||||||
|
|
||||||
void setIrColor(decode_type_t type,uint32_t code, uint16_t bits) {
|
void setIrColor(decode_type_t type,uint32_t code, uint16_t bits) {
|
||||||
irsend.send(type, code, bits);
|
irsend.send(type, code, bits);
|
||||||
Serial.print("The code \"" + String(code) + "\" with \"" + String(bits) + "\" bits was send in format \"" + getDecodeType(type) + "\".");
|
Serial.println("The code \"" + String(code) + "\" with \"" + String(bits) + "\" bits was send in format \"" + String(type) + "\".");
|
||||||
|
}
|
||||||
|
|
||||||
|
void setSound(int time_in_ms){
|
||||||
|
Serial.println("Making sound for \"" + String(time_in_ms) + "ms.");
|
||||||
|
pinMode(pin_active_buzzer,OUTPUT);
|
||||||
|
digitalWrite(pin_active_buzzer,LOW);
|
||||||
|
delay(time_in_ms);
|
||||||
|
digitalWrite(pin_active_buzzer,HIGH);
|
||||||
|
pinMode(pin_active_buzzer,INPUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool isParameterDefined(String parameter_name){
|
bool isParameterDefined(String parameter_name){
|
||||||
@ -122,6 +100,9 @@ bool isParameterDefined(String parameter_name){
|
|||||||
}
|
}
|
||||||
|
|
||||||
void controller(void){
|
void controller(void){
|
||||||
|
if(isParameterDefined(parameter_sound_time_in_ms)){
|
||||||
|
setSound(server.arg(parameter_sound_time_in_ms).toInt());
|
||||||
|
}
|
||||||
if(isParameterDefined(parameter_ir_type) && isParameterDefined(parameter_ir_data) && isParameterDefined(parameter_ir_bits)){
|
if(isParameterDefined(parameter_ir_type) && isParameterDefined(parameter_ir_data) && isParameterDefined(parameter_ir_bits)){
|
||||||
setIrColor(static_cast<decode_type_t>(server.arg(parameter_ir_type).toInt()),server.arg(parameter_ir_data).toInt(),server.arg(parameter_ir_bits).toInt());
|
setIrColor(static_cast<decode_type_t>(server.arg(parameter_ir_type).toInt()),server.arg(parameter_ir_data).toInt(),server.arg(parameter_ir_bits).toInt());
|
||||||
}
|
}
|
||||||
@ -192,6 +173,8 @@ void setup(void)
|
|||||||
irrecv.enableIRIn();
|
irrecv.enableIRIn();
|
||||||
Serial.println("Enable IR-sender.");
|
Serial.println("Enable IR-sender.");
|
||||||
irsend.begin();
|
irsend.begin();
|
||||||
|
Serial.println("Activate active buzzer.");
|
||||||
|
setSound(1);
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
Serial.println("Started program.");
|
Serial.println("Started program.");
|
||||||
//WiFi.softAPdisconnect(true);
|
//WiFi.softAPdisconnect(true);
|
||||||
@ -204,7 +187,7 @@ void setup(void)
|
|||||||
Serial.print("IP address: ");
|
Serial.print("IP address: ");
|
||||||
Serial.println(WiFi.localIP());
|
Serial.println(WiFi.localIP());
|
||||||
if (mdns.begin(hostname, WiFi.localIP())) {
|
if (mdns.begin(hostname, WiFi.localIP())) {
|
||||||
Serial.println("MDNS responder started.");
|
Serial.println("MDNS responder started. Using \"" + String(hostname) + "\" as hostname.");
|
||||||
}
|
}
|
||||||
server.onNotFound(handleRequest);
|
server.onNotFound(handleRequest);
|
||||||
server.begin();
|
server.begin();
|
||||||
|
Loading…
Reference in New Issue
Block a user