2017-10-16 15 views
1

J'utilise plotly.js et jquery.Planant sur l'intrigue dans l'intrigue et ayant quelques images apparaissent

Je voudrais avoir un effet de survol personnalisé avec les images. J'ai vu the answer par Etpinard (here est l'aspect et la sensation). Mais je pense que j'ai besoin d'une solution différente.

Ce que je ne veux pas, c'est de travailler avec l'iframe, alors que la solution mentionnée fonctionne avec. Au lieu de cela, je veux me connecter à $("path.point") et y ajouter une fonction de survol.

J'ai étudié ce qui se trouve à l'intérieur du tracé. Donc, voici mon code html:

<head> 
    <script src="https://cdn.plot.ly/plotly-latest.min.js"></script> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 
</head> 

<body> 
    <div id="myDiv"></div> 
    <script src="MakePlot.js"></script> 
    <script src="Mod2.js"></script> 
</body> 

Et voici ce que je vois à l'intérieur:

enter image description here

enter image description here

J'ai essayé de créer un code, qui pourrait démontrer le caractère image 'sur le vol stationnaire, mais cela n'a pas fonctionné. J'ai donc essayé la chose du journal:

$(document.getElementById('myDiv')).ready(function() { 
    $("path.point").hover(function() { 
     console.log("SUCCESS!"); 
    }, function() {}) 
}); 

Et cela ne montre rien. Donc je suppose que je m'adresse à l'objet (le point de chemin de Plotly) d'une mauvaise façon.

Juste au cas où, voici le code pour l'apparence de l'image:

$(document.getElementById('myDiv')).ready(function() { 
    $(this).css({backgroundColor:"#00FFFFFF", color: "#00FFFFFF"}).prepend('<img src="2368518-ghost.jpg" alt="" />');}, 
    function() { 
     $(this).css({backgroundColor: "#00FFFFFF", color: "#00FFFFFF"}); 
     $('img', this).remove()[0]; 
}); 

C'est le code de that answer.

+0

Y at-il raison de ne pas utiliser les hoverevents de Plotly? –

Répondre

2

Vous pouvez utiliser le hoverevents de Plotly sans avoir besoin de jQuery. Les données d'événement sont utilisées pour afficher une image basée sur l'index de la trace (curveNumber dans le code ci-dessous).

var trace1 = { 
 
    x: [1, 2, 3, 4, 5], 
 
    y: [1, 6, 3, 6, 1], 
 
    mode: 'markers', 
 
    type: 'scatter', 
 
}; 
 

 
var trace2 = { 
 
    x: [1.5, 2.5, 3.5, 4.5, 5.5], 
 
    y: [4, 1, 7, 1, 4], 
 
    mode: 'markers', 
 
    type: 'scatter', 
 
}; 
 

 
var data = [trace1, trace2]; 
 
images = ['', 
 
    ''] 
 
Plotly.newPlot('myDiv', data, { 
 
    hovermode: 'closest' 
 
}); 
 

 

 
document.getElementById('myDiv').on('plotly_hover', function(data) { 
 
    console.log(data.points[0].curveNumber); 
 
    document.getElementById('image').innerHTML="<img src='" + images[data.points[0].curveNumber] + "' />"; 
 
});
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script> 
 

 
<div id="myDiv"></div> 
 
<div id='image'></div>

+1

Je pensais que cela ne fonctionnait qu'avec les données de texte. D'une manière ou d'une autre, je pensais que c'était ce hover apparaissant juste au-dessus du point. Je vous remercie! –

+0

Je suppose que jQuery serait toujours utile, si je voudrais faire une image en vol stationnaire juste au-dessus de la dispersion. Je vais probablement expérimenter plus avec les classes etc et l'ajouter à la q/a dans le futur. –

+0

Jetez un oeil à D3, la bibliothèque sur laquelle est construit Plotly. J'ai son propre langage de sélection et il est plus facile de manipuler les graphes de Plotly. –