AbbyDabby
AbbyDabby

Reputation: 33

Trying to use spirals to show an image in p5.js

I have an image which I am trying to show using a spiral with varying thickness depending upon the image pixel. But the thickness of my line/ellipses in spiral is not coming out correctly.

The image I am using: blackcircle on a white background

The image I am getting A spiral of small black dots on a light green background where the black dots have a larger size in the bottom right quarter of the image (when it should have been from the top left corner)

As you can see for whatever reason the bottom right quadrant is getting thick and nothing else, this is happening even if I use other images.

My code:

FG = '#222323';
BG = '#f0f6f0';

function preload() {    
    Img = loadImage('black.png');
}


function setup() {
    createCanvas(500, 500);
    Img.resize(500, 500);
    background(BG);
    fill(FG);
    colorMode(HSB, 255);
    noLoop();
    noStroke(); 
}

function draw() {   
    var r = width;
    var a = 0;
    while (r > 1) {
        strokeWeight(1);
        var x1 = r * cos(a);
        var y1 = r * sin(a);
        
        a += 0.01;
        r -= 0.03;
        
        var x2 = r * cos(a);
        var y2 = r * sin(a);
        
        let c = Img.get(x1, y1);
        let b = brightness(c);
        const val = map(b, 0, 255, 1, 10);
        
        push();
        translate(width/2, height/2);
        ellipse(x1, y1, val, val);
        pop();
    }
}

Upvotes: 1

Views: 142

Answers (1)

George Profenza
George Profenza

Reputation: 51837

The coordinates where you're sampling from aren't the same where you're rendering.

Because you use translate(), the ellipses themselves are offset based on the centre (but there's nothing changing where you're sampling from in the image (x1,y1).

You can offset x1,y1 to take the centre of the stage into account and then you sample from the right location (and draw offset to the centre):

FG = '#222323';
BG = '#f0f6f0';

function preload() {    
    // Img = loadImage('black.png');
  Img = loadImage('');
}


function setup() {
    createCanvas(500, 500);
    Img.resize(500, 500);
    background(BG);
    fill(FG);
    colorMode(HSB, 255);
    noLoop();
    noStroke(); 
}

function draw() {   
    var r = width;
    var a = 0;
    
    const centerX = width * 0.5;
    const centerY = height * 0.5;
    
    while (r > 1) {
        
        var x1 = centerX + (r * cos(a));
        var y1 = centerX + (r * sin(a));
        
        a += 0.01;
        r -= 0.03;
        
        let c = Img.get(x1, y1);
        let b = brightness(c);
        const val = map(b, 0, 255, 1, 10);
        
      ellipse(x1, y1, val, val);
    }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/p5.js/1.4.1/p5.min.js"></script>

(Notice the central area where the source image has a black circle is what based on your mapping. You can reverse that as well if that's more interesting (const val = map(b, 0, 255, 10, 1);))

Upvotes: 1

Related Questions