【转载】关于CHART控件使用的一个例子

关于CHART控件使用的一个例子--Captain_Amazing

最近一段时间, 有用到WinForm的chart控件, 主要是做了一个纺织行业的验布数据的图表显示, 比如长度值和重量值的曲线绘制,

以此图表, 相关人员则可判断哪些检验数据是错误的, 后来, 又安排我检查一个保安人员夜间巡查情况的事, 我就又开始使用chart控件

了, 折腾了大半天, 也没弄好, 周日在家, 不死心, 又反复调试, 终于功夫不负有心人, 成功自定义显示了"X轴", 在此写下来, 以供以后参考! 

 效果见图, 比如2022/11/2这天, 1点多, 3点多巡逻了, 留下了巡检记录数据, 这个是厂里的巡更棒, 市面上很常见, 可以下载到电脑上

下面是代码(主要是思想, 算是DEMO)

private void Form1_Load(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add("patrolDate", typeof(DateTime));
            dt.Columns.Add("patrolTime", typeof(float));
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/2"), 0.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/2"), 3.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/3"), 1.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/3"), 4.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/8"), 1.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/8"), 4.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/22"), 1.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/22"), 4.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/30"), 1.3F });
            dt.Rows.Add(new object[] { DateTime.Parse("2022/11/30"), 4.3F });

            for (int i = 0; i < dt.Rows.Count; i++)
            {
                chart1.Series[0].Points.AddXY(dt.Rows[i]["patrolDate"], dt.Rows[i]["patrolTime"]);
                //设置X轴字体绘制角度
                chart1.ChartAreas[0].AxisX.LabelStyle.Angle = 90;
                CustomLabel label = new CustomLabel();
                label.Text = ((DateTime)dt.Rows[i]["patrolDate"]).ToShortDateString();
                //定义自定义标签的位置, 显示标签的关键代码
                label.FromPosition = ((DateTime)dt.Rows[i]["patrolDate"]).ToOADate() - 1;
                label.ToPosition = ((DateTime)dt.Rows[i]["patrolDate"]).ToOADate() + 1;
                //显示网格线
                label.GridTicks = GridTickTypes.Gridline;
                chart1.ChartAreas[0].AxisX.CustomLabels.Add(label);

            }

        }

主要容易失败的地方, 在于X轴标签显示上, 网上有贴子说日期时间类型不能在此使用, 是不对的, 需要设置

CustomLabel的FromPosition和ToPosition属性, 这才是自定义轴标签的关键所在, 这个是在Chart控件的

ChartAreas集合的Axes集合中的X axis中定义的, chart控件比较庞大, 需要慢慢消化.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值