.net 實現 畫圖 餅圖折線圖等
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; }