P5js Verschachtelten Schleife (de)

Beispiel mit Screenshot-Funktion

void setup()
{
  size(600,600);      // def. fenstergroesse
  
  smooth();           // aktiviere antialiasing
  strokeWeight(1);    // linienbreite
}
  
void draw()
{
  background(255);    // def. hintergrundfarbe
  
  for(int x = 0; x <= width; x+=30)
  {
    for(int y = 0; y <= height; y+=30)
    {
        smiley(x,y);          // funtions anruf
    }
  }
  
}
  
void keyPressed()
{
  switch(key)
  {
  case 's':
    save("screenShot.jpg");
    println("save the screen to screenShot.jpg");
    break;
  }
}
  
// funktion
void smiley(int x, int y)
{
  println("smiley");
  noFill();
  ellipse(x,y,18,18);  // kopf
  
  fill(0);
  ellipse(x - 3,y - 3,2,5);  // linkes augen
  ellipse(x + 3,y - 3,2,5);  // rechtes augen
  
  noFill();
  arc(x,y,10,10,radians(20),radians(180-20));  // mund
}

Dieses Beispiel gibt die Zeichnung nicht auf den Bildschirm aus, es schreibt die Ausgabe in ein PDF-File.

import processing.pdf.*;
  
void setup()
{
  size(600,600,PDF,"ornament.pdf");      // def. fenstergroesse
  
  smooth();           // aktiviere antialiasing
  strokeWeight(1);    // linienbreite
}
  
void draw()
{
  background(255);    // def. hintergrundfarbe
  
  for(int x = 0; x <= width; x+=30)
  {
    for(int y = 0; y <= height; y+=30)
    {
        smiley(x,y);          // funtions aufruf
    }
  }
  
  exit();
}
  
// funktion
void smiley(int x, int y)
{
  println("smiley");
  noFill();
  ellipse(x,y,18,18);  // kopf
  
  fill(0);
  ellipse(x - 3,y - 3,2,5);  // linkes augen
  ellipse(x + 3,y - 3,2,5);  // rechtes augen
  
  noFill();
  arc(x,y,10,10,radians(20),radians(180-20));  // mund
}

Aufgabe

  • Erstelle ein Ornament, welches sich auf allen 4 Seiten mit sich selbst erweitern lässt. Druck es aus und test es.
  • Erstelle ein Ornament welches mit einem Ornament einer anderen Person erweitert werden kann.