您现在的位置是: 软件 > 开发者网络 > 程序方舟 > 开发专栏 > PB开发 > 正文
·速成电脑精英(包分配)白领高薪一族从这里开始



-Java套接字编程(下)
-MediaStudio Pro 6.5教程
-三款卸载软件最新试用
-基于Visual C++的Winsock API研究

PB动态报表格式自由定义的实现
2002-04-12· ·廖海辉 ··yesky


  在通常的Server/Client方式MIS开发中,总是有没完没了的报表需要制作,调试报表花费的时间也是最多而且乏味,还常常不能满足客户的要求。要是能够让用户自己调整报表的格式和内容,然后将它保存下来,程序下次启动时它自动调用保存了的报表格式那有多好。本人通过如下方法最终实现了用的要求。
PB(PowerBuilder)有一种以PSR结尾的特殊的保存报表的文件格式(本文简称作PSR文件)。根据数据窗口可以直接读取PSR文件生成报表的原理,程序通过生成PSR文件,实现动态报表格式的保存。

  一、实现原理:

  PB中的报表其实就相当于是数据窗口。

  第一步,动态报表的实现。通过设置数据窗口对象(dataobject)中文本、列等的Resizeable和moveable属性为1来实现对象位置的拖动控制,通过数据窗口的Modify函数实现对象值的更改(包括增加和删除)。

  第二步,报表格式的保存。在一个应用当中,数据窗口对象的名称总是唯一的,将每一个数据窗口对象转化成PSR文件存于数据库表中。在窗口打开时,程序先校验报表格式是否存在。如果存在,先将报表格式读取出来放在一个临时文件当中,然后设置数据窗口(datawindow)的数据对象(dataobject)为这个报表文件,然后提取数据;如果不存在,直接提取数据即可。

  二、实现过程:

   1、建立一个数据库表用以保存报表格式文件。
表名:dyn_report
Dwobject Varchar2(20) 数据窗口对象名称 Primary key
Rptitle Varchar2(80) 报表的标题名称  
Memo Long raw 报表格式  

   2、建立一个窗口w_temp。 定义实例变量如下:

   string is_dwtype,is_dwobject //保存报表中对象的类型及名称

控件名称 控件含义
Dw_print 数据窗口对象
Cb_exit 退出按钮
Cb_savereport 报表格式保存按钮
  
   3、在窗口的OPEN事件中加入如下代码, 校验报表格式是否存在,如果存在读取定义好的报表格式到数据窗口。

  blob emp_pic
   long ll_handle
   string ls_dwobject,ls_reportfile,ls_path
   ls_dwobject = dw_print.dataobject
   //判断是否存在该数据窗口的报表格式
   select count(*) into:ll_count from dyn_report where dwobject =:ls_dwobject;
   if ll_count>0 then
     //读取报表格式文件到大文本变量
     selectblob memo into:emp_pic from dyn_report where dwobject =:ls_dwobject;
     //创建psr临时文件到硬盘
     ls_reportfile = '\temp7089.psr'
     ll_handle = FileOpen(is_reportfile,StreamMode!,write!,LockWrite!,Replace!)
     FileWrite(ll_handle,emp_pic)
     FileClose(ll_handle)
     dw_print.dataobject = ls_reportfile
     dw_print.settransobject(sqlca)
   else
     Dw_print.settransobject(sqlca)
   End if
   Dw_print.retrieve()
   4、报表格式的保存。通过Cb_savereport按钮的clicked实现。
   string ls_filename
   long ll_count
   blob Emp_id_pic
   ls_filename = "temp70201.psr"
   //保存报表格式到硬盘临时文件
   dw_print.saveas(ls_filename,PSReport! ,false)
   sqlca.autocommit = true
   select count(*) into :ll_count from dyn_report where dwobject =:is_dwobject;
   if ll_count =0 then
     insert into dyn_report(dwobject,rptitle)
     values(:is_dwobject,:ls_filename,:ls_path);
   end if
   //从硬盘临时文件读取数据保存到数据库表中
   emp_id_pic = of_readbmpfile(ls_filename)//该函数将二进制文件内容读到大文本对象中
   //更新数据库
   UPDATEBLOB dyn_report SET memo = :Emp_id_pic where dwobject = :is_dwobject;
   sqlca.autocommit = false

  5、动态报表的实现。通过数据窗口dw_print的clicked事件捕获数据窗口中对象,并将对象名存放在实现变量is_dwobject中,为下一步修改报表作准备。

   string ls_type,ls_dwoname
   //得到对象类型和名称
   ls_type = trim(upper(dwo.type))
   ls_dwoname = trim(dwo.name)
   is_dwtype = ls_type
   choose case ls_type
     case "TEXT","CommandButton","GROUPBOX"
       is_dwobject = ls_dwoname
       //设置为可以拖动和改变大小,其它类同
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable="+"1")
     case "LINE" //直线对象不能通过设置Resizeable和moveable属性进行调整,必须通过其它路径
       is_dwobject = ls_dwoname
     case "RECTANGLE","ELLIPSE","GRAPH","BITMAP"
       is_dwobject = ls_dwoname
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable='"+"1'")
     case "COLUMN","COMPUTE"
       is_dwobject = ls_dwoname
       this.modify(ls_dwoname+".Resizeable='"+"1'")
       this.modify(ls_dwoname+".moveable='"+"1'")
   end choose


   然后再通过modify()函数可以实现基本的动态报表操作,这一类的文章较多,PB中也有大量的例子可直接使用,在此这不再累述。

   6、在cb_exit按钮的clicked()事件中加入:close(parent)。

   7、在应用的open事件中加入: open(w_temp)。然后保存并运行,大功告成啦!

   8、本程序在PB7.0加Oracle8.05下调试通过。




【责任编辑:方舟】
【发表评论】【关闭窗口】
■ 相关内容
 API函数和PB编程
 使用PB 7.0 开发Web应用
 用PB编写多线程应用程序
 PB中编写10进制到其他进制的转换函数
 PB中相关联下拉数据窗口的实现
 定制PB与SQL Anywhere的程序发布
 PB数据管道的实用程序设计技术
 在PB中方便的实现图片动态切换
 关于PB应用程序的2000年问题
 如何在PB6中播放AVI多媒体文件
 PB中数据窗口的两点应用技巧
 PB中一个类Word打印对话框的实现
 如何实现PB应用程序的屏幕保护功能
 在PB应用中实现声音与动画
 在PB应用中收发电子邮件
 用PB的ocx控件ctGauge实现进度条显示
 用PB的ocx控件ctGauge实现进度条显示
 PB6.5中OLE控件的三个缺点
 如何在PB中调用数据管道
 PB中如何得到Crosstab中的列名
 在PB程序中实现ODBC数据源的添加
 如何在PB中用直连驱动联接数据库
 如何在PB中切换中英文输入法数
 PB中实现图片按钮mousemove事件
 在PB中方便的实现图片动态切换
感谢 访问天极网,如果您觉得该文章涉及版权问题,请看这里!