AntMe! - Eine Ameisenstraße: Unterschied zwischen den Versionen
K (→Äpfel zusammen tragen) |
K |
||
Zeile 95: | Zeile 95: | ||
{{Aufgabe-Mathe| | {{Aufgabe-Mathe| | ||
− | Hier ist wieder die Programmierumgebung vom Wiki. In ihr schreibst du nach den Kommentaren deinen eigenen Quellcode. Die Objekte werden wie in dem Beispiel erzeugt (siehe unten). | + | Hier ist wieder die Programmierumgebung vom Wiki. In ihr schreibst du nach den Kommentaren deinen eigenen Quellcode. Die Objekte werden wie in dem Beispiel erzeugt (siehe unten).<br /> |
+ | '''Achtung:''' Das Objekt wird hier <u>ohne</u> <tt>new</tt> erzeugt! | ||
# Erzeuge ein Objekt ''Ameise'' mit deinem Namen. | # Erzeuge ein Objekt ''Ameise'' mit deinem Namen. | ||
# Initialisiere eine weitere Ameise mit <tt>null</tt>. | # Initialisiere eine weitere Ameise mit <tt>null</tt>. |
Version vom 4. März 2010, 16:19 Uhr
<language>Java</language>
Lernpfad
|
Ziele des Lernpfads
- Ameisen kommunizieren auf einfache Art
- eigene Objekte in der Wiki-Umgebung erstellen
- Was ist die Besonderheit am null-Wert?
- Umgang mit vorgegebenen Objekten von AntMe!
- eine Ameisenstraße bauen
Die Kommunikation
|
Die Ameisen kommunizieren mit Duftwolken, sie werden auch (Durft-)Markierung genannt. Sie haben zwei Attribute: eine Information und einen Radius. Die Information und der Radius sind vom Datentyp Integer. Je größer der Radius der Duftmarkierung, desto schneller verschwindet sie auch.
Befindet sich eine Ameise in einer Duftwolke, so wird die Methode RiechtFreund(Markierung markierung) aufgerufen. Mit markierung.information kann die übermittelte Nachricht ausgelesen werden.
Äpfel zusammen tragen
|
public override void Sieht(Obst obst) { if (AktuelleLast == 0 && BrauchtNochTräger(obst) && WanzenInSichtweite == 0) { SprüheMarkierung(0, 100); GeheZuZiel(obst); } }
public override void RiechtFreund(Markierung markierung) { if (AktuelleLast != 0 && Ziel == null) { GeheZuZiel(markierung); } }
Das Ergebnis siehst du hier:
|
Der null-Wert
Strukturierte Datentypen werden auch Referenz-Datentypen genannt, weil man auf sie nur indirekt über einen Zeiger zugreift - einer Referenz. Diese Referenz kann entweder mit dem
- Default-Wert null initialisiert werden oder
- durch den Aufruf des new Operators
erzeugt werden.
In der Ameisensimulation AntMe! hatte die Referenz Ziel den Default-Wert null. Trotzdem sind Initialisierungen mit null gefährlich, weil das Objekt existiert, aber seine Komponenten nicht initialisiert wurden.
Ein Beispiel ohne Fehlermeldung:
Object obj1 = new Object(); Object obj2 = null;
|
public Object Ameise(String name) {
String myname = name;
void zeigeNamen() { System.out.println("Ich bin eine Ameise und heiße "+myname+"."); }
return this;
} <eval id="4b7becafdb750"> // Beispiel: // Object MeineAmeise = Ameise("Tobias"); // MeineAmeise.zeigeNamen(); </eval>
Welche Methoden kennen wir bereits?
|
RiechtFreund | Eine Ameise nimmt Geruch von einer Ameise des eigenes Volkes wahr. |
GeheZuZiel | Methode schickt die Ameise in eine bestimmte Richtung. |
ZielErreicht | Ameise kommt an. |
SiehtFeind | Eine Wanze oder gegnerische Ameise ist gesichtet. |
WirdAngegriffen | Wenn Gegner die Ameise attackieren, wird diese Methode aufgerufen. |
LasseNahrungFallen | Die aktuelle Last wird weggeworfen. |
BrauchtNochTräger | Schleppen genügend Ameisen einen Apfel? |
Sieht | Eine Ameise erblickt einen Apfel oder Zuckerhut. |
Nimm | Eine Ameise hebt einen Zuckerwürfel oder Apfel auf. |
GeheZuBau | Ameise läuft zu ihrem Startpunkt. |
So sollten auch deine Ameisen kommunizieren:
Und jetzt bauen wir ...
Eine Ameisenstraße
|
public override void Tick() | Wird jede Runde bei jeder Ameise aufgerufen |
this.Richtung | Gibt die Richtung der Ameise an. |
Ziel is Bau | Überprüft, ob das Ziel der Ameise der Bau ist(Rückgabwert: true oder false) |
SprüheMarkierung(int information, int groesse) | Die Ameise verteilt ihre Duftwolke mit einer Information in einer bestimmten Größe. |
this.Richtung + 180 | Gibt die entgegengesetzte Richtung der Ameise an. |
Koordinate.BestimmeRichtung(Startpunkt, Zielpunkt) | Gibt eine Richtung im Gradmaß zurück. Gemessen wird der Drehwinkel ausgehend vom Startpunkt zum Zielpunkt. |
markierung.Information | Liest die Information aus einer Duftwolke aus. |
public void DreheInRichtung(int richtung) | Dreht die Ameise in die angegebene Richtung. |
|
Die Eigenschaft this.Richtung aus der Ameisenklasse gibt die Blickrichtung der Ameise auf dem Spielfeld an. Außerdem bringt die "GeheGeradeaus"-Bewegung der Ameisen in der Simulation eine kleine Ungenauigkeit mit kurzen Zickzack-Bewegungen. Deshalb ist die Anwendung der Methode BestimmeRichtung() besser geeignet.
|
|
Das kannst du jetzt
- eigene Markierung mit den Ameisen versprühen
- auf Markierungen reagieren
- Objekte in der Wiki-Umgebung erstellen und damit arbeiten
- den Unterschied bei der Objektinstanziierung mit dem new-Operator und dem null-Wert
- Ameisenstraßen mit AntMe! bauen
Quellen
- ↑ Quelle: http://antme.net