Atlassian uses cookies to improve your browsing experience, perform analytics and research, and conduct advertising. Accept all cookies to indicate that you agree to our use of cookies on your device. Atlassian cookies and tracking notice, (opens new window)
Confluence
For you

Programming
Results will update as you type.
  • Tiling and Repetition
  • Reactors
  • Programming Basics: Parametric and Generative Graphic Design 2016
  • Archive
  • High Scores
  • Artificial Neural Network
  • Alternatives to the Processing IDE
  • p5.js Programming
    • p5.js Introduction
    • p5.js Variables
    • p5.js Random Numbers
    • p5.js SVG + Images
    • p5.js WebGL
    • p5.js Classes and Objects
    • p5.js Events and Functions
    • p5.js Loops
    • p5.js Coordinates
    • P5js Nested Loops
    • p5.js Animation Exercise 1
    • p5.js Animation Exercise 2
    • p5.js Conditionals
    • p5.js Arrays and Lists
    • p5.js Simple Collision Detection
    • p5.js Reactors
    • p5.js Tiling and Repetition
    • p5.js Vectors
    • p5.js Animation Solution with Objects
    • p5.js Easing
    • p5.js Perlin Noise
    • p5.js Particle System
    • p5.js Sound
    • p5j.s Typography
    • P5js Archive
  • Programming in Processing (java)

    Two hearts overlapped with each other
    Welcome back
    Catch up on the top discussions and highlights from your team.
    /
    p5.js Particle System
    Published Aug 06, 2021

    p5.js Particle System

    Analytics

    Loading data...


    Particle System is a so called “emitter”, which emits the particles and is often used to display “fuzzy” things, such as galaxies or explosions. They can create complex, interactive graphics which interact with fields, physics etc.

     

    Here’s a basic example of flow field particle system:

    var inc = 0.1; var scl = 100,zoff = 0; var cols,rows,movement = 0; var particles = []; var flowfield; var img; var maxSpeed; let lineMaxDist = 50; function setup() { var canvas = createCanvas(820, 820); maxSpeed = 10.5; cols = floor(width / scl); rows = floor(height / scl); flowfield = new Array(cols); var numParticles = Math.floor(width/4); for (var i = 0; i < numParticles; i++) { particles[i] = new Particle(); } background(245); colorMode(RGB); r = random(255); g = random(255); b = random(255); } function draw() { noStroke(); fill(10, 10); rect(0, 0, width, height); noFill(); var yoff = 0; for (var y = 0; y < rows; y++) { var xoff = 0; for (var x = 0; x < cols; x++) { var index = x + y * cols; var angle = noise(xoff, yoff, zoff) * TWO_PI * 4; var v = p5.Vector.fromAngle(angle); v.setMag(1); flowfield[index] = v; xoff += inc; } yoff += inc; zoff += 0.001; } for (var i = 0; i < particles.length; i++) { particles[i].follow(flowfield); particles[i].update(); particles[i].edges(); particles[i].scatter(); particles[i].show(); //particles[i].connect(); //might be used to draw connections } } function Particle() { this.pos = createVector(random(width), random(height - 100)); this.vel = createVector(0, 0); this.acc = createVector(0, 0); this.maxspeed = maxSpeed; this.prevPos = this.pos.copy(); this.lifespan = 255; this.update = function () { this.vel.add(this.acc); this.vel.limit(this.maxspeed); this.pos.add(this.vel); this.acc.mult(0); this.lifespan -= 1; }; this.follow = function (vectors) { var x = floor(this.pos.x / scl); var y = floor(this.pos.y / scl); var index = x + y * cols; var force = vectors[index]; this.applyForce(force); }; this.scatter = function (vectors) { this.pos.x += random(-0.9, 0.9); this.pos.y += random(-0.9, 0.9); }; this.applyForce = function (force) { this.acc.add(force); }; this.show = function () { stroke(r, g, b, this.lifespan); line(this.pos.x, this.pos.y, this.prevPos.x, this.prevPos.y); this.updatePrev(); }; this.updatePrev = function () { this.prevPos.x = this.pos.x; this.prevPos.y = this.pos.y; }; this.edges = function () { if (this.pos.x > width) { this.pos.x = 0; this.updatePrev(); } if (this.pos.x < 0) { this.pos.x = width; this.updatePrev(); } if (this.pos.y > height) { this.pos.y = 0; this.updatePrev(); } if (this.pos.y < 0) { this.pos.y = height; this.updatePrev(); } }; //uncomment this to draw connections between particles that are less than lineMaxDist /* this.connect = function() { particles.forEach(particle => { let distance = dist(this.pos.x, this.pos.y, particle.pos.x, particle.pos.y); if (distance < lineMaxDist) { stroke(r,g,b, map(distance, 0, lineMaxDist, 255, 0)); strokeWeight(map(distance, 0, lineMaxDist, 2, 0)); line(this.pos.x, this.pos.y, particle.pos.x, particle.pos.y); } }) } */ }

     

     

    Related content
    p5.js Introduction
    p5.js Introduction
    Luke Franzke
    p5.js Programming
    p5.js Programming
    Luke Franzke
    p5.js Reactors
    p5.js Reactors
    Luke Franzke
    p5.js Variables
    p5.js Variables
    Luke Franzke
    p5.js Events and Functions
    p5.js Events and Functions
    Luke Franzke
    p5.js Simple Reactor
    p5.js Simple Reactor
    Luke Franzke
    {"serverDuration": 41, "requestCorrelationId": "e21f92bd34c84856841679eff26e59c5"}