P5js Classes and Objects (de)

Klassen sind eine der wichtigsten Programmierkonstrukte von Java. Sie sind das abstrakte Modell eines Objektes. Sozusagen der Bauplan für ein Objekt. Vereinfacht gesagt könnte man Klassen auch als erweiterte Datentypen sehen. Als selbst definierte Datentypen die Variablen und Funktionen beinhalten. Um Zugriff auf Variablen=Attribute und Funktionen=Methoden zu haben muss nach dem Objekt ein Punkt “.” gesetzt werden, gefolgt von dem Namen des Attributs oder der Methode.

Aufbau einer Klasse:

class KlassenName extends BasisKlasse
{
[Konstruktor – Initialisierungs Funktion]

[Attribute - Variablen]

[Methoden - Funkionen]

}

Konstruktor

Der Konstruktor ist die Initialisierungsfunktion einer Klasse. Sie wird aufgerufen wenn eine Klasse erzeugt wird. Eine Klasse wird mit dem Befehl ‘new’ und dem anschliessenden Aufruf des Konstruktors erzeugt. Um den Konstruktor einer Basisklasse aufzurufen(im Falle einer abgeleiteten Klasse) muss das Schlüsselwort ‘super’ benutzt werden.

Attribute

Attribute sind die Variablen einer Klasse.

Methoden

Methoden sind die Funktionen einer Klasse.

Abgeleitete Klasse – Keyword ‘extends’

Eine Klasse kann von einer anderen Klasse abgeleitet werden. Damit erbt diese Klasse die Eigenschaften der Basisklasse. Die Klasse erbt die Methoden und Attribute der Basisklasse. Sollte sie aber Methoden oder Attribute setzen, welche gleich heissen wie solche in der Basisklasse, dann werden die Basisklassen Eigenschaften überschrieben.

Beispiel BallKlasse

BouncingBall ball1;
BouncingBall ball2;
 
PVector      p1 = new PVector();
PVector      p2 = new PVector();
boolean      drag = false;
 
void setup()
{
  size(800,600);
 
  ball1 = new BouncingBall(100,100);
  ball2 = new BouncingBall(50,50);
 
  // svg bild soll zentriert sein
  shapeMode(CENTER);
  smooth();
}
 
void draw()
{
  // hintergrund loeschen
  //background(255);
  // ghosting
  fill(255,255,255,60);
  rect(0,0,width,height);
 
  if(drag)
  { // zeichne die abschussrichtung
    p1.set(ball1._pos.x,ball1._pos.y,0);
    line(p1.x,p1.y,p2.x,p2.y);
  }
 
  // zeichne den ball
  ball1.draw();
  ball2.draw();
}
 
void mousePressed()
{
  drag = true;
  p1.set(ball1._pos.x,ball1._pos.y,0);
  p2.set(mouseX,mouseY,0);
}
 
void mouseDragged()
{
  p2.set(mouseX,mouseY,0);
}
 
void mouseReleased()
{
  drag = false;
 
  // abschuss staerke berechnen
  PVector dir = PVector.sub(p2,p1);
  // laenge verkuerzen
  dir.mult(.09);
 
  // der ball wird neu ausgerichtet
  ball1.set(p1,dir,.993);
  ball2.set(p1,dir,.95);
}

BouncingBall

class BouncingBall
{
  PVector _pos;
  PVector _dir;
  float   _dampV;
  PShape  _shape;
  int     _w;
  int     _h;
   
  // konstruktor
  BouncingBall(int shapeWidth,int shapeHeight)
  {
    _pos = new PVector(width/2, height/2);
    _dir = new PVector(0,0);
    _dampV = 1;
     
    _w = shapeWidth;
    _h = shapeHeight;
     
    _shape = loadShape("ball1.svg");
  }
   
  // setzt die neue pos + richtung + daempfung
  void set(PVector pos,PVector dir,float dampV)
  {
    _pos = pos.get();
    _dir.add(dir);
    _dampV = dampV;
  }
   
  // erneuert die aktuelle position
  void calcPos()
  {
    // aktuelle position verschieben
    _pos.add(_dir);
     
    // bewegungs vektor veraendert
    _dir.mult(_dampV);
     
    // teste horizontal 
    if(_pos.x + _w/2 > width)
    {
      _dir.x *= -1;
      _pos.x = width - _w/2;
    }
    else if(_pos.x - _w/2 < 0)
    {
      _dir.x *= -1;
      _pos.x = _w/2;
    }
     
    // teste vertikal 
    if(_pos.y + _h/2 > height)
    {
      _dir.y *= -1;
      _pos.y = height - _w/2;
    }
    else if(_pos.y - _h/2 < 0)
    {
      _dir.y *= -1;
      _pos.y = _h/2;
    }
     
  }
   
  // zeichnet den ball
  void draw()
  {
    calcPos();
     shape(_shape,
          _pos.x,_pos.y,
          _w,_h);
  }
}
 
class BallEx extends BouncingBall
{
  BallEx(int size)
  {
     super(size,size);
  }
 
  void draw()
  {
    super.draw();
    line(0,0,_pos.x,_pos.y);
  }
 
}

Download Beispiel

Aufgabe:

  • Erweitere das Programm, dass mehrere Bälle unabhängig voneinander platziert werden können
  • Erweitere die Klasse um eine neue Art von Bällen