IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Événement onClick avec filtre / D3JS


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Etudiant L3 MIAGE
    Inscrit en
    Juin 2014
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Etudiant L3 MIAGE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 36
    Points : 26
    Points
    26
    Par défaut Événement onClick avec filtre / D3JS
    Bonjour à tous,

    j'ai un projet de visualisation de données, actuellement ma visualisation de données fonctionne correctement et je veux désormais rendre ma page un peut plus dynamique :

    J'aimerai donc qu'en cliquant sur un rectangle de ma légende seul les points correspondant à cet élément de légende ne s'affichent sur mon graphe, l'élément commun à la légende et à mes points de graphe serait par exemple la couleur (rectangle bleu = points bleus ).

    Mon problème est que je n'arrive pas a sélectionner la couleur de l'élément sur lequel je clique et ensuite je ne sais pas comment affecter un filtre à mon graphique.

    Si vous avez des idées ...
    merci d'avance pour vos idées !

  2. #2
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2014
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Janvier 2014
    Messages : 21
    Points : 50
    Points
    50
    Par défaut
    Bonjour,

    voici un petit exemple pour la récupération de la couleur.
    En ce qui concerne la partie graphique, il faudrait que tu nous dise ce que tu utilise comme lib

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    <html>
    <head>
      <script type="text/javascript">
        function clickrectangle(color)
        {
          console.log(color);
        }
      </script>
    </head>
    <body>
    <div style="background:RED;" onclick="clickrectangle(this.style.background)">RED</div>
    <div style="background:GREEN;" onclick="clickrectangle(this.style.background)">GREEN</div>
    <div style="background:BLUE;" onclick="clickrectangle(this.style.background)">BLUE</div>
    </body>
    </html>

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Etudiant L3 MIAGE
    Inscrit en
    Juin 2014
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Etudiant L3 MIAGE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 36
    Points : 26
    Points
    26
    Par défaut
    J'utilise la librairie D3.JS pour la visualisation des données.

    J'ai essayé une chose comme la suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    d3.selectAll("#legende").on("mouseover", function(da, indLegende) {
                d3.selectAll("circles").style("opacity", function(db, indCircle) { cVal = (indCircle == indLegende) ? 1 : 0; return opacityVal; } );
    });

    Cela met en opacité à 1 le premier cercle de mon tableau quand je passe ma souris sur mon premier élément de légende et l'opacité des autres cercles à zéro, le deuxième élément de mon tableau quand je passe ma souris sur le deuxième élément de légende etc ...

    Et moi je veux que ça m'affiche les points correspondants à ma légende et c'est là que je bloque !

  4. #4
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2014
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Janvier 2014
    Messages : 21
    Points : 50
    Points
    50
    Par défaut montrer cacher une courbe sur simple clique de sa légende avec d3.js
    Salut,

    il est plus utile de montrer/cacher une courbe en cliquant sur sa légende.

    par example :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    d3.selectAll("#legende").on("click",function(){
        var color = d3.select(this).attr("stroke");
        d3.selectAll("path[stroke="+color+"]").each(function(){this.style.opacity=this.style.opacity==0?1:0;});
    });

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    Etudiant L3 MIAGE
    Inscrit en
    Juin 2014
    Messages
    36
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Etudiant L3 MIAGE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 36
    Points : 26
    Points
    26
    Par défaut
    Le problème c'est que je ne veux pas modifier un seul point mais plusieurs sur le clique légende, c'est là que ça pêche !

  6. #6
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2014
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Janvier 2014
    Messages : 21
    Points : 50
    Points
    50
    Par défaut
    le code précédent modifie tous les path de la même couleur que celle de ta legende

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Dojo] Attacher une fonction à l'événement onClick avec dom-attr.set()
    Par Gueknow dans le forum Bibliothèques & Frameworks
    Réponses: 0
    Dernier message: 17/10/2014, 17h12
  2. évènement onClick avec Firefox
    Par Bugger24 dans le forum Général JavaScript
    Réponses: 21
    Dernier message: 15/01/2010, 13h47
  3. Ajouter un évènement onclick avec un argument au callback
    Par _jey_ dans le forum Général JavaScript
    Réponses: 22
    Dernier message: 17/07/2009, 15h24
  4. évènement onclick avec php
    Par canary dans le forum Langage
    Réponses: 5
    Dernier message: 25/03/2009, 23h09
  5. Erreur avec l'évènement OnClick de ListView
    Par xenos dans le forum Composants VCL
    Réponses: 2
    Dernier message: 21/03/2006, 14h54

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo