Versions Compared

Key

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

...

Modify the code so that the ellipse always follows the mouse position.  

Replace with the ellipse with another shape (like a triangle or even a car) , and keep it pointed towards the mouse.

Exercise Solution Using Arrays

Code Block
collapsetrue
PVector[] pos;
PVector[] targetPos;
PVector mousePos;
int arrayLength = 5;
void setup() {
  size(1000, 600);
  fill(0);

  pos = new PVector[arrayLength];
  targetPos = new PVector[arrayLength];

  for (int i = 0; i<pos.length; i++) { 
    pos[i] = new PVector(0, 0);
    targetPos[i] = new PVector(0, 0);
  }
  mousePos = new PVector(width/2, height/2);
}

void draw() {
    mousePos.set(mouseX, mouseY);
  background(255);
  
    for (int i = 0; i<pos.length; i++) { 
        targetPos[i].set(mousePos); 
        targetPos[i].sub(pos[i]);  // find the vector between mouse position and ellipse position
        targetPos[i].mult((i*0.02)+.02); // each step in the animation will move this percentage of the distance to the target position
        pos[i].add(targetPos[i]);
        ellipse(pos[i].x, pos[i].y, 60, 60);
    }
}


...