Partager via


Interactivité

Selon le contrôle Chart que vous utilisez, vous pouvez employer diverses fonctionnalités et techniques pour le rendre interactif.

Interactivité dans ASP.NET

Dans le contrôle Chart pour ASP.NET, vous pouvez utiliser des images interactives côté client pour une expérience utilisateur plus riche dans l'interactivité de vos graphiques.Pour activer les images interactives, affectez à la propriété IsMapEnabled la valeur True.

Vous pouvez ensuite effectuer une ou plusieurs des opérations suivantes :

  • Spécifier les propriétés de zone réactive dans un élément spécifique du contrôle Chart.Vous pouvez le faire dans la plupart des éléments, tels que Axis, Series, DataPoint, Annotation, StripLine, LegendCellColumn, LegendItem et LegendCell.

    Dans chacun de ces éléments, utilisez les propriétés Tooltip et Url.Elles correspondent aux attributs href et alt de la balise HTML MAP.Pour spécifier des attributs de zone réactive supplémentaires, utilisez la propriété MapAreaAttributes.Pour spécifier plusieurs attributs, séparez-les par des espaces.Par exemple, vous pouvez spécifier le code suivant dans cette propriété pour enregistrer un script côté client qui affiche un autre graphique sous forme d'info-bulle contextuelle :

    onmouseover=\"DisplayTooltip(' <img src=DetailedChart.aspx />');\"
    

    Notez que, pour que le script ci-dessus fonctionne, le contrôle Chart de DetailedChart.aspx doit utiliser comme type de rendu les flux binaires.Pour plus d'informations, consultez Rendu de l'image du graphique.

  • Définir manuellement des zones réactives dans votre contrôle Chart à l'aide de la propriété de collection MapAreas (une collection d'objets MapArea).

    Vous pouvez définir dans chaque objet MapArea la forme, les coordonnées, l'URL et l'info-bulle de la zone réactive.Ils correspondent aux attributs respectifs suivants de la balise HTML MAP : shape, coord, href et alt.

    Pour spécifier des attributs de zone réactive supplémentaires qui n'ont pas de propriété correspondante dans l'objet MapArea, spécifiez-les dans la propriété MapAreaAttributes.

  • Utiliser la propriété PostBackValue dans MapArea ou chacun des éléments du contrôle Chart mentionnés ci-dessus pour définir une valeur de publication pour ImageMapEventHandler, puis récupérer la valeur de publication via la propriété PostBackValue lorsque l'événement est déclenché.

    [!REMARQUE]

    Vous pouvez utiliser les mots clés applicables dans tous ces attributs.Pour plus d'informations, consultez Mots clés.

Le code suivant sélectionne et désélectionne l'image d'une cellule de légende chaque fois que l'utilisateur clique sur cette cellule.

Imports System.Web.UI.DataVisualization.Charting
...
' Set the legend cell to an image showing selection cleared
Chart1.Legends(0).CustomItems(0).Cells(0).Image = "./cleared.png"
Chart1.Legends(0).CustomItems(0).Cells(0).PostBackValue = "item 1"
' Add an ImageMapEventHandler to the Chart.Click event
Me.Chart1.Click += New ImageMapEventHandler(Me.Chart1_Click)
...
' Change the selection image when the user clicks on the legend cell
Private  Sub Chart1_Click(ByVal sender As Object, ByVal e As System.Web.UI.WebControls.ImageMapEventArgs)
   If e.PostBackValue = "item 1" Then
      Dim cell As LegendCell = Chart1.Legends(0).CustomItems(0).Cells(0)
      cell.Image = (cell.Image = "./cleared.png") ? "./selected.png" : "./cleared.png"
   End If
End Sub
using System.Web.UI.DataVisualization.Charting;
...
// Set the legend cell to an image showing selection cleared
Chart1.Legends[0].CustomItems[0].Cells[0].Image = "./cleared.png";
Chart1.Legends[0].CustomItems[0].Cells[0].PostBackValue = "item 1";
// Add an ImageMapEventHandler to the Chart.Click event
this.Chart1.Click += new ImageMapEventHandler(this.Chart1_Click);
...
// Change the selection image when the user clicks on the legend cell
private void Chart1_Click(object sender, System.Web.UI.WebControls.ImageMapEventArgs e)
{
   if (e.PostBackValue == "item 1")
   {
      LegendCell cell = Chart1.Legends[0].CustomItems[0].Cells[0];
      cell.Image = (cell.Image == "./cleared.png") ? "./selected.png" : "./cleared.png";
   }
}

Interactivité dans les Windows Forms

Dans le contrôle Chart pour les Windows Forms, vous utilisez les événements de souris et la méthode HitTest pour permettre l'interactivité du graphique.Vous pouvez également utiliser des curseurs, le défilement et le zoom.Pour plus d'informations, consultez Curseurs, zoom et défilement.

L'exemple de code suivant utilise l'événement OnMouseMove pour mettre en surbrillance un point de données lorsque le curseur se déplace au-dessus.

Me.Chart1.MouseMove += New System.Windows.Forms.MouseEventHandler(Me.Chart1_MouseMove)
...
Private  Sub Chart1_MouseMove(ByVal sender As Object, ByVal e As System.Windows.Forms.MouseEventArgs)
   ' Call HitTest
   Dim result As HitTestResult =  Chart1.HitTest(e.X,e.Y) 
 
   ' Reset Data Point Attributes
   Dim point As DataPoint
   For Each point In Chart1.Series(0).Points
   poInteger.BackSecondaryColor = Color.Black
   poInteger.BackHatchStyle = ChartHatchStyle.None
   poInteger.BorderWidth = 1
   Next
 
   ' If the mouse if over a data point
   If result.ChartElementType = ChartElementType.DataPoint Then
      ' Find selected data point
      Dim point As DataPoint =  Chart1.Series(0).Points(result.PointIndex) 
 
      ' Change the appearance of the data point
      poInteger.BackSecondaryColor = Color.White
      poInteger.BackHatchStyle = ChartHatchStyle.Percent25
      poInteger.BorderWidth = 2
   Else 
      ' Set default cursor
      Me.Cursor = Cursors.Default
   End If
End Sub
this.Chart1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.Chart1_MouseMove);
...
private void Chart1_MouseMove(object sender, System.Windows.Forms.MouseEventArgs e)
{
   // Call HitTest
   HitTestResult result = Chart1.HitTest( e.X, e.Y );

   // Reset Data Point Attributes
   foreach( DataPoint point in Chart1.Series[0].Points )
   {
   point.BackSecondaryColor = Color.Black;
   point.BackHatchStyle = ChartHatchStyle.None;
   point.BorderWidth = 1;
   }

   // If the mouse if over a data point
   if(result.ChartElementType == ChartElementType.DataPoint)
   {
      // Find selected data point
      DataPoint point = Chart1.Series[0].Points[result.PointIndex];

      // Change the appearance of the data point
      point.BackSecondaryColor = Color.White;
      point.BackHatchStyle = ChartHatchStyle.Percent25;
      point.BorderWidth = 2;
   }
   else
   {
      // Set default cursor
      this.Cursor = Cursors.Default;
   }
}

Voir aussi

Référence

System.Windows.Forms.DataVisualization.Charting

System.Web.UI.DataVisualization.Charting

Concepts

Personnalisation et événements

Autres ressources

Rubriques avancées