赛迪网 > IT技术 编程语言 > 文章
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

3、基本函数和事件

发布时间:2006.08.16 03:04     来源:plwww    作者:

 

下面是ExcelChart组件中的一些基本函数和事件。

SetChartBaseProps函数

如下面的代码所示,SetChartBaseProps()函数的作用是设置图表基本属性的默认值。

Private Sub SetChartBaseProps()'--- 为组件用户预定义的属性With oExcelChart .ChartType = xl3DColumnClustered .SizeWithWindow = True .HasDataTable = FalseEnd WithEnd Sub

该函数由Class_Intialize事件调用。在这里我们把默认的图表类型设置为三维柱形图。如果SizeWithWindow属性没有设置,则图表的大小会超过Excel工作表的大小,最终也会超过浏览器窗口的大小。Excel图表允许将数值作为一个独立的表格显示,在这里我们通过HasDataTable属性关闭了该功能。

Class_Initialize事件

Class_Initialize()完成一些准备工作。

Private Sub Class_Initialize()'--- 创建Excel应用实例Set oExcelApp = CreateObject("Excel.Application")'---设置Excel应用不可见,然后加入一个工作簿oExcelApp.Visible = FalseoExcelApp.SheetsInNewWorkbook = 1: oExcelApp.Workbooks.Add With oExcelApp.ActiveWorkbook '--- 获取第一个工作表 Set oExcelSheet = .Sheets(1) '--- 加入新的图形工作表 Set oExcelChart = .Sheets.Add(Type:=xlChart) '--- 设置图表的基本属性 SetChartBasePropsEnd WithEnd Sub

所有基于该类的对象,其初始化过程都会触发这个Class_Initialize事件。第一行代码的作用是初始化一个Excel应用作为ActiveX服务器。用户并不直接访问ActiveX服务器,该服务器仅在内部完成图表绘制工作。Excel应用的visible属性设置成了False,这保证了任何情况下用户都不会直接见到Excel。

默认情况下Excel 2000会将三个空的工作表加入新工作簿。为便于控制,程序把新工作表数量设置成了1,当然必要的时候可以加入新的工作表。接下来程序又将新的工作簿加入到了已经初始化的Excel应用。新加入的工作簿将自动成为活动工作簿,因为它是应用中唯一的工作簿。

第一个工作表也是唯一的工作表,该表可以通过工作簿的Sheets集合访问,程序把它存储到了全局变量oExcelSheet以便其他方法访问。该表实际上用来存储AddDataSeries()函数所传递的数据。接下来程序又将一个新的工作表加入到了Sheets集合,新表的类型为xlChart。第二个工作表用来存放图表,现在我们把它保存到了全局变量oExcelChart。

综上所述,现在组件中有了下面这些对象:



【图2】

Class_Terminate事件

Private Sub Class_Terminate()If (Not (oExcelApp Is Nothing)) Then '--- 检查是否确实存在工作簿 If (oExcelApp.Workbooks.Count> 0) Then'--- 关闭工作簿,忽略任何修改oExcelApp.Workbooks(1).Close SaveChanges:=False End If '--- 退出Excel,释放资源 oExcelApp.Quit: Set oExcelApp = NothingEnd IfEnd Sub

结束全部工作之后,对象的拆除操作将触发Class_Terminate事件。Class_Terminate检查所有已经分配空间的对象并依次释放它们。工作簿对象包含两个工作表,即图表工作表和数据工作表。在绘制图表之后工作表的内容已经改变,因此,close方法的SaveChanges参数必须指定False以忽略对工作表内容的修改,这样也就避免了每次生成一个图表都要创建一个Excel文件(.xls文件)。程序最后调用Quit方法退出Excel应用并清除对象。


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 1、组件结构概览 (07-06) · 怎么让窗体总在前 (01-13)
· VB环境下压缩数据流播放技术(1) (03-25) · 在VB中使用文件对象 (08-27)
· VB中获取逻辑磁盘的信息 (11-06) · 在菜单中加入图标 (01-07)
· vb开发通信软件(cloud转贴) (09-16) · vb调用winInet API接口post数据到指定的url (03-24)
· VB IGMP (03-26) · 源代码推荐:vb的GUID生成算法 (08-03)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管