zoukankan      html  css  js  c++  java
  • MSChart的常用属性和事件

    最常用的属性包括

    ChartAreas:增加多个绘图区域,每个绘图区域包含独立的图表组、数据源,用于多个图表类型在一个绘图区不兼容时。

    AlignmentOrientation:图表区对齐方向,定义两个绘图区域间的对齐方式。

    AlignmentStyle:图表区对齐类型,定义图表间用以对其的元素。

    AlignWithChartArea:参照对齐的绘图区名称。

    InnerPlotPosition:图表在绘图区内的位置属性。

    Auto:是否自动对齐。

    Height:图表在绘图区内的高度(百分比,取值在0-100)

    Width:图表在绘图区内的宽度(百分比,取值在0-100)

    X,Y:图表在绘图区内左上角坐标

    Position:绘图区位置属性,同InnerPlotPosition。

    Name:绘图区名称。

    Axis:坐标轴集合

    Title:坐标轴标题

    TitleAlignment:坐标轴标题对齐方式

    Interval:轴刻度间隔大小

    IntervalOffset:轴刻度偏移量大小

    MinorGrid:次要辅助线

    MinorTickMark:次要刻度线

    MajorGrid:主要辅助线

    MajorTickMark:主要刻度线

    DataSourceID:MSChart的数据源。

    Legends:图例说明。

    Palette:图表外观定义。

    Series:最重要的属性,图表集合,就是最终看到的饼图、柱状图、线图、点图等构成的集合;可以将多种相互兼容的类型放在一个绘图区域内,形成复合图。

    IsValueShownAsLabel:是否显示数据点标签,如果为true,在图表中显示每一个数据值

    Label:数据点标签文本

    LabelFormat:数据点标签文本格式

    LabelAngle:标签字体角度

    Name:图表名称

    Points:数据点集合

    XValueType:横坐标轴类型

    YValueType:纵坐标轴类型

    XValueMember:横坐标绑定的数据源(如果数据源为Table,则填写横坐标要显示的字段名称)

    YValueMembers:纵坐标绑定的数据源(如果数据源为Table,则填写纵坐标要显示的字段名称,纵坐标可以有两个)

    ChartArea:图表所属的绘图区域名称

    ChartType:图表类型(柱形、饼形、线形、点形等)

    Legend:图表使用的图例名称

    Titles:标题集合。

    width:MSChart的宽度。

    height:MSChart的高度。

    常用事件:

    Series1.Points.DataBind()
    绑定数据点集合,如果要在一个MSChart控件的一个绘图区(ChartArea)内添加多个不同数据源的图表,就用这个主动绑定数据集合的方法。可以将表中指定字段的值绑定到指定的坐标轴上。

    MSChart1.DataBind()
    给整个MSChart绑定一个数据源,该MSChart中的图表全部可以使用该数据源作为统计来源。

    示例:

    private void BindGrid()
            {
                chart2.Width = 800;
                chart2.Height = 600;

                //作图区的显示属性设置
                //chart2.ChartAreas["ChartArea1"].AxisX.IsMarginVisible = false;
                //chart2.ChartAreas["ChartArea1"].Area3DStyle.Enable3D = false;
                //背景色设置
                chart2.ChartAreas["ChartArea1"].ShadowColor = Color.Transparent;
                chart2.ChartAreas["ChartArea1"].BackColor = Color.FromArgb(209, 237, 254);         //该处设置为了由天蓝到白色的逐渐变化
                chart2.ChartAreas["ChartArea1"].BackGradientStyle = GradientStyle.TopBottom;
                chart2.ChartAreas["ChartArea1"].BackSecondaryColor = Color.White;
                //X,Y坐标线颜色和大小
                chart2.ChartAreas["ChartArea1"].AxisX.LineColor = Color.FromArgb(64, 64, 64, 64);
                chart2.ChartAreas["ChartArea1"].AxisY.LineColor = Color.FromArgb(64, 64, 64, 64);
                chart2.ChartAreas["ChartArea1"].AxisX.LineWidth = 2;
                chart2.ChartAreas["ChartArea1"].AxisY.LineWidth = 2;
                chart2.ChartAreas["ChartArea1"].AxisX.Title = "时间";
                chart2.ChartAreas["ChartArea1"].AxisY.Title = "灰量";
                //中间X,Y线条的颜色设置
                chart2.ChartAreas["ChartArea1"].AxisX.MajorGrid.LineColor = Color.FromArgb(64, 64, 64, 64);
                chart2.ChartAreas["ChartArea1"].AxisY.MajorGrid.LineColor = Color.FromArgb(64, 64, 64, 64);
                //X.Y轴数据显示间隔
                chart2.ChartAreas["ChartArea1"].AxisX.Interval = 1.0; //X轴数据显示间隔
                chart2.ChartAreas["ChartArea1"].AxisX.IntervalType = DateTimeIntervalType.Days;
                chart2.ChartAreas["ChartArea1"].AxisX.IntervalOffset = 0.0;
                chart2.ChartAreas["ChartArea1"].AxisX.IntervalOffsetType = DateTimeIntervalType.Days;
                chart2.ChartAreas["ChartArea1"].AxisX.LabelStyle.Format = "M-d";
                chart2.ChartAreas["ChartArea1"].AxisY.Interval = 200;//y轴数据显示间隔
                //X轴线条显示间隔
                //chart2.ChartAreas["ChartArea1"].AxisX.MajorGrid.IntervalType = DateTimeIntervalType.Hours;
                chart2.Palette = ChartColorPalette.Pastel;

                string sql = "select sum(zhl) zhl, input_date, ash_type_name from (" +
                " select sum(t.second_load - t.first_load) as zhl," +
                       " to_date(to_char(t.input_date, 'dd/mm/yyyy')||'00:00','dd/mm/yyyy hh24:mi:ss') as input_date," +
                       " u.ash_type_name" +
                 " from transportation_bill t, ash_type u" +
                 " where t.ash_type_id = u.ash_type_id" +
                  " and (t.input_date between to_date('2009-6-11','yyyy-mm-dd') and to_date('2009-6-20','yyyy-mm-dd'))" +//此处加按日期查询的条件
                   " and t.sale_organization_id = 1" +//此处加用户所在机构查询条件
                 " group by u.ash_type_name, t.input_date" +
                 " order by t.input_date" +
                 ")" +
                 " group by ash_type_name,input_date" +
                " order by input_date";
                DataTable dt2 = OracleHelper.ExecuteDataTable(OracleHelper.ConnectionString, CommandType.Text, sql, "T", null);
                chart2.DataBindCrossTable(dt2.DefaultView, "ash_type_name", "input_date", "zhl", "", PointSortOrder.Ascending);

                foreach (Series sr in chart2.Series)
                {
                    sr.ChartType = SeriesChartType.Spline;
                    sr.XValueType = ChartValueType.Date;
                    sr.MarkerStyle = MarkerStyle.Circle;//散点样式
                    sr.MarkerSize = 5;//默认是5,散点大小
                    sr.MarkerStep = 1;//默认是1,散点频率
                    sr.MarkerColor = 1;//默认是透明,散点颜色
                    sr.BorderWidth = 2;
                }

                //chart2.Legends["Default"].Docking = Docking.Left;
            }

  • 相关阅读:
    【作业】Python
    【作业】判断某个数是否是素数,返回结果
    【案例】Python之列表反转
    Python模块
    【作业】Python-数据转换:将列表["mo","deng","ge"]和[1,2,3] 转换成[("mo",1),("deng",2),("ge",3)]
    【个人笔记】Python-zip()函数
    【作业】Python-数据转换:将列表[3,7,0,5,1,8]中大于5元素置为0,小于5的元素置为1
    【作业】Python-将元组(1,2,3) 和集合{"four",5,6}合成一个列表
    【作业】Python-函数封装:交换两个变量的值
    【个人笔记】Python-sorted()函数
  • 原文地址:https://www.cnblogs.com/cuiwenke/p/1689202.html
Copyright © 2011-2022 走看看