繁体   English   中英

C#图表轴标签未正确格式化

[英]C# Chart Axis Labels Not Formatting Properly

假设我们有一个访问远程数据库的方法调用,大约需要1秒钟来完成并返回一个DataTable (在下面模拟):

DataTable GetData()
{
    Thread.Sleep(1000); // simulated delay

    var dt = new DataTable("DataTable");
    dt.Columns.Add("DateTime", typeof(DateTime));
    dt.Columns.Add("Value", typeof(double));

    var rand = new Random();
    var date = new DateTime(2016, 1, 1);
    for (int i = 0; i < 1000; i++)
    {
        dt.Rows.Add(date, rand.NextDouble() * 100);

        date = date.AddHours(12);
    }

    return dt;
}

从此方法返回的DataTable用于使用单个行系列填充Chart 为什么此代码显示正确,格式正确的DateTime X-Axis标签:

async void MainForm_Load(object sender, EventArgs e)
{
    var data = GetData();
    chart.DataSource = data;
    chart.DataBind();
}

带有DateTime X轴的图表

这段代码显示错误的,未格式化的X轴标签?

async void MainForm_Load(object sender, EventArgs e)
{
    var data = await Task.Run(() => GetData());
    chart.DataSource = data;
    chart.DataBind();
}

带有破X轴的图表

请注意,即使使用第二个版本,删除Thread.Sleep()调用也可以解决此问题。

答案在于chart.Series[0].XValueType

首先,几个陈述:

  1. XValueType默认为Auto ,如果未明确指定,则在Paint事件之前解析为特定类型。

    这不是显而易见的事情,我通过反编译来源找到它; 如果你想跟随我的研究,这里有一些里程碑:

    • Chart构造函数:

      this._dataManager.Initialize();

    • DataManager.Initialize

      chartImage.BeforePaint += ChartPicture_BeforePaint

    • DataManager.ChartPicture_BeforePaint
    • DataManager.PrepareData
    • Series.PrepareData =>

      if (this._xValueType == ChartValueType.Auto) { this._xValueType = ChartValueType.Double;

  2. DataBind将尝试基于DataSourceAuto解析为特定类型。 如果它不是 Auto ,则不会尊重DataSource数据类型。

好的,你的样本中发生了什么:

  1. 当你不使用任务时, Form_Load整个主体同步执行; 当您在图表上调用DataBind时,它具有Auto for XValueType并且基于提供DataSource将其解析为DateTime

  2. 当您使用sleep with sleep时,在初始化DataSource之前会发生Paint事件,这XValueType解析为Double 在此之后,您绑定DataSource,它使用DateTime浮点表示。

如何解决所有混乱局面? 有很多方法,但所有方法都基于图表值类型:

  • Form_Load显式指定值类型
  • 删除系列并在DataBind之前添加新系列
  • DataBind之前显式指定值类型
  • ...

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM