PB动态报表的实现

 我来答
温屿17
2022-11-02 · TA获得超过1.2万个赞
知道小有建树答主
回答量:827
采纳率:0%
帮助的人:94.6万
展开全部

   实现原理

  PowerBuilder中有一种以PSR为后缀的特殊的保存报表的文件格式(本文简称PSR文件) 数据窗口可以直接读取PSR文件生成报表 而程序通过生成PSR文件 就可以实现动态报表格式的保存

  首先 通过设置数据窗口对象(dataobject)中的文本 列等的Resizeable和moveable属性为 来实现对象位置的拖动控制 通过数据窗口的Modify函数实现对象值的更改(包括增加和删除)

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

   实现过程

   建立一个数据库表用以保存报表格式文件

   建立一个窗口w_temp 定义实例变量如下

  string is_dwtype is_dwobject

  //保存报表中对象的类型及名称

   在窗口的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> then

  //读取报表格式文件到大文本变量

  selectblob memo into:emp_pic from dyn_report where dwobject =:ls_dwobject;

  //创建PSR临时文件并保存到硬盘

  ls_reportfile = \temp 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()

   保存报表格式 这可以通过Cb_savereport按钮的clicked事件实现

  string ls_filename

  long ll_count

  blob Emp_id_pic

  ls_filename = temp psr

  //保存报表格式到硬盘临时文件

  dw_print saveas(ls_filename PSReport! false)

  sqlca automit = true

  select count(*) into :ll_count from dyn_report where dwobject =:is_dwobject;

  if ll_count = 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 automit = false

   动态报表的实现 通过数据窗口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= + )

  this modify(ls_dwoname+ moveable= + )

  case LINE

  //直线对象不能通过设置Resizeable和moveable属性进行调整 必须通过其他途径

  is_dwobject = ls_dwoname

  case RECTANGLE ELLIPSE GRAPH BITMAP

  is_dwobject = ls_dwoname

  this modify(ls_dwoname+ Resizeable= + )

  this modify(ls_dwoname+ moveable= + )

  case COLUMN PUTE

  is_dwobject = ls_dwoname

  this modify(ls_dwoname+ Resizeable= + )

  this modify(ls_dwoname+ moveable= + )

  end choose

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

   在cb_exit按钮的clicked()事件中加入 close(parent)

   在应用的open事件中加入 open(w_temp) 然后保存并运行 全部工作到此结束!

  本程序在PB Oracle 下调试通过

       编辑推荐

       ASP NET开发培训视频教程

lishixinzhi/Article/program/PB/201311/24637

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式