饼图切片点击

Pie chart slice click

我正在尝试单击我从工具箱中以 Windows 形式为 C# 添加的饼图,并显示该切片的详细信息。现在这是我的点击代码。我想知道这是正确的路线还是我应该走的路线。

private void chart1_Click(object sender, EventArgs e)
{
    HitTestResult results = chart1.HitTest((e as MouseEventArgs).X, (e as MouseEventArgs).Y);
}

我也是using System.Windows.Forms.DataVisualization.Charting;

是的,这是正确的方法。

您现在可以测试 DataPoint 是否有效等。

我会使用 MouseClick 顺便说一句,默认情况下它有 MouseEventArgs

您甚至可以编写 MouseMove 事件并使用相同的命中测试来控制光标以显示用户位于数据点上..

这是一个例子:

private void chart1_MouseClick(object sender, MouseEventArgs e)
{
    HitTestResult hit = chart1.HitTest(e.X, e.Y, ChartElementType.DataPoint);

    if (hit.PointIndex >= 0 && hit.Series != null)
    {
        DataPoint dp = chart1.Series[0].Points[hit.PointIndex];
        label1.Text = "Value #" + hit.PointIndex + " = " + dp.XValue;
    }
    else label1.Text = "";
}

private void chart1_MouseMove(object sender, MouseEventArgs e)
{
    HitTestResult hit = chart1.HitTest(e.X, e.Y);
    var dp = hit.Object as DataPoint;
    Cursor = (dp is null) ? Cursors.Default : Cursors.Hand;
}

请注意,这两个事件使用不同的方式来测试命中..!

我喜欢接受的答案。但是这里有一个稍微不同的方法,它使用通用代码进行命中测试,并且还支持悬停和单击图例中的项目。

private int pieHitPointIndex(Chart pie, MouseEventArgs e)
{
    HitTestResult hitPiece = pie.HitTest(e.X, e.Y, ChartElementType.DataPoint);
    HitTestResult hitLegend = pie.HitTest(e.X, e.Y, ChartElementType.LegendItem);
    int pointIndex = -1;
    if (hitPiece.Series != null) pointIndex = hitPiece.PointIndex;
    if (hitLegend.Series != null) pointIndex = hitLegend.PointIndex;
    return pointIndex;
}
private void pie_MouseClick(object sender, MouseEventArgs e)
{
    Chart pie = (Chart)sender;
    int pointIndex = pieHitPointIndex(pie, e);
    if (pointIndex >= 0)
    {
        DataPoint dp = pie.Series[0].Points[pointIndex];
        // do what you want to do with a click
    }
}
private void pie_MouseMove(object sender, MouseEventArgs e)
{
    Chart pie = (Chart)sender;
    int pointIndex = pieHitPointIndex(pie, e);
    if (pointIndex >= 0)
    {
        Cursor = Cursors.Hand;
    }
    else
    {
        Cursor = Cursors.Default;
    }
}
public class CustomChart : Chart
{
    public CustomChart()
    : base()
    {
        // Prevent the button from drawing its own border
        SetStyle(ControlStyles.Selectable, false);
    }
}