Class BorderBox

java.lang.Object
pi.graphics.boxes.Box
pi.graphics.boxes.BorderBox
All Implemented Interfaces:
Iterable<Box>

public class BorderBox extends Box
Legt einen Rahmen um eine enthaltene Kind-Box.
Since:
0.40.0
  • Field Details

    • child

      protected Box child
      Die Kind-Box, dieser übergeordneten Box.
  • Constructor Details

    • BorderBox

      public BorderBox(Box child)
      Erzeugt einen neuen Rahmen durch die Angabe der enthaltenen Kind-Box.
      Parameters:
      child - Die Kind-Box, die umrahmt werden soll.
      Since:
      0.40.0
  • Method Details

    • thickness

      public BorderBox thickness(int thickness)
      Setzt die Dicke der Linie in Pixel. Ist die Linienfarbe noch nicht festgelegt worden, so wird auf schwarz gesetzt.
      Parameters:
      thickness - Die Dicke der Linie in Pixel.
      Returns:
      Eine Referenz auf die eigene Instanz der Box, damit nach dem Erbauer/Builder-Entwurfsmuster die Eigenschaften der Box durch aneinander gekettete Setter festgelegt werden können, z. B. box.x(..).y(..).
      Since:
      0.40.0
    • color

      public BorderBox color(Color color)
      Setzt die Farbe der Linie in Pixel. Ist die Liniendicke noch nicht festgelegt worden, so wird sie auf 1 Pixel gesetzt.
      Parameters:
      color - Die Farbe der Linie in Pixel.
      Returns:
      Eine Referenz auf die eigene Instanz der Box, damit nach dem Erbauer/Builder-Entwurfsmuster die Eigenschaften der Box durch aneinander gekettete Setter festgelegt werden können, z. B. box.x(..).y(..).
      Since:
      0.40.0
    • color

      @Setter public BorderBox color(String color)
      Returns:
      Eine Referenz auf die eigene Instanz der Box, damit nach dem Erbauer/Builder-Entwurfsmuster die Eigenschaften der Box durch aneinander gekettete Setter festgelegt werden können, z. B. box.x(..).y(..).
    • calculateDimension

      protected void calculateDimension()
      Description copied from class: Box
      Berechnet rekursiv die Abmessung (die Höhe und Breite) der eigenen Box.

      Single-Child-Code-Beispiel

       
       protected void calculateDimension()
       {
           width = child.width + 2 * margin;
           height = child.height + 2 * margin;
       }
       
       

      Multiple-Child-Code-Beispiel

       
       protected void calculateDimension()
       {
           int maxWidth = 0;
           for (Box child : childs)
           {
               if (child.width > maxWidth)
               {
                   maxWidth = child.width;
               }
               height += child.height;
           }
           width = maxWidth;
       }
       
       
      Specified by:
      calculateDimension in class Box
    • calculateAnchors

      protected void calculateAnchors()
      Description copied from class: Box
      Berechnet rekursiv alle Ankerpunkte (linkes oberes Eck) der untergeordneten Kinder-Boxen. Die inneren Blattboxen brauchen diese Methode nicht zu implementieren.

      Single-Child-Code-Beispiel

       
       protected void calculateAnchors()
       {
           child.x = x + margin;
           child.y = y + margin;
       }
       
       

      Multiple-Child-Code-Beispiel

       
       protected void calculateAnchors()
       {
           int yCursor = y;
           for (Box child : childs)
           {
               child.x = x;
               child.y = yCursor;
               yCursor += child.height;
           }
       }
       
       
      Specified by:
      calculateAnchors in class Box
    • toString

      public String toString()
      Overrides:
      toString in class Object
    • addChild

      public void addChild(Box child)
      Fügt eine Kind-Box hinzu.

      Die Zellbox wird dabei als Elternbox der Kind-Box gesetzt.

      Parameters:
      child - Die Kind-Box.
    • numberOfChilds

      public int numberOfChilds()
      Description copied from class: Box
      Gibt die Anzahl an Kinder-Boxen zurück.
      Specified by:
      numberOfChilds in class Box
      Returns:
      Die Anzahl an Kinder-Boxen.