Catcher Game Tutorial Level 1

in #programming7 years ago (edited)

Zusammenfassung

In diesem Level lernst du die beiden Hauptfunkionen in Processing kennen. In diesem Zuge schauen wir uns das Koordinatensystem eines Fensters an. Du wirst außerdem nach diesem Level Formen darstellen können.

ThemaVoraussetzungen
Schwierigkeit**
HardwarePC (Windows/Mac/Linux)
SoftwareBrowser, Internetzugang, Processing IDE
CatcherTutorial Level0
ProgrammierungAufruf von Funktionen

Vorbereitung

  • Wir gehen nicht auf alle Programmiergrundlagen ein. Wenn du noch nie etwas programmiert hast, schaue dir die Hello Processing Videos an. Ich würde aber auch allen Processing Neulingen diese Videoreihe empfehlen. So kannst du dir die Suche für einige processing-spezifischen Besonderheiten sparen.
  • Achte darauf, dass dein Modus auf Java gestellt ist.
  • Speicher den derzeit leeren Sketch unter einem Namen deiner Wahl ab
  • Öffne die Einstellungen (Datei -> Einstellungen) der Processing IDE. Aktiviere die Checkbox Codevervollständigung Ctrl-Leerzeichen. Wenn du beim Programmieren Variablennamen, Funktionsamen oder Paramter beginnst zu Tippen, kannst du dir von der Entwicklungsumgebung mit Ctrl-Leerzeichen Vorschläge zur Vervollständigung geben lassen.
  • Öffne die Projektwebseite zu Processing. Beispiele und Referenzen solltest du hier finden und auch nutzen!

Das Spiel

Ich möchte mit dir zusammen ein Spiel programmieren. Wir nennen es Catcher. Ziel soll es sein, herunter fliegende Objekte einzusammeln und somit einen möglichst hohen Highscore zu erreichen. Verpasste Objekte ziehen Leben ab. Das Spiel muss gestartet und nach verlorener Runde neu gestartet werden können.

Programmierung

In Processing existieren zwei wichtige Hauptfunktionen. Die setup-Methode wird zu Beginn des Programmstarts einmal ausgeführt. Die draw-Methode wird in einer Schleife dauerhaft ausgeführt.

void setup() {

}

void draw() {

}

Das Fenster, das du erstellst hat eine Breite und Höhe in Pixel. Jeder Pixel kann durch ein x und ein y in einem Koordinatensystem exakt bestimmt werden. Dabei ist zu beachten, dass in der Computergrafik der Punkt x=0 und y=0 oben links definiert ist. Dies ist im ersten Moment irreführend, da das bei dir wahrscheinlich bisher bekannte System links unten beginnt. Das musst du die gesamte Zeit beachten!


if/else ist eine bedingte Anweisung und Verzweigung. Der Ausdruck im if wird ausgewertet. Wenn dieser Wahr (true) ist, wird der Programmcode doA() innerhalb der geschweiften Klammern ausgeführt - sonst nicht. Mit else hast du die Möglichkeit eine alternative Ausführung anzugeben. Dadurch wird immer das eine doB() oder das andere doC() ausgeführt.

if(isThisTrue){
  doA();
}

if(isThisAlsoTrue){
  doB();
}else{
  doC();
}

Variablen sind Container, die einen Datentyp haben. Dies kann eine Zahl, eine Zeichenkette, ein boolesche Ausdruck oder ein beliebiges Objekt sein.

int a = 1; // Ganze Zahlen. a hat den Wert 1
float b = 2.5; // Fließkommazahlen. b hat den Wert 2,5
String c = "Catcher"; // Zeichenkette. c hat den Wert Catcher
boolean d = true; // Boolesche Ausdruck (true oder false). d hat den Wert true
PShape catcher; // Leeres Objekt PShape (noch nichts mit = zugewiesen) namens catcher.

Du kannst auf Variablen von überall zugreifen, wenn du sie global definiert hast. Das bedeutet außerhalb einer Funktion. Lokale Variablen innerhalb einer Funktion können auch nur dort verwendet werden.

float a = 3.4; // global
void setup() {
  float b = 1.3; //lokal
  a // kann ich nutzen
  b // kann ich nutzen
}
void draw() {
  a // kann ich nutzen
  b // kenne ich nicht - kann ich nicht nutzen
}

Aufgabe 1

  1. Erstelle ein Fenster in folgender Größe Breite 400 Pixel und Höhe 640 Pixel
  2. Setze den Hintergrund auf eine Farbe
  3. Zeichne den Catcher (ein Rechteck) im unteren Bereich des Fensters
  4. Starte dein Programm mit dem Play-Button oben links in der Entwicklungsumgebung

Mögliche Lösung

Aufgabe 2

  1. Der Catcher soll sich entlang der x-Achse nach rechts und links verschieben lassen (mit der Maus).
  2. Der Catcher soll nur verschoben werden, wenn die Maus gedrückt ist.

Mögliche Lösung

Github Repository Catcher
Github Repository Tutorial