1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86
| window.addEventListener('load', ev => {
// le DOM est construit et la page web est visible
// début code du test
let canvas = document.getElementById("canvas");
function getElementPosition(obj) {
let
curleft = 0,
curtop = 0;
if (obj.offsetParent) {
do {
curleft += obj.offsetLeft;
curtop += obj.offsetTop;
} while (obj = obj.offsetParent);
return {
x: curleft,
y: curtop
};
}
return undefined;
}
function getEventLocation(element, event) {
let pos = getElementPosition(element);
return {
x: (event.pageX - pos.x),
y: (event.pageY - pos.y)
};
}
function rgbToHex(r, g, b) {
if (r > 255 || g > 255 || b > 255) throw "Invalid color component";
return ((r << 16) | (g << 8) | b).toString(16);
}
function drawImageFromWebUrl(sourceurl) {
let img = new Image();
img.addEventListener("load", function () {
canvas.getContext("2d").drawImage(img, 0, 0, img.width, img.height, 0, 0, canvas.width, canvas.height);
});
img.setAttribute("src", sourceurl);
}
drawImageFromWebUrl("");
canvas.addEventListener('click', ev => {
let eventLocation = getEventLocation(ev.target, ev);
let coord = "x=" + eventLocation.x + ", y=" + eventLocation.y;
// Get the data of the pixel according to the location generate by the getEventLocation function
let context = canvas.getContext('2d');
let pixelData = context.getImageData(eventLocation.x, eventLocation.y, 1, 1).data;
// If transparency on the image
if ((pixelData[0] == 0) && (pixelData[1] == 0) && (pixelData[2] == 0) && (pixelData[3] == 0)) {
coord += " (Transparent color detected, cannot be converted to HEX)";
}
let hex = "#" + ("000000" + rgbToHex(pixelData[0], pixelData[1], pixelData[2])).slice(-6);
if (hex === '#2cb0cf'){
console.log(`Clic à la position ${coord} , pixel de couleur ${hex} `);
// Clic à la position x=80, y=87 , pixel de couleur #2cb0cf
}
}, {
capture: false,
passive: true,
once: false
});
// fin code du test
}, {
capture: false,
passive: true,
once: false
}); |