使用C#画图(饼图折线图)

 public PlaceHolder PlaceHolder1; //显示图像的控件

各个图像的类别名称如下:

   PictureType    图形种类    5    chChartTypeBarClustered    簇状条形图    0    NULL

PictureType    图形种类    7    chChartTypeBarClustered3D    三维簇状条形图    0    NULL

PictureType    图形种类    6    chChartTypeBarStacked    堆积条形图    0    NULL

PictureType    图形种类    8    chChartTypeBarStacked3D    三维堆积条形图    0    NULL

PictureType    图形种类    1    chChartTypeColumnClustered    簇状柱形图    0    NULL

PictureType    图形种类    3    chChartTypeColumnClustered3D    三维簇状柱形图    0    NULL

PictureType    图形种类    2    chChartTypeColumnStacked    堆积柱状图    1    NULL

PictureType    图形种类    4    chChartTypeColumnStacked3D    三维堆积柱形图    0    NULL

PictureType    图形种类    13    chChartTypeLine    折线图    0    NULL

PictureType    图形种类    15    chChartTypeLineMarkers    数据点折线图    0    NULL

PictureType    图形种类    14    chChartTypeLineStacked    堆积折线图    0    NULL

PictureType    图形种类    16    chChartTypeLineStackedMarkers    堆积数据点折线图    0    NULL

PictureType    图形种类    17    chChartTypePie    饼图    1    NULL

PictureType    图形种类    19    chChartTypePie3D    三维饼图    0    NULL

PictureType    图形种类    18    chChartTypePieExploded    分离型饼图    0    NULL

PictureType    图形种类    20    chChartTypePieExploded3D    分离型三维饼图    0    NULL

PictureType    图形种类    9    chChartTypeSmoothLine    平滑线图    0    NULL

PictureType    图形种类    10    chChartTypeSmoothLineMarkers    数据点平滑线图    0    NULL

PictureType    图形种类    11    chChartTypeSmoothLineStacked    堆积平滑线图    0    NULL

PictureType    图形种类    12    chChartTypeSmoothLineStackedMarkers    堆积数据平滑线图    0    NULL

 取图像的方法如下:

/// </summary>
        /// <param name="dbDtViewWrk">传递的数据</param>
        /// <param name="strAbsolutePath">绝对路径</param>
        /// <param name="strRelativePath">相对路径</param>
        /// <param name="ChartType">要画的图格式(饼图或者折线图等)</param>
        /// <param name="strTitle">统计名称</param>
public void PaintToImage(DataTable dbDtViewWrk, string strAbsolutePath, string strRelativePath, ChartChartTypeEnum ChartType, string strTitle)

        {
            string strSeriesName = "图例";
            //存放项目
            string[] ItemsName = new string[dbDtViewWrk.Rows.Count];
            //存放数据
            string[] ItemsCount = new string[dbDtViewWrk.Rows.Count];
            //刻度单位
            int iUnit = 1;
            //最大值
            int iMaxValue = 0;
            string strXdata = String.Empty;
            string strYdata = String.Empty;
           
                //为数组赋值
                for (int i = 0; i < dbDtViewWrk.Rows.Count; i++)
                {
                    ItemsName[i] = dbDtViewWrk.Rows[i][0].ToString();  //要统计的字段名字
                    ItemsCount[i] = dbDtViewWrk.Rows[i][5].ToString();//要统计的字段数据
                }
            //为x轴指定特定字符串,以便显示数据
            // string strXdata = String.Empty;
            foreach (string strData in ItemsName)
            {
                strXdata += strData + "\t";
            }
            // string strYdata = String.Empty;
            //为y轴指定特定的字符串,以便与x轴相对应
            foreach (string strValue in ItemsCount)
            {
                strYdata += strValue + "\t";
                if (int.Parse(strValue) > iMaxValue)
                {
                    iMaxValue = int.Parse(strValue);
                }
            }
            if (iMaxValue > 20)
            {
                iUnit = iMaxValue / 10;
            }
            //创建ChartSpace对象来放置图表
            ChartSpace laySpace = new ChartSpaceClass();
            
            //在ChartSpace对象中添加图表
            ChChart InsertChart = laySpace.Charts.Add(0);
            
            //底座颜色
            InsertChart.PlotArea.Interior.Color = "white";

            //指定绘制图表的类型。类型可以通过OWC.ChartChartTypeEnum枚举值得到
            InsertChart.Type = ChartType;//柱形图


            //指定图表是否需要图例标注
            InsertChart.HasLegend = true;
            InsertChart.BarWidth = 0;
            InsertChart.Legend.Position = ChartLegendPositionEnum.chLegendPositionBottom;

            InsertChart.HasTitle = true;//为图表添加标题
            InsertChart.Title.Caption = strTitle;//标题名称

            //为x,y轴添加图示说明
            if (ChartType.ToString().IndexOf("ChartTypePie") == -1)
            {
                InsertChart.Axes[0].Font.Size = 11; //X轴

                InsertChart.Axes[1].Font.Size = 11; //Y轴
                InsertChart.Legend.Font.Size = 11;
                InsertChart.Axes[0].HasTitle = true;
                InsertChart.Axes[0].Title.Caption = "";//月份
                InsertChart.Axes[1].HasTitle = true;
                //InsertChart.Axes[1].Scaling.SplitMinimum = 200;
                InsertChart.Axes[1].Title.Caption = "数量";
                InsertChart.Axes[1].MajorUnit = iUnit;  //刻度单位设置
                InsertChart.Axes[1].Scaling.Minimum = 0;//最小刻度=0
            }

            //添加一个series系列
            InsertChart.SeriesCollection.Add(0);
            
            //给定series系列的名字
            InsertChart.SeriesCollection[0].SetData(ChartDimensionsEnum.chDimSeriesNames, +(int)ChartSpecialDataSourcesEnum.chDataLiteral, strSeriesName);

            //给定分类
            strXdata = strXdata.Substring(0, strXdata.Length - 1);
            InsertChart.SeriesCollection[0].SetData(ChartDimensionsEnum.chDimCategories, +(int)ChartSpecialDataSourcesEnum.chDataLiteral, strXdata);

            //给定值
            strYdata = strYdata.Substring(0, strYdata.Length - 1);
            InsertChart.SeriesCollection[0].SetData(ChartDimensionsEnum.chDimValues, (int)ChartSpecialDataSourcesEnum.chDataLiteral, strYdata);

            //添加标签
            ChDataLabels dls = InsertChart.SeriesCollection[0].DataLabelsCollection.Add();
            if (ChartType.ToString().IndexOf("ChartTypePie") != -1)
            {
                dls.Position = ChartDataLabelPositionEnum.chLabelPositionCenter;
                dls.HasPercentage = false;
                //dls.HasValue = false;
                dls.HasCategoryName = false;
                //指定图表是否需要图例标注
                InsertChart.HasLegend = true;
                InsertChart.Legend.Position = ChartLegendPositionEnum.chLegendPositionBottom;
            }

            //输出文件.
            int iImageLength = 0;
            int iImageWidth = 0;

            //从Config文件取得设置
            //iImageLength = int.Parse(WebConfigurationManager.AppSettings["ShowImageLength"]);
            //iImageWidth = int.Parse(WebConfigurationManager.AppSettings["ShowImageWidth"]);
            iImageLength = 450;
            iImageWidth = 300;

            string strImageName = ChartType.ToString() + "_" + Guid.NewGuid().ToString("N") + ".png";
            laySpace.ExportPicture(strAbsolutePath + strImageName, "PNG", 450, 300);

            //把图片添加到placeholder中,并在页面上显示
            string strImageTag = "<IMG WIDTH='450' SRC='" + strRelativePath + strImageName + "'/>";
            
            this.PlaceHolder1.Controls.Add(new LiteralControl(strImageTag));
           // return strImageTag;
        }

 

posted @ 2014-09-17 08:47  r163  阅读(2491)  评论(0编辑  收藏  举报