`
shine1200
  • 浏览: 41982 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

flex 带打印预览功能的

阅读更多
flex 带打印预览功能的

前几天看到论坛上有人需要flex中的打印预览功能,但是没有合适的方法来实现。经过我几天的努力,终

于实现了flex的打印预览。把它做成了一个库文件,SuperPrintJob.swc。使用时只需要把SuperPrintJob

类加入mxml或者在as代码中创建一个实例,然后设定需要的函数就可以实现打印预览,不需要额外添加其

他的类。打印预览的效果是,弹出一个TitleWindow,打印效果显示在弹出窗口中,弹出窗口的大小与纸张

的大小是一致的。
为了实现打印预览,并且为了方便使用,SuperPrintJob和flex中提供的FlexPrintJob的使用方式上有很大

差异。并且可以作为一个标签加入到mxml文件中。
下载地址:http://download.csdn.net/source/1765732
下面详细介绍一下使用方法:
1、将SuperPrintJob.swc复制到工程的lib目录下。
2、把SuperPrintJob加入自己的程序中。
可以用标签加入到mxml中,例如如下代码:
<hi:SuperPrintJob id="pj" container="{this}" scaleType="matchHeight"
pageWidth="560" pageHeight="806"/>
也可以在as代码中创建SuperPrintJob实例,例如如下代码。
var spj:SuperPrintJob = new SuperPrintJob();
3、纸张的设定。
系统提供的PrintJob是通过start()函数来打开一个打印机选择框,选择完打印机后,就能够得到所选打印

的纸张信息,例如纸张的宽度和纸张的高度。如果在每次打印预览的时候都打开一个打印机选择框很很讨

厌的一件事,用户体验会非常差。所以纸张的大小只能是手工设置了。SuperPrintJob提供了pageWidth和

paperHeight两个属性设置纸张的宽度和高度。一般情况下,每个打印功能都是固定的打印机和打印纸,纸

张的大小都是固定的。因此设置纸张的大小是可行的。SuperPrintJob提供默认的纸张格式是A4纸竖版。
4、printAsBitmap属性的设定。
printAsBitmap属性,是与系统提供的PrintJob的printAsBitmap属性一致的。使用方法也一致,在此不多

说。
5、容器对象的设置container属性。
在打印预览的时候要弹出一个窗口来预览打印信息的,因为弹出窗口需要一个容器对象,所以需要提供一

个容器对象,来作为Popup窗口的容器。在SuperPrintJob中是通过container属性来进行设置的。一般情况

下这个容器对象是Application对象。例如Application.application。另外注意一点,容器对象没有默认

值。如果不设置的话系统会发生异常,预览画面不能弹出。所以来说,这个属性非常重要。
6、打印纸的匹配类型——scaleType
打印内容和打印纸的匹配形式,例如匹配宽度或者匹配高度等。
有以下几个选项:
FlexPrintJobScaleType.SHOW_ALL
FlexPrintJobScaleType.FILL_PAGE
FlexPrintJobScaleType.NONE
FlexPrintJobScaleType.MATCH_HEIGHT
FlexPrintJobScaleType.MATCH_WIDTH
在SuperPrintJob中默认值是FlexPrintJobScaleType.MATCH_WIDTH。
7、打印对象的设置。
打印对象的设置对应属性printObject,把需要打印的对象对这个属性进行设置之后,就可以进行打印预览

或者是打印了。除了printObject这个属性之外还得提一下addPrintObject()这个函数,如果打印对象不止

一个,需要调用这个函数进行设置。与之相关的还有一个clearPrintObject()函数,可以清除掉所有的打

印对象,这个函数调用后,如果进行下次打印的话需要重新设置。另外再次设置printObject属性,可以清

除以前的打印对象,用设定的打印对象代替。
8、打印预览窗口缩放比例previewPanelRatio属性。
打印预览窗口是根据打印纸张的变化而变化的,如果打印纸张过大或者过小,都应该打印预览窗口的使用

。所以可以设置previewPanelRatio属性来调整打印预览窗口的大小,这个属性的默认值是0.7,也就是原

来窗口大小乘以0.7,设置成1就是原始大小,如果大于1就放大了。
9、getPageInfo()函数。
此函数功能是得到打印机设定的打印纸的高度和宽度。成功时返回一个Object对象,直接取对象的

pageWidth和pageHeight属性就可以得到纸张的宽度和纸张的高度。失败时返回null。但是这个方法调用后
会弹出一个打印提示框,并且开始一个打印任务,因为这个方法调用了PrintJob的start()方法,只有点击

打印提示框上的“打印”按钮才能得到打印纸的高度和宽度,但是打印任务会随之关闭不会真的进行打印

。这个方法可以用来在编码期间得到打印纸的信息,来设定paperWidth和papgerHeight属性。不推荐在程

序中使用。用户体验不好,容易让人误会要进行真的打印。
10、addPrintObject()函数。
向SuperPrintJob中添加打印对象。
11、clearPrintObject()函数。
清除掉所有的打印对象,这个函数调用后,如果进行下次打印的话需要重新设置。
12、preview()打印预览函数。
弹出打印预览窗口。
13、print()打印函数。
对打印对象进行打印。

下面是一个使用SuperPrintJob的例子:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
xmlns:local="*" xmlns:hi="http://hi.csdn.net/To9m" creationComplete="init()">
<hi:SuperPrintJob id="pj" container="{this}" scaleType="matchHeight"
pageWidth="560" pageHeight="806"/>
<mx:Script>
<![CDATA[
   import mx.controls.Button;
   import mx.collections.ArrayCollection;
   import mx.managers.PopUpManager;

   private function init():void
   {
    pj.clearPrintObject();
    pj.addPrintObject(dg);
    pj.addPrintObject(dg0);
   }
   private function onClick():void
   {
    pj.preview();
   }
   private function onPrintClick():void
   {
    pj.print();
   }
   private var datas:ArrayCollection =new ArrayCollection([
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3},
        

{col1:1,col2:2,col3:3},{col1:1,col2:2,col3:3}
          ]);
]]>
</mx:Script>
<mx:Button id="btn" label="preview" click="onClick()" x="10" y="10"/>
<mx:Button label="print" click="onPrintClick()" x="132" y="10"/>

<mx:DataGrid id="dg" x="10" y="40" width="100%" height="264" dataProvider="{datas}">
<mx:columns>
   <mx:DataGridColumn headerText="Column 1" dataField="col1"/>
   <mx:DataGridColumn headerText="Column 2" dataField="col2"/>
   <mx:DataGridColumn headerText="Column 3" dataField="col3"/>
</mx:columns>
</mx:DataGrid>
<mx:DataGrid id="dg0" x="10" y="325" width="100%" height="264"

dataProvider="{datas}">
<mx:columns>
   <mx:DataGridColumn headerText="Column 1" dataField="col1"/>
   <mx:DataGridColumn headerText="Column 2" dataField="col2"/>
   <mx:DataGridColumn headerText="Column 3" dataField="col3"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>

欢迎大家进行交流。

效果图片:


分享到:
评论
1 楼 guiguadan 2011-08-25  
在第二步就出错了,怎么把SuperPrintJob加入到自己的项目中啊,加入后,一部署就出错了???该怎么搞啊………………

相关推荐

    flex 带打印预览功能的PrintJob

    flex 带打印预览功能的PrintJob 经过我几天的努力,终于实现了flex的打印预览。把它做成了一个库文件,SuperPrintJob.swc。大家可以自由下载使用。这个压缩包中包含库文件的代码和使用的工程。详细的使用方法参见我...

    Flex 打印及打印预览功能

    在Flex中,打印和打印预览功能是应用程序与用户进行数据输出交互的重要部分。本篇文章将深入探讨Flex中的打印及打印预览功能,以及如何利用这些功能来提升应用程序的实用性。 首先,我们要了解Flex中的`mx.printing...

    Flex实现打印预览

    Flex是Adobe公司开发的一种基于ActionScript 3.0的...综上所述,实现Flex的打印预览功能涉及到对Flex打印API的理解、预览组件的创建以及用户交互的实现。通过这些步骤,你可以为用户提供一个方便且直观的打印预览体验。

    flex 打印预览

    在Flex中,打印预览功能是为用户提供在实际打印前查看文档外观的重要特性。下面将详细介绍Flex中的打印预览及其相关知识点。 1. Flex打印服务: Flex提供了PrintJob类,该类是打印服务的基础,允许开发者创建、配置...

    flex4.5 打印功能

    "带有预览功能"意味着Flex 4.5提供了打印预览功能,用户可以在实际打印之前查看内容在纸上的呈现效果。预览可以帮助用户检查页面布局、分页和样式是否符合预期。`mx.printing.PrintPreview`组件就是用来实现这一功能...

    打印预览(flex)

    Flex打印预览是一种在Flex应用程序中实现打印功能的技术,它允许用户在实际打印之前查看文档的打印效果。Flex是Adobe公司开发的...通过学习和掌握这些知识点,开发者可以构建出功能完善的打印预览功能,提升用户体验。

    Flex实践——Datagrid的打印预览与打印

    这个主题聚焦于Flex中的一个关键组件——Datagrid,以及如何实现它的打印预览和打印功能。Datagrid是Flex中用于展示数据集的常用控件,常用于表格形式的数据展示和操作。 首先,我们要理解Flex Datagrid的基础知识...

    Flex打印预览

    在ArcGIS Flex Viewer中,开发者通常会遇到一个挑战:尽管内置的打印功能使得地图的输出成为可能,但它并不包括一个直观的打印预览功能。这可能会导致用户在实际打印前无法准确预览地图的布局和样式,从而可能导致不...

    flex 打印源代码

    8. **打印预览**: 在Flex中实现打印前的预览功能,通常需要使用`flash.display.DisplayObject`的`drawToBitmap`方法将舞台内容捕获为位图,然后在屏幕上显示预览。 9. **页面设置与布局**: 了解如何通过`...

    Flex 打印例子官方的哦

    在提供的文件列表"Pring"中,虽然没有具体的代码示例,但我们可以假设它包含了一些Flex打印功能的示例代码或教程资料。通过研究这些文件,开发者可以更好地理解如何在实际项目中运用Flex的打印功能。 总的来说,...

    web打印,打印预览

    Web打印和打印预览是网页开发中的重要组成部分,它们允许用户在正式打印前查看文档的打印效果,确保格式正确无误。在这个过程中,开发者通常会利用浏览器提供的API和CSS技术来实现这一功能。下面我们将详细探讨这个...

    Flex在线预览文档组件FlexPaper_swc

    FlexPaper是一款功能强大的...总之,FlexPaper_swc是Flex开发者实现文档在线预览的理想选择,无论你是新手还是经验丰富的开发者,都能借助其强大的功能和易用性,轻松地将高质量的文档预览功能整合到你的Flex应用中。

    flex的一个打印测试

    首先,Flex打印功能的实现依赖于`flash.printing.PrintJob`类。这个类提供了创建、设置和执行打印任务的方法。例如,`start()`方法启动打印作业,`addPage()`用于添加要打印的位图或显示对象,而`send()`则将所有...

    Flex打印(转)

    标题“Flex打印(转)”可能指的是一个关于使用Adobe Flex技术进行打印功能开发的文章或教程。Flex是一种基于ActionScript 3.0的开源框架,用于构建富互联网应用程序(RIA)。在这个场景中,"转"可能意味着内容是作者...

    flex 分页打印 FlexReport

    7. **打印和预览**:提供预览功能,让用户在实际打印前查看报表效果。FlexReport通常会提供控件以支持打印操作。 8. **事件处理**:处理用户交互,例如点击页码切换页面、选择打印选项等。 9. **优化性能**:对于...

    实现客户端打印之jasperrport3.7.0(打印预览+多页同时打印)

    标题中的“实现客户端打印之jasperrport3.7.0”指的是使用JasperReports的Portlet版本3.7.0来实现在客户端的打印功能,包括打印预览和多页同时打印。JasperReports是一个开源的Java报表库,它能够帮助开发者创建、...

    Flex:Web报表引擎MyReport 1.0.0.2

    Web上的良好的打印解决方案,WinForm的打印预览体现,报表自动化,支持直接打印,页小计,统计,转成金额大写等功能,满足中国式报表的常见功能需求。 最新版1.2.0.1下载地址:...

    FlexReport打印

    其API特性包括 :支持报表布局、多页内容以及打印预览功能。 报表布局:如果要在Flex中打印页面,你应该创建一个容器,并把它加入到FlexPrintJob中。它处理静态内容时没有什么大问题。但是如果创建动态报表,即你不...

Global site tag (gtag.js) - Google Analytics