Tronicart

A playground for creative coding expeiments

A quiet corner of the internet where I share my explorations and musings at the crossroads of coding and creativity.

Tronicart began as a personal project, a way to document my own learning and to connect with others who find joy in the confluence of technology and art.

What is creative coding ?

For those new to the concept, creative coding is about writing software with the intent to create something expressive instead of something purely functional.

As an example, you could write a program that generates a piece of music, or a program that creates a visual artwork. The goal is to create something that is aesthetically pleasing or thought-provoking.

Here's a simple example of creative coding in action. The following code generates a random dots which move in a singular direction. Those that are within a certain distance of each other are connected by a line.

sketch((p5) => {
  let dotCount = 100
  let dots = []

  p5.setup = () => {
    p5.createCanvas(600, 600)
    p5.stroke(150)
    p5.fill(0)

    for (let i = 0; i < dotCount; i++) {
      dots.push({
        x: p5.random(p5.width),
        y: p5.random(p5.height),
        vx: p5.random(-1, 1),
        vy: p5.random(-1, 1),
      })
    }
  }

  p5.draw = () => {
    p5.clear()
    for (let i = 0; i < dotCount; i++) {
      const dot = dots[i]
      dot.x += dot.vx
      dot.y += dot.vy

      if (dot.x < 0 || dot.x > p5.width) {
        dot.vx *= -1
      }
      if (dot.y < 0 || dot.y > p5.height) {
        dot.vy *= -1
      }

      p5.ellipse(dot.x, dot.y, 5, 5)

      for (let j = 0; j < dotCount; j++) {
        if (i !== j) {
          const other = dots[j]
          const distance = p5.dist(dot.x, dot.y, other.x, other.y)
          if (distance < 70) {
            p5.line(dot.x, dot.y, other.x, other.y)
          }
        }
      }
    }
  }
})