Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

deutsche Version

Functions are an elementary part of programming languages. With them, programs can be simplified and presented in a manageable and reusable way (modularisation). Functions also help us to keep our code organised and understandable. 

Functions act as jumps in the program. In the event of a function call, the program jumps to the position where the function is defined and then returns after the function has been executed. Most programming languages have many built-in or native functions. To find out how the Processing functions work, and what parameters they expect, we need to look at the processing documentation (https://processing.org/reference/).

In the previous examples, we have written programs without functions. These programs were not interactive and do not include animations. So how can you extend a program so that, for example, the keyboard is used as an input? The answer is to use program events, which are recorded and forwarded by the program. Here is a short list of some such events:

  • program start
  • Output to refresh of the window
  • keyboard input
  • mouse input

...

Let's take the Example 1 and expand it to use events:

Code Block
int length1 = 0;
int length2 = 0;

void setup() {
  size(300, 300); // define window size
  smoothbackground(0); // define background colour
  stroke(255, 255, 255); // define }line colour
}
void draw() {
  background(0);
  length1  strokeWeight(1)= mouseX;
  length2 = mouseY;
  line(100, 10, 100,150 length1); // draw a line
  line(150, 10, 150,200 length2);
  line(200, 10, 200, 250);


  fill(0, 0, 0); // fill colour
  strokeWeight(5); // line thickness
  ellipse(100,150 length1, 50, 50); // draw an ellipse
  ellipse(150,200 length2, 50, 50); // draw an ellipse
  noFill(); // turn off fill
  ellipse(200, 250, 50, 50); // draw an ellipse
}


In this program we use two special functions:

  • void setup ()
  • void draw ()

These functions have accept no parameters so the space between the brackets is left blank, and they have no return value , so only the 'void' is replaced by the return type. The function names are reserved names that processing knows, so Processing calls these functions as soon as the corresponding event occurs.

Further functional examples

This example shows how to write functions with return values.

Code Block
void setup()
{
  println(addition(1,2));
  println(addition(2,10));
}
 
int addition(int parameter1, int parameter2)
{
  return parameter1 + parameter2;
}

This example shows how to use functions around the code of legible and simple shapes (modularization).

Code Block
void setup()
{
  size(300,300);
  smooth();
  stroke(255,255,255);
  noFill();
}
 
void draw()
{
  background(0);
 
  bommel(100,10,140,50);
  bommel(150,10,190,50);
  bommel(200,10,240,50);
}
 
void bommel(int x,int y,int length,int size)
{
  strokeWeight(1);
  line(x,y,x,y+length);
  strokeWeight(5);
  ellipse(x,y+length,size,size);
}

And here is our first interactive program:

Code Block
void setup()
{
  size(300,300);
  background(0);
}
 
void draw()
{}
 
void mousePressed()
{
  println("x:" + mouseX + ", y:" + mouseY);
}

Exercise

Create a Programm where a unique shape follows the mouse position.keyword is used (this will make more sense when we look at writing our functions). Processing calls the setup functions as soon as the program starts, and the draw function every time the screen refreshes. We will use these two functions for all of our future processing sketches.  

Exercise 3:

Take your results to form exercise 2, and modify it so it animates across the screen.