Search code examples
javascriptarraysmousedistanceclosest

JavaScript Closest point from mouse


Before you comment, yes i have checked other questions aswell... like this article, or this one, or maybe even this one. However, i couldn't find how to set the point of origin. So, let's say i have an array picture X coords and picture Y coords

(on a grid of 100*100) x /y 92/81 82/47 81/03

Now i have the mouseX and mouseY. Does anyone know how to make a function that gives you the closest point x and y values in JavaScript?

Thanks in advance!


Solution

  • Just do some vecor math. Given the images and the touch position:

     const coords = [[92, 81],  [82, 47], [81, 03]];
     const touchX = 57, touchY = 84;
    

    Just go over them and calculate the distance vecors length:

    let closest = [null, null];
    let distance = Infinity;
    
    for(const [x, y] of coords){
      let d = Math.sqrt((touchX - x) ** 2 + (touchY - y) ** 2);
      if(d < distance){
        closest = [x, y];
        distance = d;
      }
    }
    

    Vectors

    Calculating the length