Home >Web Front-end >JS Tutorial >How Can I Get Precise Mouse Click Coordinates on a Canvas Element?
Determining Mouse Click Coordinates on Canvas Elements
Retrieving the precise coordinates of mouse clicks within a canvas element is a common need in various programming applications. The following guide provides a straightforward approach for web browsers including Safari, Opera, and Firefox.
Cross-Browser Solution
To achieve a simple and cross-browser solution, a JavaScript function named getCursorPosition can be defined:
function getCursorPosition(canvas, event) { const rect = canvas.getBoundingClientRect(); const x = event.clientX - rect.left; const y = event.clientY - rect.top; console.log("x: " + x + " y: " + y); }
This function calculates the coordinates relative to the canvas element itself.
Event Handling
To attach this functionality to a canvas element, add an event listener for mouse down events:
const canvas = document.querySelector('canvas'); canvas.addEventListener('mousedown', function(e) { getCursorPosition(canvas, e); });
Once a mouse click is detected, the getCursorPosition function is invoked, and the x and y coordinates of the click are logged to the console.
The above is the detailed content of How Can I Get Precise Mouse Click Coordinates on a Canvas Element?. For more information, please follow other related articles on the PHP Chinese website!