Charting a New Course with OWC and ASP

General
Typography
  • Smaller Small Medium Big Bigger
  • Default Helvetica Segoe Georgia Times

You may already know how easy it is to create a Web page that accesses data on the iSeries. When your application is created using Active Server Pages (ASPs), this ability is enhanced by the ability to use ActiveX controls within your ASP. A great example of this is to use the charting object included with the Microsoft Office Web Components (OWC) to create a chart or graph from your iSeries data within a Web page. In this article, you'll explore using OWC charts within an ASP.

Software Requirements and Setup

To use the examples within this article, you'll need a Windows server running Microsoft Internet Information Services (IIS). In addition, you'll have to install OWC on the Web server. If you have Microsoft Office, you can install this from the Office Setup CD, or you can download OWC from the Microsoft Web site. Once you've installed OWC on your IIS server, you're ready to go.

OWC Chart Object Model

The OWC Chart component is a simple ActiveX control that allows you to create a graph or chart. If you're familiar with creating graphs and charts in Microsoft Excel or any other spreadsheet package, the concept behind the OWC chart object won't be too foreign to you. Figure 1 shows a graphic representation of the OWC chart object model.

http://www.mcpressonline.com/articles/images/2002/Charting%20a%20new%20course%20with%20OWC%20and%20ASP%20V4--03220400.png

Figure 1: The OWC Chart component allows you to create a chart. This is the OWC Chart object model. (Click images to enlarge.)

As this figure shows, the base component used for creating a chart is the Chartspace object. One Chartspace object can contain multiple Chart objects within a Charts collection. The Chart object's data is supplied through the Axis and Series objects. Figure 2 shows a sample of what the Axes and Series represent within your data.

http://www.mcpressonline.com/articles/images/2002/Charting%20a%20new%20course%20with%20OWC%20and%20ASP%20V4--03220401.png

Figure 2: This example illustrates what the Axes and Series represent within your data.

In this example, Series represents the number of columns within your data. Axes represents the rows within each column. In the example above, 1900, 1901, and 1902 represent the three items within the Series collection. The months and their corresponding values represent the Axes within the object.

Creating Charts Server-Side

When using the OWC Chart component, you have the option of creating the chart on the Web server or within the client browser. There are pros and cons to each of these. If you create the chart server-side, you need to have the OWC component installed only on the Web server, not on each client PC that accesses the page. On the other hand, a client-side chart can be changed dynamically through client-side VB Script or JavaScript code. One main difference between the two techniques is that, while the client-side technique loads an ActiveX control into the browser window, the server-side technique simply displays the chart as an image file. For the examples in this article, I'll be focusing on the server-side technique. For more information on the client-side technique, see the book Active Server Pages Primer from MC Press.

Using the Sample Application

Before you get to the actual code for this example, you'll need to go into the root HTTP folder on your IIS server (usually, this will be c:inetpubwwwroot) and create a subfolder named ASPChart. You'll use this folder to store your source code and the temporary image files that will contain your charts. Figure 3 contains the source for the file "global.asa." Place it in the folder you just created.



Sub Session_OnStart
' Create a FileSystemObject to provide files in the script
Set Session("FSO") = CreateObject("Scripting.FileSystemObject")

' Variable to hold the number of files created in this session
Session("n") = 0

' Set timeout to be 1 minute
Session.Timeout = 1
End Sub

Sub Session_OnEnd
' Delete the files created in this session
Dim x
For x = 0 to Session("n")-1
Session("FSO").DeleteFile Session("gifFile" & x), True
Next
End Sub

Figure 3: This is the code for the file global.asa.

This file is used to create script source to be executed whenever the page loads. The example here contains two VBScript functions: Session_Onstart, which is executed each time a user creates a new session by logging into any Web page in this folder, and Session_OnEnd, which is run when a user ends a session by closing the browser or navigating away from the Web site.

This file can also contain Application_OnStart, which is executed the first time a user accesses the page and each time the IIS server is restarted, and Application_OnEnd , which occurs when the IIS server is ended.

Within your OnStart event, you need to do several things. First, create a Session variable that contains a Scripting.Filesystemobject ActiveX control, which can be used to manipulate files on the Web server. A Session variable can be accessed anytime throughout a user's "session" as described above, even from a different ASP. Next, create a second session variable, which will act as a simple counter to be used later. Finally, set the session timeout to one minute. This will cause the session to expire if no activity occurs for one minute.

The Session_OnEnd event performs cleanup tasks by using the two session objects created earlier to delete the temporary image files created during the life of the session using the .Deletefile method of the Scripting.Filesystemobject. The parameter supplied points to session variables containing the names of each of the image files created by the application. Figure 4 contains the source for ASPChart.asp, which is responsible for actually creating and displaying the chart.

123456789012345789212345678931234567894123456789512345678961234567890
<%@ Language=VBScript %>






Number of Libraries:


Response.Write "Selected"%>>5

Response.Write "Selected"%>>10

Response.Write "Selected"%>>20

Response.Write "Selected"%>>40
 
Chart Type


Response.Write "Selected"%>>Pie

Response.Write "Selected"%>>Bar


<%

' Create ADO Connection and Recordset Objects
Set conn = CreateObject("ADODB.Connection")
Set rs = CreateObject("ADODB.Recordset")

NumLibs=request.Form("NumLibs")
If NumLibs=0 then NumLibs=5
redim Libraries(NumLibs), Files(NumLibs)

ChartType=request.Form("ChartType")
conn.CommandTimeout=0
conn.open "DRIVER=Client Access ODBC Driver (32-bit); " & _ 
        "UID=user; PWD=secret; System=192.168.0.3; TRANSLATE=1;" 

' Retrieve Data for Our Chart
sql="SELECT * FROM (SELECT TABLE_SCHEMA, COUNT(*) AS FILES " & _ 
    " FROM QSYS2.SYSTABLES WHERE TABLE_SCHEMA LIKE 'Q%' " & _ 
    " GROUP BY TABLE_SCHEMA) AS DATAFILE ORDER BY FILES DESC"
rs.Source=sql
rs.ActiveConnection=conn
rs.Open 

For x=0 to NumLibs
if not rs.EOF Then
Libraries(x)=rs.Fields(0)
Files(x)=rs.Fields(1)'
rs.MoveNext
End If
Next
' Create Chart Objects
Set oChart = CreateObject("OWC10.Chartspace")
Set c = oChart.Constants

' Add & Define new Chart
oChart.Charts.Add
'on error resume next
If ChartType="PIE" Then

   ChtTyp = oChart.Constants.chChartTypePie

End IF

If ChartType="BAR" Then

   ChtTyp = oChart.Constants.chChartTypeColumnClustered

End IF

oChart.Charts(0).Type = ChtTyp

oChart.Charts(0).SeriesCollection.Add
oChart.Charts(0).SeriesCollection(0).Caption = "Top " & NumLibs & _
                                  " libraries by Number of Files"
oChart.Charts(0).SeriesCollection(0).SetData c.chDimCategories, 
                                        c.chDataLiteral, Libraries
oChart.Charts(0).SeriesCollection(0).SetData c.chDimValues, 
                                          c.chDataLiteral, Files
oChart.Charts(0).HasLegend=(oChart.Charts(0).Type=c.chChartTypePie)
oChart.Charts(0).HasTitle = True

' Export chart to a temporary GIF file and insert IMG tag
Set FSO = CreateObject("Scripting.FileSystemObject")
gifFile = Session.SessionID & Session("n") & ".gif"
oChart.ExportPicture server.MapPath(gifFile), "gif", 640, 480
Response.Write ""

' Save the file name for cleanup after session ends
Session("gifFile" & session("n")) = Server.MapPath(gifFile)
Session("n") = Session("n") + 1
%>

Figure 4: This is an example of how to code an OWC chart.

This sample ASP will chart the top libraries based on number of files per library. The number of libraries displayed is selected using a drop-down box. The type of chart display (pie or bar) is also defined using a drop-down box. The data for this page is read in using an ActiveX Data Object (ADO) connection and recordset. The data is moved from the fields within a record into two arrays. One of these will contain all of the library names from your file. The other one will contain the file counts for each corresponding library.

Load the values into the arrays so that they can be transferred into the chart object. Then, create the reference to the Chartspace and add a new chart to that chartspace. Depending on the value of the drop-down box, your chart will be either a pie chart or a bar chart. Next, add a new Series collection to your chart and define the chart's caption. Define the headings and values using the SetData method of your Series object. Use the constant chDimCategories to identify that you are defining the categories for the report and the constant chDimValues to define the actual chart values themselves. The constant chDataLiteral identifies that the values being passed into the chart are simple data variables. Now, identify whether your chart should display a legend containing the chart colors and associated categories. When that piece is complete, use your Scripting.Filesystemobject so that you can output your next chart as a GIF file. This is done through the ExportPicture method of your Chart object. You also write to a session variable the name of the file containing your new chart so that you can clean it up when the session's ON_END event occurs.

Figure 5 shows a side-by-side example of a bar chart and a pie chart created using this example.

http://www.mcpressonline.com/articles/images/2002/Charting%20a%20new%20course%20with%20OWC%20and%20ASP%20V4--03220402.png

Figure 5: These sample bar and pie charts were created using this example.

This example shows the top 10 libraries expressed as a bar chart and as a pie chart. The nice thing about this specific example is that it is completely browser-independent. Since the graph itself is sent to the browser as a GIF image, there are no special requirements for the client browser--or the operating system, for that matter.

Full Steam Ahead!

The sample ASP application shown here can easily be customized to suit your specific needs. By simply changing the SQL statement used with the ADO recordset, you can modify what data is used for the categories and values for the chart. With a little tweaking, you can allow users to easily generate custom charts, all through a simple browser interface.

Mike Faust is MIS Manager for The Lehigh Group in Macungie, Pennsylvania. Mike is also the author of the books The iSeries and AS/400 Programmer's Guide to Cool Things and Active Server Pages Primer from MC Press. You can contact Mike at This email address is being protected from spambots. You need JavaScript enabled to view it..


BLOG COMMENTS POWERED BY DISQUS

LATEST COMMENTS

Support MC Press Online

$0.00 Raised:
$