Voir le flux RSS

danielhagnoul

Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur

Noter ce billet
par , 06/10/2019 à 18h07 (217 Affichages)
Citation Envoyé par danielhagnoul Voir le message


C'est réalisable !

En partant de How to get the pixel color from a canvas on click or mouse event with Javascript on arrive facilement à gérer un clic sur une couleur précise.

Ici on autorise un clic sur une des petites fenêtres du bus, couleur '#2cb0cf'.

Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part
<canvas id="canvas" width="150" height="150"></canvas>

Code JavaScript : Sélectionner tout - Visualiser dans une fenêtre à part
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
});

Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Viadeo Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Twitter Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Google Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Facebook Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Digg Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Delicious Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog MySpace Envoyer le billet « Rendre un pixel d'une image cliquable uniquement s'il est de la bonne couleur » dans le blog Yahoo

Commentaires