Versions Compared

Key

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

...

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:

...

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); //  smooth(define window size
  background(0); // define background colour
  stroke(255, 255, 255); }
 // define line colour
}
void draw() {
  background(0);
  length1 = mouseX;
  length2 = strokeWeight(1)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 accept no parameters so the space between the brackets is left blank, and they have no return value so the 'void' keyword is used . The function names are reserved names that Processing knows, Processing calls these (this will make more sense when we look at writing our functions). Processing calls the setup functions as soon as the corresponding event occurs.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.