微软MVP 张洪举

非淡泊无以明志,非宁静无以致远。

张洪举ID:zhanghongju
73334次访问,排名1288好友0人,关注者1
zhanghongju的文章
原创 19 篇
翻译 2 篇
转载 2 篇
评论 72 篇
最近评论
dongxiaolin:巴西木,令箭,那个叫不上来。长势不错,绿油油的,每一片叶都那么好。闲暇时放松一下压力,继续加油。
yt045326:张老师你好:
最近我用vfp+sql server2000作了一个C/S系统。
请教怎样才能实现用sqlexec()函数向sql 传送图片和长度大于255的字符串?
急用,赐教为盼!
21cg21cg:张老大,能不能说说UNPIVOT.a.首先建立一个临时结果集的结构,该结构中包含MyPvt表中除IN (五月, 六月, 七月)之外的列,以及SubTotal FOR OrderMonth中指定的值列(SubTotal)和透视列(OrderMonth)。这个临时结果集的结构有什么用.
lyt319:
我买了一本<<Visual Foxpro 软件开发模式与应用案例>>但是光盘丢失了,可否提供下载? 下面是我关于本书的的些疑问,及在网上一些的提出的疑部.:
在第二章中.depin, depout 为什么不把每个记录都记入一个表中然后库存的数量由统计产生呢?而是每张单计算再输入.这样很难控制,也很容易出错.下面在网上就有一位网友提出了疑问.
jamton:请教张老师,reportlistener中文输出乱码的情况怎么解决?
文章分类
    收藏
      相册
      存档
      软件项目交易
      订阅我的博客
      XML聚合  FeedSky
      订阅到鲜果
      订阅到Google
      订阅到抓虾
      订阅到BlogLines
      订阅到Yahoo
      订阅到GouGou
      订阅到飞鸽
      订阅到Rojo
      订阅到newsgator
      订阅到netvibes

      原创 Visual FoxPro 9.0 SP2对报表的增强收藏

      新一篇: Visual FoxPro Sedna Beta | 旧一篇: 儿子四年级的作文:飞翔的翅膀

      订购:http://www.huachu.com.cn/itbook/itbookinfo.asp?lbbh=10054628
      http://www.china-pub.com/computers/common/info.asp?id=34809

      在本书即将完成之际,微软公司发布了Visual FoxPro 9.0SP2版本。在SP2中又引入了对报表的许多增强,这些增强中最引人注目的是现在可以通过xBase代码扩展报表设计器和报表输出引擎。

      报表设计器现在允许自定义设计器的Properties对话框,在SP2之前,开发者不能扩展现有Properties对话框,但是可以通过事件处理器注册表(Event Handler Registry)来替换它们。不过创建一个自定义Properties对话框并不是一件容易的事情,SP2的增强受欢迎之处是为所有用户在报表设计器中提供了一个接口,作为对所创建自定义报表绘制对象的补充。

      SP2也使得报表输出处理更加容易。包含在SP2中的REPORTOUTPUT.APP,提供了一种使用自定义类挂钩报表输出的方法。这个新增类叫做Handlers,它由FXGFX两部分构成。FX Handlers提供了报表运行的扩展功能,但是它并不处理任何报表绘制功能。GFX Handlers执行实际的报表绘制功能,并提供扩展当前绘制或替换所有绘制的功能。

      12.17.1 ReportListener的新增功能

      1CallAdjustObjectSize属性

      12.10.5节使用EvaluateContents事件实现了对域控件对象绘制的调整,要实现对形状或图片类型的布局元素的调整,则应当在控件的AdjustObjectSize事件中进行。Visual FoxPro为形状或图片的每个布局元素在绘制之前调用一次AdjustObjectSize,但是当具备下列某个条件时除外:

      l     如果在运行时刻派生的ReportListenerAdjustObjectSize事件中没有代码;

      l     如果元素在带区中没有标记为可扩展;

      SP2中新增了CallAdjustObjectSize属性,用于指定是否要求ReportListener为所有相应的形状或图片类型控件调用AdjustObjectSize事件。该属性的可用值在如表12-50所示。

      12-50                                                         CallAdjustObjectSize属性的可用值

      说明

      0(默认值)

      如果在AdjustObjectSize事件具有代码的话,则对所有布局对象运行此代码

      1

      不发生AdjustObjectSize事件,即使其中具有代码

      2

      AdjustObjectSize事件总是发生,不管事件中是否具有代码。该值主要的目的是用于调用BINDEVENT( ),而不是执行方法中的代码

      如果报表输出不需要动态对象大小,可以关闭该功能,以实现更好的性能。假设在表单上有一个复选框被选定,下列代码示例使用CallAdjustObjectSize关闭AdjustObjectSize事件,进行最佳化报表输出。

      oReport = CREATEOBJECT("myReportlistener")

      IF THISFORM.chkNoAdjustSize.Value = .T.

         oReport.CallAdjustObjectSize = 1

      ENDIF

      REPORT FORM (myreportfile) OBJECT oReport PREVIEW

      2CallEvaluateContents属性

      CallAdjustObjectSize属性类似,CallEvaluateContents属性用于指定是否要求ReportListener对报表上的所有的域控件调用EvaluateContents事件。通过12.10.5节的介绍可以知道,在EvaluateContents事件中可以改变域控件的文本、颜色、字体和Alpha值。该属性的可用值如表12-51所示。

      12-51                                                         CallEvaluateContents属性的可用值

      说明

      0(默认值)

      如果在EvaluateContents事件具有代码的话,则对所有布局对象运行此代码

      1

      不发生EvaluateContents事件,即使其中具有代码

      2

      EvaluateContents事件总是发生,不管事件中是否具有代码。该值主要的目的是用于调用BINDEVENT( ),而不是执行方法中的代码

      现有一个报表,可以在运行时刻通过ReportListenerEvaluateContents事件修改域控件的画笔颜色,如果使用了一个非彩色打印机,则可能希望关闭EvaluateContents事件。下面的代码根据复选框的值来决定是否关闭EvaluateContents事件的处理。

      oReport = CREATEOBJECT("myReportlistener")

      IF THISFORM.chkColorPrinter.Value = .F.

         oReport.CallEvaluateContents = 1

      ENDIF

      REPORT FORM (myreportfile) OBJECT oReport PREVIEW

      3PrintCachedPages方法

      SP2之前,在将报表输出到预览窗口后,如果希望打印缓冲区中的报表,只能在关闭预览窗口的情况下执行ReportListenerOnPreviewClose(.T.)方法(参考12.13.2节的示例代码)。在SP2中提供了PrintCachedPages方法,如果在预览窗口打开的情况下调用该方法,执行结果OnPreviewClose(.T.)相同。

      由于ReportPreview应用程序中已经包含了PrintCachedPages方法,所以可以控制报表预览工具栏中打印按钮的行为。例如,如果希望在用户单击打印后打印预览窗口保持为打开状态,可以在REPORT FORM命令中包含NOWAIT子句。

      REPORT FORM (filename) OBJECT oReportListener PREVIEW NOWAIT

      4.可以在LoadReport方法中读写CommandClauses.File属性

      SP2开始,可以在LoadReport方法中读写CommandClauses.File属性,从而提供了在装载报表时修改要打印报表文件的能力。

      12.17.2 Properties对话框的增强

      SP2包含新增的FXGFX Handlers,以及添加到Properties对话框的新增选项卡,用来配合这些Handlers。这实际上是为用户提供了一个这些Handlers的设计时刻接口。

      1Document Properties选项卡

      SP2添加了一个叫做Document Properties的选项卡到Report Properties对话框中,其中显示了一个自定义属性列表,可以从中存储有关文档的附加信息或控制报表的绘制,如图12-100所示。

      12-100 Document Properties选项卡

      列表中以HTML开始的属性名称特定于HTML输出,并且当前仅被HTMLListener(包含在_ReportListener.vcx类库中)支持。而所有能够生成文档的ReportListener可以使用其他的属性名称。

      例如,如果设置如图12-100中所示的自定义文档属性,则在使用HTML Report Listener绘制报表的情况下,下面的文本将包含在生成的HTML文件中。

      <title>My Report</title>

      <META name="description" content="My description text">

      <META name="author" content="Hong Ju">

      尽管这些数据并不显示Web页上,但是在为搜索引擎创建文档索引时这却是有用的信息。在SP2之前,没有一种更有效的方法可以在HTML报表文档中包含这些信息。表12-52列出了对这些扩展属性的简要说明。

      可以添加自定义属性到属性列表中,但是它们不能被标准的ReportListener识别,任何新增的自定义属性应当由新的ReportListener或自定义FXGFX Handler进行处理。

      12-52                                                         内置在新报表设计器中的报表属性

      属性

      说明

      Document.Title

      为报表文档指定一个标题。对于HTML输出,这会作为一个TITLE标签在所绘制的文档中出现

      Document.Author

      为报表文档指定作者信息。对于HTML输出,这将以一个META标签出现

      Document.Description

      为报表文档指定一个说明。对于HTML输出,这将以一个META标签出现

      Document.Keywords

      指定包含在报表文档中的关键词。对于HTML输出,这将以一个META标签出现

      Document.Copyright

      为报表文档指定版本信息。对于HTML输出,这将以一个META标签出现

      Document.Date

      为报表文档指定一个日期

      HTML.CSSFile

      仅用于HTML输出。为生成的文档指定要使用的外部CSS文件名称

      HTML.Metatag.HTTP-EQUIV

      仅用于HTML输出。指定一个包含在HTML输出中的HTTP-EQUIV标签

      HTML.TextAreasOff

      仅用于HTML输出。对溢出伸展字段取消使用TEXTAREA标签

      2Advanced Properties选项卡

      SP2向每个控件属性对话框(包括标签、字段、矩形、线条和图片)添加了一个新增的Advanced选项卡,该选项卡提供了一个属性列表,开发者可以自定义报表上的每个对象。如图12-101所示。

      12-101 Advanced选项卡

      注意列表中以HTML作为前缀的属性名称在默认情况下仅用于HTMLListenerAdvanced选项卡也包含一个Object Rotation控件,使用该控件可以为当前对象指定一个旋转角度。旋转仅在绘制期间发生,因此在报表设计器中并不可见。需要注意的是,HTMLListener不支持旋转,在输出为HTML时,旋转角度会被忽略。

      通常情况下,在Advanced选项卡中列出的是与报表控件相关的默认属性。此外,也可以为报表控件设置、新增或删除自定义属性。表12-53列出了对这些默认属性的简要说明。

      12-53                                                     Advanced选项卡中报表控件的默认属性

      属性

      说明

      HTML.Link

      当以HTML输出运行报表时,该表达式作为控件超级链接的HREF属性

      HTML.Anchor

      当以HTML输出运行报表时,该表达式作为控件超级链接的name属性

      HTML.Alt-Title

      当以HTML输出运行报表时,该表达式作为控件<div>元素中的title属性

      HTML.CSSClass.OverrideFRX

      当以HTML输出运行报表时,ReportOutput应用程序为每个报表元素创建具有格式定义的CSS类。如果在Document Properties选项卡中设置了HTML.CSSFile报表属性,在Report Builder Properties对话框的Report Properties对话框(Report Builder)指定了一个CSS文件,则可以使用HTML.CSSClass.OverrideFRX属性在文件中指定一个CSS类,这会替换由Report Builder创建的格式

      HTML.CSSClass.ExtendFRX

      如果设置了HTML.CSSFile报表属性到一个CSS文件,则可以使用该属性指定一个类来添加格式特征到由Report Builder创建的格式中

      HTML.PrintablePageLink

      HTML报表中,系统为每页创建一个位图文件。对于实际页面,打印位图比HTML更加紧凑。如果将控件的该属性设置为“真”,则该控件则会转换为到该图像的一个超级链接

      ListenerRef.NoRenderWhen

      当表达式计算为“真”时,所打印页面中将不包含指定对象。ListenerRef是在报表运行时对Report Listener的引用

      ListenerRef.Preprocess.NoRenderWhen

      当表达式计算为“真”时,在一个多次运行的报表的第一次运行时,所打印页面中将不包含指定对象

      1)控件旋转和输出到HTML示例

      现有一个如图12-102所示的报表,其中第二列的标题(This is a long column title)超长,为了使其显示的更加完整,可以对该标签控件旋转一定的角度。双击该标签控件,打开其Properties对话框,可以在Advanced选项卡的Object Rotation中单击鼠标左键指定角度,也可以通过下方的Angle微调按钮进行调整。单击OK按钮关闭对话框,并执行下面的命令在预览窗口中打开报表。可以看到第二列的标题发生了旋转,如图12-104所示。

      SET REPORTBEHAVIOR 90

      REPORT FORM report1.frx PREVIEW NOWAIT

      12-102 示例报表

        

      12-103 指定标签的旋转角度                           

       12-104 报表预览效果

      但是,在输出到HTML时控件无法进行旋转,第二列的标题仍旧会显示不完整,如图12-105所示。在这种情况下,可以设置在输出到HTML时不输出该标题,而是为下方的域控件添加提示信息,当鼠标指针移动域控件上方时,显示提示信息。

      12-105 将报表输出到HTML时的效果

      双击报表中的This is a long column title标签,打开其Properties对话框。选择Advanced选项卡并编辑ListenerRef.NoRenderWhen属性的值为“This.Listener.OutputType=5,指定在输出HTML时不输出该控件,如图12-106所示。

      双击报表中的contact域控件,打开其Properties对话框。选择Advanced选项卡并编辑HTML.Alt-Title属性的值为“"This column is contact name of customer."”,指定当鼠标指针移动到该控件上时将显示该提示信息,如图12-107所示。

      设置完成后,选择File菜单中的Save As HTML菜单项或执行下面的命令输出报表到HTML,执行结果如图12-108所示。

      SET REPORTBEHAVIOR 90

      oListener = CREATEOBJECT('ReportListener') 

      oListener.ListenerType = 5

      REPORT FORM report1.frx TO FILE report1.htm OBJECT oListener

      RUN report1.htm

         

       12-106 设置This is a long column title标签不输出到HTML 

      12-107 设置控件输出到HTML时的提示信息

      12-108 在输出到HTML时未输出第二列的标题,并且为第二列中的控件添加了提示

      2)建立报表控件到当前页面的图像链接示例

      如果为报表中的某个控件设置了HTML.PrintablePageLink属性,则将报表输出到HTML的同时会为每页生成一个GIF文件,并且每页上的该控件会链接到相应的GIF文件。例如,在上面所设计报表的基础上添加一个标签控件,并双击该控件打开其Properties对话框,在Advanced选项卡中双击HTML.PrintablePageLink属性,将属性值改变为Yes,如图12-109所示。

      设置完成后,按照前面介绍的方法将报表输出到HTML中,可以看到所添加的标签变成了一个指向当前页面GIF文件的超级链接,如图12-110所示。

      12-109 将控件设置为到GIF图像文件的链接

      12-110 可以链接到GIF文件的报表

      3Dynamics Properties选项卡

      SP2FieldRectanglePicture控件的Properties对话框添加了一个Dynamics选项卡,该选项卡为在报表运行期间动态改变报表对象的属性提供了一个Conditions(条件)列表。仍旧以前面建立的report1.frx报表为例,我们将使用该功能动态改变控件的背景,以实现报表中的奇偶行使用不同颜色显示。

      双击报表中的company域控件,打开其Properties对话框。单击Dynamics选项卡中的Add按钮,在打开的对话框输入新条件的名称并单击OK