Fixed bug, started implementing direction stuff
This commit is contained in:
parent
f0679635da
commit
7187c2aa53
@ -46,16 +46,87 @@ enum
|
|||||||
} anlagenzustand;
|
} anlagenzustand;
|
||||||
|
|
||||||
// Fahrtrichtungen
|
// Fahrtrichtungen
|
||||||
enum
|
enum Fahrtrichtung
|
||||||
{
|
{
|
||||||
STOP,
|
HALT,
|
||||||
VORWÄRTS,
|
NOTHALT,
|
||||||
RÜCKWÄRTS,
|
WARTE_START,
|
||||||
|
VORWAERTS_QUITTIEREN,
|
||||||
|
VORWAERTS,
|
||||||
|
RUECKWAERTS_QUITTIEREN,
|
||||||
|
RUECKWAERTS,
|
||||||
} fahrtrichtung;
|
} fahrtrichtung;
|
||||||
|
|
||||||
|
Fahrtrichtung vorherigerichtung = HALT;
|
||||||
|
|
||||||
|
void quittierenButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
if(fahrtrichtung == NOTHALT || fahrtrichtung == HALT)
|
||||||
|
{
|
||||||
|
fahrtrichtung = WARTE_START;
|
||||||
|
}
|
||||||
|
else if(fahrtrichtung == VORWAERTS_QUITTIEREN)
|
||||||
|
{
|
||||||
|
fahrtrichtung = WARTE_START;
|
||||||
|
}
|
||||||
|
else if(fahrtrichtung == RUECKWAERTS_QUITTIEREN)
|
||||||
|
{
|
||||||
|
fahrtrichtung = WARTE_START;
|
||||||
|
}
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
|
void startButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
if(vorherigerichtung == VORWAERTS)
|
||||||
|
{
|
||||||
|
fahrtrichtung = RUECKWAERTS;
|
||||||
|
}
|
||||||
|
else if(vorherigerichtung == RUECKWAERTS)
|
||||||
|
{
|
||||||
|
fahrtrichtung = VORWAERTS;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fahrtrichtung = VORWAERTS;
|
||||||
|
}
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
|
void haltButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
fahrtrichtung = HALT;
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
|
void nothaltButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
fahrtrichtung = NOTHALT;
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
|
void vorwaertsButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
fahrtrichtung = VORWAERTS_QUITTIEREN;
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
|
void rueckwaertsButtonAbfragen()
|
||||||
|
{
|
||||||
|
// Button Code [...]
|
||||||
|
fahrtrichtung = RUECKWAERTS_QUITTIEREN;
|
||||||
|
// Button Code [...]
|
||||||
|
}
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
anlagenzustand = AUS;
|
anlagenzustand = AUS;
|
||||||
|
fahrtrichtung = HALT;
|
||||||
|
|
||||||
Serial.begin(9600);
|
Serial.begin(9600);
|
||||||
|
|
||||||
// Pindefinitonen
|
// Pindefinitonen
|
||||||
@ -187,21 +258,50 @@ void loop() {
|
|||||||
switch(fahrtrichtung)
|
switch(fahrtrichtung)
|
||||||
{
|
{
|
||||||
// Anlage steht
|
// Anlage steht
|
||||||
case STOP:
|
case HALT:
|
||||||
{
|
{
|
||||||
|
quittierenButtonAbfragen();
|
||||||
|
vorwaertsButtonAbfragen();
|
||||||
|
rueckwaertsButtonAbfragen();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// Anlage steht
|
||||||
|
case NOTHALT:
|
||||||
|
{
|
||||||
|
quittierenButtonAbfragen();
|
||||||
|
vorwaertsButtonAbfragen();
|
||||||
|
rueckwaertsButtonAbfragen();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// Anlage steht
|
||||||
|
case WARTE_START:
|
||||||
|
{
|
||||||
|
startButtonAbfragen();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Anlage fährt vorwärts
|
// Anlage fährt vorwärts
|
||||||
case VORWÄRTS:
|
case VORWAERTS_QUITTIEREN:
|
||||||
{
|
{
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// Anlage fährt vorwärts
|
||||||
|
case VORWAERTS:
|
||||||
|
{
|
||||||
|
haltButtonAbfragen();
|
||||||
|
nothaltButtonAbfragen();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Anlage fährt rückwärts
|
// Anlage fährt rückwärts
|
||||||
case RÜCKWÄRTS:
|
case RUECKWAERTS_QUITTIEREN:
|
||||||
{
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
// Anlage fährt rückwärts
|
||||||
|
case RUECKWAERTS:
|
||||||
|
{
|
||||||
|
haltButtonAbfragen();
|
||||||
|
nothaltButtonAbfragen();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
@ -243,8 +343,8 @@ void loop() {
|
|||||||
// Prüfen ob immernoch gedrückt
|
// Prüfen ob immernoch gedrückt
|
||||||
if (currentButtonStateFahrgastbetrieb == LOW)
|
if (currentButtonStateFahrgastbetrieb == LOW)
|
||||||
{
|
{
|
||||||
// Anlage in den Zustand "FAHRGAST_QUITTIEREN" versetzen
|
// Anlage in den Zustand "SERVICE_QUITTIEREN" versetzen
|
||||||
anlagenzustand = FAHRGAST_QUITTIEREN;
|
anlagenzustand = SERVICE_QUITTIEREN;
|
||||||
// Speichern des ButtonStates als Vergleichswert für den nächsten Durchlauf
|
// Speichern des ButtonStates als Vergleichswert für den nächsten Durchlauf
|
||||||
buttonStateFahrgastbetrieb = currentButtonStateFahrgastbetrieb;
|
buttonStateFahrgastbetrieb = currentButtonStateFahrgastbetrieb;
|
||||||
}
|
}
|
||||||
@ -342,6 +442,9 @@ void loop() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ========== Vorwärts Button abfragen
|
||||||
|
vorwaertsButtonAbfragen();
|
||||||
|
|
||||||
// ========== Ein/Aus Button abfragen
|
// ========== Ein/Aus Button abfragen
|
||||||
// Taster abfragen und aktuellen Zustand zwischenspeichern
|
// Taster abfragen und aktuellen Zustand zwischenspeichern
|
||||||
currentButtonStateAnlageEinAus = digitalRead(KNOPF_ANLAGE_EIN_AUS) == LOW;
|
currentButtonStateAnlageEinAus = digitalRead(KNOPF_ANLAGE_EIN_AUS) == LOW;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user