如何解决在 Visual Studio 图表 (C#) 中选择时间跨度
是否有可能(也许使用第三方工具)在图表中添加两条可以移动的线,然后在这两条线的边缘获取两个日期(字符串)?
也许这张图更好地描述了问题。它应该与此类似:
已经感谢您的帮助!
解决方法
您可以尝试通过 chart.SelectionRangeChanging 事件来选择时间跨度并获取相应的日期时间。
这是您可以参考的代码示例。
private void Form1_Load(object sender,EventArgs e)
{
var s = new Series();
s.ChartType = SeriesChartType.Column;
var d = new DateTime(2020,10,1);
s.Points.AddXY(d,30);
s.Points.AddXY(d.AddDays(1),20);
s.Points.AddXY(d.AddDays(2),70);
s.Points.AddXY(d.AddDays(3),90);
s.Points.AddXY(d.AddDays(4),80);
s.Points.AddXY(d.AddDays(5),50);
s.Points.AddXY(d.AddDays(6),60);
s.Points.AddXY(d.AddDays(7),80);
s.Points.AddXY(d.AddDays(8),90);
chart1.Series.Clear();
chart1.Series.Add(s);
chart1.Series[0].XValueType = ChartValueType.DateTime;
chart1.ChartAreas[0].AxisX.LabelStyle.Format = "yyyy-MM-dd";
chart1.ChartAreas[0].AxisX.Interval = 1;
chart1.ChartAreas[0].AxisX.IntervalType = DateTimeIntervalType.Days;
chart1.ChartAreas[0].AxisX.IntervalOffset = 1;
chart1.Series[0].XValueType = ChartValueType.DateTime;
DateTime minDate = new DateTime(2020,01).AddSeconds(-1);
DateTime maxDate = new DateTime(2020,08); // or DateTime.Now;
chart1.ChartAreas[0].AxisX.Minimum = minDate.ToOADate();
chart1.ChartAreas[0].AxisX.Maximum = maxDate.ToOADate();
chart1.ChartAreas[0].CursorX.IsUserEnabled = false; // red cursor at SelectionEnd
chart1.ChartAreas[0].CursorX.IsUserSelectionEnabled = true;
chart1.ChartAreas[0].AxisX.ScaleView.Zoomable = false; // zoom into SelectedRange
chart1.ChartAreas[0].AxisX.ScrollBar.IsPositionedInside = true;
}
private void chart1_SelectionRangeChanging(object sender,CursorEventArgs e)
{
double x1 = e.NewSelectionStart;
double x2 = e.NewSelectionEnd;
DateTime date1 = DateTime.FromOADate(x1);
DateTime date2 = DateTime.FromOADate(x2);
txtStart.Text = date1.ToString("yyyy-MM-dd");
txtEnd.Text = date2.ToString("yyyy-MM-dd");
}
结果:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。