2007-02-11 19:03:00 +00:00
|
|
|
|
#include "navigation.h"
|
|
|
|
|
|
|
|
|
|
// Initialisiert die Klasse
|
|
|
|
|
Navigation::Navigation() {
|
2007-02-14 17:47:03 +00:00
|
|
|
|
// Am Anfang stehen wir an der Stelle
|
2007-02-11 19:03:00 +00:00
|
|
|
|
richtung = 0;
|
|
|
|
|
ausrichtung = 0;
|
|
|
|
|
geschwindigkeit = 0;
|
2007-02-14 17:47:03 +00:00
|
|
|
|
Aktualisieren(); // und <20>nderungen anwenden
|
2007-02-11 19:03:00 +00:00
|
|
|
|
}
|
|
|
|
|
Navigation::~Navigation() {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Setze eine neue Richtung
|
|
|
|
|
void Navigation::SetzeRichtung(int nRichtung) {
|
|
|
|
|
richtung = nRichtung;
|
|
|
|
|
}
|
|
|
|
|
// Setze eine neue Ausrichtung
|
|
|
|
|
void Navigation::SetzeAusrichtung(int nAusrichtung) {
|
|
|
|
|
ausrichtung = nAusrichtung;
|
|
|
|
|
}
|
|
|
|
|
// Setze eine neue Geschwindigkeit
|
|
|
|
|
void Navigation::SetzeGeschwindigkeit(int nGeschwindigkeit) {
|
|
|
|
|
geschwindigkeit = nGeschwindigkeit;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Aktualieren ohne Parameter
|
2007-02-17 00:35:01 +00:00
|
|
|
|
void Navigation::Aktualisieren() {
|
2007-02-11 19:03:00 +00:00
|
|
|
|
// Richtung in x und y-Kompontente zerlegen
|
2007-02-17 00:35:01 +00:00
|
|
|
|
double y = cos((double)richtung*0.01745); // richtung ist winkel
|
|
|
|
|
double x = sin((double)richtung*0.01745);
|
2007-02-11 19:03:00 +00:00
|
|
|
|
|
|
|
|
|
// Abweichung der Ausrichtung ermitteln(als winkel)
|
2007-02-14 17:47:03 +00:00
|
|
|
|
int w = sensor.GetAusrichtung() - ausrichtung;
|
2007-02-11 19:03:00 +00:00
|
|
|
|
|
2007-02-15 19:03:00 +00:00
|
|
|
|
// St<53>rke der einzelnen Motoren berechnen
|
2007-02-17 00:35:01 +00:00
|
|
|
|
double v0 = (-x+sqrt(3)*y)/2;
|
2007-02-15 19:03:00 +00:00
|
|
|
|
double v1 = x;
|
2007-02-17 00:35:01 +00:00
|
|
|
|
double v2 = (-x-sqrt(3)*y)/2;
|
2007-02-11 19:03:00 +00:00
|
|
|
|
|
|
|
|
|
// Ausgerechnete St<53>rke an die Motoren <20>bergeben
|
2007-02-15 19:03:00 +00:00
|
|
|
|
board.motor(0,(int)((double)v0*geschwindigkeit +w));
|
|
|
|
|
board.motor(1,(int)((double)v1*geschwindigkeit +w));
|
|
|
|
|
board.motor(2,(int)((double)v2*geschwindigkeit +w));
|
2007-02-11 19:03:00 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Aktualieren mit allen Parametern
|
|
|
|
|
void Navigation::Aktualisieren(int nRichtung,int nAusrichtung,int nGeschwindigkeit) {
|
|
|
|
|
SetzeRichtung(nRichtung); // <20>bergebene Werte schreiben
|
|
|
|
|
SetzeAusrichtung(nAusrichtung);
|
|
|
|
|
SetzeGeschwindigkeit(nGeschwindigkeit);
|
|
|
|
|
Aktualisieren(); // Und anwenden
|
|
|
|
|
}
|
|
|
|
|
|