我有WinForm与图表和数据库.Chart从数据库获取数据。如果没有数据,则图表不可见。我想在图表中显示一条消息。例如:“还没有数据。”我可以做吗?
if (chart1["Series1"].Points.Count == 0)
{
???
}
..在图表中显示一条消息。我能做到吗?
当然。实际上有很多方法,从设置图表的Title
到使用Paint
事件和DrawString
或创建TextAnnotation
等。
后两个选项很容易居中,即使调整图表大小,它们也会保持位置。
例1 - a TextAnnotation
:
TextAnnotation ta = new TextAnnotation();
设置如下:
ta.Text = "No Data Yet";
ta.X = 45; // % of the..
ta.Y = 45; // chart size
ta.Font = new Font("Consolas", 20f);
ta.Visible = false; // first we hide it
chart1.Annotations.Add(ta);
每当数据发生变化时显示:
ta.Visible = (chart1.Series[seriesNameOrIndex].Points.Count == 0)
示例2 - 在Paint
事件中绘制消息:
private void chart1_Paint(object sender, PaintEventArgs e)
{
if (chart1.Series[seriesNameOrIndex].Points.Count == 0)
{
using (Font font = new Font("Consolas", 20f))
using (StringFormat fmt = new StringFormat()
{ Alignment = StringAlignment.Center, LineAlignment = StringAlignment.Center })
e.Graphics.DrawString("No data yet",
font, Brushes.Black, chart1.ClientRectangle, fmt);
}
}
这应该保持自己更新,因为添加或删除DataPoints
将触发Paint
事件。
顺便说一句:测试集合包含任何数据的推荐方法是使用Linq Any()
函数:
(!chart1.Series[seriesNameOrIndex].Points.Any())
它的意图尽可能快,清晰。