My environment: VS 2005, MS Office 2003.
- Adding the reference. Right click on your web project -> select add a reference -> select "COM" tab -> find and add the "Microsoft Office Web Component 11".
PS: The OWC version is depending on the version of MS Office you are using. I am using Office 2003 so the OWC version will be 11. - In your code-behind file, add this
using Microsoft.Office.Interop.Owc11;
- Prepare your data source. Here I create a sample data for this demo:
string CategoryData = "01:00, 02:00, 03:00, 04:00, 05:00, 06:00, 0700, 0800, 0900, 10:00, 11:00, 12:00"; string ValueData = "2.6, 2.5, 2.4, 2.3, 2.4, 2.5, 2.3, 2.6, 2.8, 3.3, 3.8, 4.2";
- Adding this method
private void DrawChart(string CategoryData, string ValueData) { ChartSpaceClass oChartSpace = new ChartSpaceClass(); ChChart oChart = oChartSpace.Charts.Add(0); //Here is the place to set the chart type. I use the Line chart here. oChart.Type = ChartChartTypeEnum.chChartTypeLine; oChart.Axes[0].HasMajorGridlines = true; oChart.Axes[1].HasTitle = true; oChart.Axes[1].Title.Caption = "MWH"; oChart.HasTitle = true; oChart.Title.Caption = "Hourly Data"; oChart.SeriesCollection.Add(0); //CategoryData is the X axes value oChart.SeriesCollection[0].SetData(ChartDimensionsEnum.chDimCategories, Convert.ToInt32(ChartSpecialDataSourcesEnum.chDataLiteral), CategoryData); //ValueData is the Y axes value oChart.SeriesCollection[0].SetData(ChartDimensionsEnum.chDimValues, Convert.ToInt32(ChartSpecialDataSourcesEnum.chDataLiteral), ValueData); //Export to an image and assign it to the image control. You can change the width and height. oChartSpace.ExportPicture(Server.MapPath("~/Common/DPChart.gif"), "GIF", 640, 480); //this makes sure you can always get the new image Image1.Attributes.Add("src", "Common/DPChart.gif?ts=" + DateTime.Now.ToBinary()); oChart = null; oChartSpace = null; dt.Dispose(); }
data:image/s3,"s3://crabby-images/b10be/b10bec48543e4bd83a1e4f9dd77865c0f82f7413" alt=""
data:image/s3,"s3://crabby-images/59ea8/59ea8c3300e47c1dffb96c878c6c281e9f818051" alt=""
data:image/s3,"s3://crabby-images/469cf/469cf377aab77c15bcbd056e8d93003426c9d5cb" alt=""
data:image/s3,"s3://crabby-images/a3d44/a3d4420583c7559c425e938514b243128f8ede3c" alt=""
data:image/s3,"s3://crabby-images/2d92f/2d92f0318fb439bb10ddb4960fa51e173d5aebfc" alt=""
data:image/s3,"s3://crabby-images/25a35/25a3554ea44bf7a1cdc044db67e2a2f4764430da" alt=""
data:image/s3,"s3://crabby-images/0d277/0d277a13bef022cfc59ac2d8d250a93f2d9397cb" alt=""
data:image/s3,"s3://crabby-images/c70a2/c70a23726e67d02da1e1962643cf44541a5cec89" alt=""
You can find the more professional .Net chart component called "ZedGraph". It's FREE, and it comes with source code.
Update:
You must register OWC on the Server in order to use it. If you are using the same version as I am, then go here to download and install it.
Nice post...
ReplyDelete