.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;
}