Skip to content

Interactive Drawing

Posted on:September 25, 2022

Check out my work here

This is a very basic drawing pad made with p5.js. Only 87 lines of code, but it works beautifully!

Hey, using functions as variables are fun, right?

let hueAdding = true;
let currentHue = 0;
let currentState = "";

let drawLine = (sc, sw) => {
  if (mouseIsPressed === true) {
    stroke(sc);
    strokeWeight(sw);
    line(mouseX, mouseY, pmouseX, pmouseY);
  }
};

let colorfulLine = () => {
  if (mouseIsPressed === true) {
    strokeWeight(20);
    stroke(currentHue, 100, 100);
    line(mouseX, mouseY, pmouseX, pmouseY);
  }

  if (hueAdding == true) {
    currentHue += 5;
  } else {
    currentHue -= 5;
  }

  if (currentHue >= 255) {
    hueAdding = false;
  } else if (currentHue <= 0) {
    hueAdding = true;
  }
};

let drawUpdate = () => {};

let showIns = (w) => {
  fill(255);
  strokeWeight(2);
  stroke(0);
  rect(25, height - 70, 200, 65);
  noStroke();
  textSize(15);
  fill(0);
  text(
    w === "d"
      ? "> " + "D - Normal drawing mode"
      : "" + "D - Normal drawing mode",
    30,
    height - 55,
  );
  text(
    w === "x"
      ? "> " + "X - Draw colorful lines!"
      : "" + "X - Draw colorful lines!",
    30,
    height - 40,
  );
  text(w === "e" ? "> " + "E - Eraser" : "" + "E - Eraser", 30, height - 25);
  fill(0, 75, 75);
  text(
    w === "c" ? "> " + "C - Clear all!" : "" + "C - Clear all!",
    30,
    height - 10,
  );
};

function setup() {
  createCanvas(400, 400);
  colorMode(HSB);
  background(255);
}

function draw() {
  drawUpdate();
  showIns(currentState);
}

function keyPressed() {
  if (key === "C" || key === "c") {
    drawUpdate = () => {
      background(255);
    };
    currentState = "c";
  } else if (key === "E" || key === "e") {
    drawUpdate = () => {
      drawLine(255, 40);
    };
    currentState = "e";
  } else if (key === "D" || key === "d") {
    drawUpdate = () => {
      drawLine(0, 20);
    };
    currentState = "d";
  } else if (key === "X" || key === "x") {
    drawUpdate = () => {
      colorfulLine();
    };
    currentState = "x";
  }
}