web-dev-qa-db-ja.com

マウスがポイント上にあるときにチャートポイントの値を表示する

グラフがあり、ポインターがポイント上にあるときにユーザーに値を表示してもらいたい。ページ でdigEmAllのヘルプを使用して、グラフ内のポイントの値を検索することで 、次のコードを記述できます。

Point? prevPosition = null; 
ToolTip tooltip = new ToolTip();  

void chart1_MouseMove(object sender, MouseEventArgs e) 
{     
    var pos = e.Location;     
    if (prevPosition.HasValue && pos == prevPosition.Value)         
        return;     
    tooltip.RemoveAll();     
    prevPosition = pos;     
    var results = chart1.HitTest(pos.X, pos.Y, false, ChartElementType.PlottingArea);     
    foreach (var result in results)     
    {         
        if (result.ChartElementType == ChartElementType.PlottingArea)         
        {            
            chart1.Series[0].ToolTip = "X=#VALX, Y=#VALY";          
        }    
    } 
} 

上記のコードにより、ユーザーはポインターが系列の近くのときに値を表示できますが、今度はユーザーに値を表示させる方法ポインターがonポイントのときのみ?交換しました

int k = result.PointIndex;
if (k >= 0)
{
    chart1.Series[0].Points[k].ToolTip = "X=#VALX, Y=#VALY";
}

の代わりに

chart1.Series[0].ToolTip = "X=#VALX, Y=#VALY";

私の問題を解決するために。しかし、それは役に立たなかった。

15
Asma Good

この方法でコードを変更する必要があります。

Point? prevPosition = null;
ToolTip tooltip = new ToolTip();

void chart1_MouseMove(object sender, MouseEventArgs e)
{
    var pos = e.Location;
    if (prevPosition.HasValue && pos == prevPosition.Value)
        return;
    tooltip.RemoveAll();
    prevPosition = pos;
    var results = chart1.HitTest(pos.X, pos.Y, false,
                                    ChartElementType.DataPoint);
    foreach (var result in results)
    {
        if (result.ChartElementType == ChartElementType.DataPoint)
        {
            var prop = result.Object as DataPoint;
            if (prop != null)
            {
                var pointXPixel = result.ChartArea.AxisX.ValueToPixelPosition(prop.XValue);
                var pointYPixel = result.ChartArea.AxisY.ValueToPixelPosition(prop.YValues[0]);

                // check if the cursor is really close to the point (2 pixels around the point)
                if (Math.Abs(pos.X - pointXPixel) < 2 &&
                    Math.Abs(pos.Y - pointYPixel) < 2)
                {
                    tooltip.Show("X=" + prop.XValue + ", Y=" + prop.YValues[0], this.chart1,
                                    pos.X, pos.Y - 15);
                }
            }
        }
    }
}

アイデアは、マウスがポイントに非常に近いかどうかを確認することです。 2その周りのピクセル(ポイント上で正確にになる可能性は非常に低いため)、その場合はツールチップを表示します。

これは完全な動作例です。

24
digEmAll

私はこの解決策を取ります:

カスタムツールチップイベントハンドラーを追加します。

 this.chart1.GetToolTipText += this.chart1_GetToolTipText;

イベントハンドラーを実装します。

  private void chart1_GetToolTipText(object sender, ToolTipEventArgs e)
  {
     // Check selected chart element and set tooltip text for it
     switch (e.HitTestResult.ChartElementType)
     {
        case ChartElementType.DataPoint:
           var dataPoint = e.HitTestResult.Series.Points[e.HitTestResult.PointIndex];
           e.Text = string.Format("X:\t{0}\nY:\t{1}", dataPoint.XValue, dataPoint.YValues[0]);
           break;
     }
  }
7
jreichert

ツールチップよりも優れたオプションとして以下を検討してください...チャートコントロールのラベル機能を使用します。

DataPoint _prevPoint;
void chart1_MouseMove(object sender, MouseEventArgs e)
{
    // this if statement clears the values from the previously activated point.
    if (_prevPoint) {
        _prevPoint.MarkerStyle = MarkerStyle.None;
        _prevPoint.IsValueShownAsLabel = false;
    }

    var result = chart1.HitTest(e.X, e.Y, ChartElementType.DataPoint);
    if (result.ChartElementType == ChartElementType.DataPoint)
    {
        var prop = result.Object as DataPoint;
        if (prop != null)
        {
            prop.IsValueShownAsLabel = true;
            prop.MarkerStyle = MarkerStyle.Star4;
        }
    }
}

私はこれをテストし、現在それを使用しています。それは同様にチャート上のマーカーを表示するので、それは多くのポイントを持つチャートでとてもいいです。

1
iQueue