cleanup and adding touchless disinfection code
This commit is contained in:
parent
a4247005b6
commit
a912c0fc68
44
touchless_disinfection/touchless_disinfection.ino
Normal file
44
touchless_disinfection/touchless_disinfection.ino
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
const int US_sensorPin = 7;
|
||||||
|
const int relayPin = 10;
|
||||||
|
const int range = 8; //Range of detection from the sensor in cm
|
||||||
|
|
||||||
|
bool newAction;
|
||||||
|
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
Serial.begin (9600); //Allows serial output to serial monitor
|
||||||
|
pinMode(relayPin, OUTPUT);
|
||||||
|
digitalWrite(relayPin, LOW); // Default relay should be OFF!
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
long duration, cm;
|
||||||
|
pinMode(US_sensorPin, OUTPUT);
|
||||||
|
digitalWrite(US_sensorPin, LOW);
|
||||||
|
delayMicroseconds(2);
|
||||||
|
digitalWrite(US_sensorPin, HIGH);
|
||||||
|
delayMicroseconds(5);
|
||||||
|
digitalWrite(US_sensorPin, LOW);
|
||||||
|
pinMode(US_sensorPin, INPUT);
|
||||||
|
duration = pulseIn(US_sensorPin, HIGH);
|
||||||
|
|
||||||
|
cm = microsecondsToCentimeters(duration);
|
||||||
|
|
||||||
|
if (cm < range && cm > 1) {
|
||||||
|
|
||||||
|
if (newAction) {
|
||||||
|
digitalWrite(relayPin, HIGH); // Turn Ralay ON
|
||||||
|
delay(50); // Miliseconds which it waits before turn off again
|
||||||
|
digitalWrite(relayPin,LOW); // Trun Ralay OFF
|
||||||
|
newAction = false;
|
||||||
|
}
|
||||||
|
delay(1000); // Miliseconds which it waits before does any action again
|
||||||
|
|
||||||
|
} else {
|
||||||
|
newAction = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
long microsecondsToCentimeters(long microseconds) {
|
||||||
|
return microseconds / 29 / 2;
|
||||||
|
}
|
@ -3,8 +3,10 @@ const int relayPin = 10;
|
|||||||
const int range = 8; //Range of detection from the sensor in cm
|
const int range = 8; //Range of detection from the sensor in cm
|
||||||
int valRelay = 0; // variable to store the read value
|
int valRelay = 0; // variable to store the read value
|
||||||
long relayAction;
|
long relayAction;
|
||||||
|
bool newAction;
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
|
Serial.begin (9600); //Allows serial output to serial monitor
|
||||||
pinMode(relayPin, OUTPUT);
|
pinMode(relayPin, OUTPUT);
|
||||||
digitalWrite(relayPin, HIGH); // Default relay should be OFF!
|
digitalWrite(relayPin, HIGH); // Default relay should be OFF!
|
||||||
}
|
}
|
||||||
@ -12,45 +14,36 @@ void setup() {
|
|||||||
void loop() {
|
void loop() {
|
||||||
long duration, cm;
|
long duration, cm;
|
||||||
pinMode(US_sensorPin, OUTPUT);
|
pinMode(US_sensorPin, OUTPUT);
|
||||||
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
digitalWrite(US_sensorPin, LOW);
|
||||||
delayMicroseconds(2);
|
delayMicroseconds(2);
|
||||||
digitalWrite(US_sensorPin, HIGH);
|
digitalWrite(US_sensorPin, HIGH);
|
||||||
delayMicroseconds(5);
|
delayMicroseconds(5);
|
||||||
digitalWrite(US_sensorPin, LOW);
|
digitalWrite(US_sensorPin, LOW);
|
||||||
|
|
||||||
pinMode(US_sensorPin, INPUT);
|
pinMode(US_sensorPin, INPUT);
|
||||||
duration = pulseIn(US_sensorPin, HIGH);
|
duration = pulseIn(US_sensorPin, HIGH);
|
||||||
|
|
||||||
cm = microsecondsToCentimeters(duration);
|
cm = microsecondsToCentimeters(duration);
|
||||||
|
|
||||||
if (cm < range && cm > 1) {
|
if (cm < range && cm > 1) {
|
||||||
long new_duration, new_cm;
|
|
||||||
pinMode(US_sensorPin, OUTPUT);
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
delayMicroseconds(2);
|
|
||||||
digitalWrite(US_sensorPin, HIGH);
|
|
||||||
delayMicroseconds(5);
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
pinMode(US_sensorPin, INPUT);
|
|
||||||
new_duration = pulseIn(US_sensorPin, HIGH);
|
|
||||||
|
|
||||||
new_cm = microsecondsToCentimeters(new_duration);
|
if (newAction) {
|
||||||
|
valRelay = digitalRead(relayPin); // read the status of input pin
|
||||||
|
if (valRelay) {
|
||||||
|
relayAction = LOW;
|
||||||
|
} else {
|
||||||
|
relayAction = HIGH;
|
||||||
|
}
|
||||||
|
|
||||||
valRelay = digitalRead(relayPin); // read the status of input pin
|
|
||||||
if (valRelay) {
|
|
||||||
relayAction = LOW;
|
|
||||||
} else {
|
|
||||||
relayAction = HIGH;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_cm < range && new_cm > 1) {
|
|
||||||
digitalWrite(relayPin, relayAction); // Switch Ralay ON or OFF
|
digitalWrite(relayPin, relayAction); // Switch Ralay ON or OFF
|
||||||
delay(1000); // Miliseconds which it waits before does any action again
|
newAction = false;
|
||||||
}
|
}
|
||||||
|
delay(1000); // Miliseconds which it waits before does any action again
|
||||||
|
|
||||||
|
} else {
|
||||||
|
newAction = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
long microsecondsToCentimeters(long microseconds) {
|
long microsecondsToCentimeters(long microseconds) {
|
||||||
return microseconds / 29 / 2;
|
return microseconds / 29 / 2;
|
||||||
|
}
|
||||||
}
|
|
@ -1,52 +0,0 @@
|
|||||||
const int US_sensorPin = 7;
|
|
||||||
const int relayPin = 10;
|
|
||||||
const int range = 8; //Range of detection from the sensor in cm
|
|
||||||
|
|
||||||
void setup() {
|
|
||||||
pinMode(relayPin, OUTPUT);
|
|
||||||
digitalWrite(relayPin, HIGH); // Default relay should be OFF!
|
|
||||||
}
|
|
||||||
|
|
||||||
void loop() {
|
|
||||||
long duration, cm;
|
|
||||||
pinMode(US_sensorPin, OUTPUT);
|
|
||||||
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
delayMicroseconds(2);
|
|
||||||
digitalWrite(US_sensorPin, HIGH);
|
|
||||||
delayMicroseconds(5);
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
|
|
||||||
pinMode(US_sensorPin, INPUT);
|
|
||||||
duration = pulseIn(US_sensorPin, HIGH);
|
|
||||||
|
|
||||||
cm = microsecondsToCentimeters(duration);
|
|
||||||
|
|
||||||
if (cm < range && cm > 1) {
|
|
||||||
long new_duration, new_cm;
|
|
||||||
pinMode(US_sensorPin, OUTPUT);
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
delayMicroseconds(2);
|
|
||||||
digitalWrite(US_sensorPin, HIGH);
|
|
||||||
delayMicroseconds(5);
|
|
||||||
digitalWrite(US_sensorPin, LOW);
|
|
||||||
pinMode(US_sensorPin, INPUT);
|
|
||||||
new_duration = pulseIn(US_sensorPin, HIGH);
|
|
||||||
|
|
||||||
new_cm = microsecondsToCentimeters(new_duration);
|
|
||||||
|
|
||||||
if (new_cm < range && new_cm > 1) {
|
|
||||||
digitalWrite(relayPin, LOW); // Turn Ralay ON
|
|
||||||
delay(500); // Miliseconds which it waits before turn off again
|
|
||||||
digitalWrite(relayPin,HIGH); // Trun Ralay OFF
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_cm < range && new_cm > 1) {
|
|
||||||
delay(3000); // Pauses the measure for 3 seconds.. so the liquid-flow stops after above time
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
long microsecondsToCentimeters(long microseconds) {
|
|
||||||
return microseconds / 29 / 2;
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user