We are about to switch to a new forum software. Until then we have removed the registration on this forum.
I'm trying to get the color of the pixel that my cursor is on with get(mouseX, mouseY) and compare it in an if statement with a color. Somehow this doesnt work in p5js but does in processing. Am I doing something wrong or is this a bug?
Find below my code.
function setup() {
    fillColor = color(0, 0, 100);
}
function overTriangle() {
    if (get(mouseX, mouseY) == fillColor) {
        return true;
    }
    else {
        return false;
    }
}
overTriangle !always! returns false.
Answers
AFAIK, get() w/ coordinates returns an Array rather than a p5.Color object:
http://p5js.org/reference/#/p5/get
Framework p5.js is under heavy development right now.
Lotsa devs are changing its internal behavior as they please.
And it's steering p5.js away from Processing's behavior unfortunately! [-(
Right now, get() is returning some very weird array w/ 16 elements! 8-}
At least for the time being, we're gonna need to check the 1st 3 elements of it.
We can paste the code & run it from here btW: http://p5js.org/reference/#/p5/clear
I had this idea before, I tried it but it still doesnt work for some reason.
Heres my final code:
I believe you didn't spot where the 1st thing I said was that get() returns an Array? :-<
That's why we added the loop, or am I getting something wrong here?
Check out both web references: :-B
However I've just read color()'s reference and it says it also returns an Array.
But that is very untrue! But if you insist on using it, grab its rgba's property like this:
P.S.: I believe it's better off to change
c.lengthto merely3within isMouseOverColor():So it's more guaranteed to skip checking out the alpha property as well. ;;)
thanks, that did the trick ;-)