首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > PB中打印预览的实现
【标  题】:PB中打印预览的实现
【关键字】:打印,PB,PB
【来  源】:网络

PB中打印预览的实现

  作为目前比较流行的数据库前端开发工具,PowerBuilder显著的一个特点就是其数据窗口(DataWindow)技术,利用此技术可生成各种复杂的报表,但在打印输出时为了打印出中国式特殊格式要求的报表时,需要编程实现,打印效果需要反复调整并打印输出,既效率低下,又浪费资源,如何让用户在打印报表前能预览报表打印效果呢 ?

  1、 在原窗口内实现预览

  最简单并且最常用的方法是在窗口内添加命令按钮“预览”,在其clicked事件中写入如下脚本:

if  this.text="预览" then
dw_1.object.datawindow.print.preview = "yes"
this.text="取消"
else
this.text="预览"
dw_1.object.datawindow.print.preview = "no"
end if

  该方法适用于打印报表的格式与数据窗口的显示格式相同。

  2、 在预览窗口w_preview中实现预览

  在PB5.0带的例子Code Examples中有一窗口w_preview,用它可完成数据窗口的预览,它的技术要点是:将数据窗口的语法作为参数传递给w_preview,再在w_preview窗口中用dw.create()函数生成此数据窗口,其中数据用describe()函数取得,再用imporstring()函数转入。依据中国人的习惯,将w_preview内英文提示全部改为中文。采用此窗口进行预览的好处是:预览的比例可随意调整,便于观察整体效果。在Code Examples中调用w_preview的过程非常复杂,它先调用一个自定义函数,然后在函数中调用w_preview,下面介绍一种比较简单的调用方法并采用另一种获取预览数据的方法。

  ? 在命令按钮“预览”的clicked事件中写入如下脚本:(原脚本全部删除)

string ls_dwname//定义变量,
用于存放数据窗口控件名
if  isvalid(w_preview)
then  close(w_preview)
ls_dwname = dw_1.dataobject//取数据窗口控件名
//拷贝数据窗口内的数据到剪贴板,
然后打开预览窗口w_preview
dw_1.saveas("",clipboard!,false)
openwithparm(w_preview,ls_dwname)

? 在w_preview的open事件中写入脚本如下:
//说明:用于单数据窗口的打印预览
//调用规则:open(w_preview,)
//参数stringparm为字符型变量,
存放数据窗口控制名
//返回值:  无
//****************************
***********************************
//例如:
// string ls_dwname
// ls_dwname = dw_1.dataobject
// dw_1.saveas("",clipboad!,false)
// openwithparm(w_preview,ls_dwname)
//**********************************
*****************************
//获得数据窗口控件名
string ls_dwname
ls_dwname = message.stringparm
dw_1.dataobject = ls_dwname
dw_1.settransobject(sqlca)
dw_1.importclipboard() //导入预览数据
dw_1.object.datawindow.print.preview
= "yes"//置预览方式为true

  这种方法比较简单,充分利用了PB5.0现有资源,而且容易理解。但如果打印是通过复合式窗口(composite dw)来实现的,其打印效果的预览采用以上方法就不行,数据无法传递,只能采用最基本的方法实现,平时复合式窗口是不可见的,预览时将其可见即可,脚本如下:(dw_7为复合式数据窗口)

if this.text="预览"  then
  SetPointer(Hourglass!)
  dw_7.object.datawindow.print.preview = "yes"
  dw_7.visible = true
  this.text="取消"
else
  this.text="预览"
  dw_7.visible = false
end if

  以上方法在P200兼容机、Windows98平台上、PowerBuilder5.0上实现,完全可行。
PowerBuilder的数据窗口:【上一篇】
浅谈PB中动态DataWindow的技术应用:【下一篇】
【相关文章】
  • PB中协调多数据窗口数据操纵的一种解决方法
  • PB数据窗口中按钮的封装
  • PowerBuilder中实现数据窗口打印预览通用方法
  • 在PB中实现分段打印功能
  • PB中表的修改对数据窗口和报表的影响的解决办法
  • PB6 + Sql Anywhere5 应用程序如何脱离开发环境运行
  • PB8.0应用程序编译发布技术研究
  • 升级到PB9.0的10个理由
  • PB所支持的Oracle 的版本
  • 不同版本的PB所需要的运行时动态链接库
  • 【随机文章】
  • Eclipse的Tomcat插件安装
  • eclipse插件:opencmd(直接开命令行工具到选择文件、文件夹、JAR包)跨平台
  • RHCE133实验(系统管理
  • Visual Basic 属性、方法和事件一
  • 栈的观察(接“一次简单的溢出调试”)
  • 在RH AS 3上完全编译安装BIND-9.2.3.txt
  • JSP之plugin的使用
  • jsp的出错处理
  • 不破坏原加密存储的存储解密
  • 如何编制DOS下的病毒(1)
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.