在ASP.NET中使用Office Web Components (OWC)创建统计图

时间:2022-06-21 05:02:07

图形和图表是Web上数据表现的很好的形式,在ASP.NET,可以使用Office Web Components (OWC)来创建统计图。Office Web Component (OWC)是包含在Microsoft Office 2000中的一套组件,利用这些组件,

下面是C#版本的OWC.asp.cs 



ublic class owc: System.Web.UI.Page

{

protected System.Web.UI.WebControls.PlaceHolder ChartHolder;



private void Page_Load(object sender, System.EventArgs e)

{

// 在此处放置用户代码以初始化页面

//创建ChartSpace对象来放置图表

OWC.ChartSpace objCSpace = new OWC.ChartSpaceClass ();



//在ChartSpace对象中添加图表,Add方法返回chart对象

OWC.WCChart objChart = objCSpace.Charts.Add (0);



//指定图表的类型。类型由OWC.ChartChartTypeEnum枚举值得到

objChart.Type = OWC.ChartChartTypeEnum.chChartTypeColumnClustered;



//指定图表是否需要图例

objChart.HasLegend = true;



//给定标题

objChart.HasTitle = true;

objChart.Title.Caption= "上半年分布图";



//给定x,y轴的图示说明

objChart.Axes[0].HasTitle = true;

objChart.Axes[0].Title.Caption = "Y : 数量";

objChart.Axes[1].HasTitle = true;

objChart.Axes[1].Title.Caption = "X : 月份";



//计算数据

/*categories 和 values 可以用tab分割的字符串来表示*/

string strSeriesName = "图例 1";

string strCategory = "1" + '/t' + "2" + '/t' + "3" + '/t'+"4" + '/t' + "5" + '/t' + "6" + '/t';

string strValue = "9" + '/t' + "8" + '/t' + "4" + '/t'+"10" + '/t' + "12" + '/t' + "6" + '/t';



//添加一个series

objChart.SeriesCollection.Add(0);



//给定series的名字

objChart.SeriesCollection[0].SetData (OWC.ChartDimensionsEnum.chDimSeriesNames,

+ (int)OWC.ChartSpecialDataSourcesEnum.chDataLiteral, strSeriesName);



//给定分类

objChart.SeriesCollection[0].SetData (OWC.ChartDimensionsEnum.chDimCategories,

+ (int)OWC.ChartSpecialDataSourcesEnum.chDataLiteral, strCategory);



//给定值

objChart.SeriesCollection[0].SetData

(OWC.ChartDimensionsEnum.chDimValues,

(int)OWC.ChartSpecialDataSourcesEnum.chDataLiteral, strValue);

//输出成GIF文件.

string strAbsolutePath = (Server.MapPath(".")) + "//i//test.gif";

objCSpace.ExportPicture(strAbsolutePath, "GIF", 600, 350);



//创建GIF文件的相对路径.

string strRelativePath = "./i/test.gif";



//把图片添加到placeholder.

string strImageTag = "<IMG SRC='" + strRelativePath + "'/>";

ChartHolder.Controls.Add(new LiteralControl(strImageTag));

}



#region Web Form Designer generated code

override protected void OnInit(EventArgs e)

{

//

// CODEGEN:该调用是 ASP.NET Web 窗体设计器所必需的。

//

InitializeComponent();

base.OnInit(e);

}



/// <summary>

/// 设计器支持所需的方法 - 不要使用代码编辑器修改

/// 此方法的内容。

/// </summary>

private void InitializeComponent()

{

this.Load += new System.EventHandler(this.Page_Load);



}

#endregion

}





如果用ADO.NET的DataSet对象,可以生成以TAB分割的字符串:



strValue += (nodes.Item(j).ChildNodes.Item(0).InnerText + '/t');

strCategory += (nodes.Item(j).ChildNodes.Item(1).InnerText + '/t');



我们可以很方便地在浏览器中或者传统的编程环境中进行数据分析和报表。比如:电子报表,图表,数据透视表等。 要在浏览器中显示图表,可以按下面的步骤进行: 从数据库中读取要生成图表的数据; 创建OWC图表; 添加必要的数据系列; 为个数据列赋数据; 定义外观; 创建GIF图形; 用IMG标记显示图形。 要生成图表的数据称为数据原,Chart Component组件支持的数据源有:实现IDataSource接口的任何数据源;ADO Recordset对象;XML文件;数组或者一定格式的文本字符串。在ASP中,我们可以用ADO Recordset对象;在.NET的ADO.NET中,由于ADO.NET没有实现IDataSource,.NET也没有提供ADO.NET DataSet对象向ADO Recordset对象的直接转换,如果你有一个 DataSet对象,你要么转换成XML文件,要么生成特殊格式的字符串才可以使用。下面就是本例子的结果: