javax.print

王朝百科·作者佚名  2010-02-16  
宽屏版  字体: |||超大  

软件包 javax.print 的描述

为 JavaTM Print Service API 提供了主要类和接口。Java Print Service API 允许客户端和服务器应用程序具备如下功能:

根据其性能发现并选择 PrintService。

指定打印数据的格式。

向支持所打印文档类型的服务提交 PrintJob。

PrintService 发现

应用程序可调用抽象类 PrintServiceLookup 的静态方法来查找 PrintService,这些 PrintService 具有满足应用程序打印要求的功能。例如,要打印双面文档,应用程序首先需要找到具有双面打印功能的打印机。

JDK 包括的 PrintServiceLookup 实现可查找标准的平台打印机。要查找其他类型的打印机(如 IPP 打印机或 JINI 打印机),PrintService 提供程序可写入 PrintServiceLookup 实现。PrintService 提供程序可使用《SPI JAR file specification》动态地安装这些 PrintServiceLookup 实现。

属性定义

javax.print.attribute 和javax.print.attribute.standard包定义了打印属性,这些属性描述了 PrintService 的功能、指定 PrintJob 的要求并跟踪 PrintJob 的进度。

javax.print.attribute 包描述了属性类型和属性分类方法。javax.print.attribute.standard 包枚举了 API 所支持的所有标准属性,其中大多数是在 IETF 规范《RFC 2911 Internet Printing Protocol, 1.1:Model and Semantics》(2000 年 9 月)中所指定的属性实现。javax.print.attribute.standard 中指定的属性包括常见的功能,如:分辨率、份数、介质大小、作业优先级和页面范围。

文档类型规范

DocFlavor 类表示了打印数据的格式,如 JPEG 或 PostScript。DocFlavor 对象由 MIME 类型(描述了格式)和文档表示形式类名(指示如何将文档发送到打印机或输出流)所组成。应用程序使用 DocFlavor 和属性集来查找某些打印机,这些打印机可打印由 DocFlavor 所指定的文档类型且具有属性集所指定的功能。

使用 API

典型的应用程序使用 Java Print Service API 执行以下步骤来处理打印请求:

选择一个 DocFlavor。

创建一个属性集。

找到一个可处理由 DocFlavor 和属性集所指定的打印请求的 PrintService。

创建一个 Doc 对象,该对象封装 DocFlavor 和实际的打印数据,这些打印数据可采用很多形式,包括:Postscript 文件、JPEG 图像、URL 或纯文本。

从 PrintService 获得一个由 DocPrintJob 表示的 PrintJob。

调用 PrintJob 的 print 方法。

以下代码示例说明了 Java Print Service API 的典型用法:找到可在 A4 大小的纸张上打印 5 份 Postscript 文档双面副本的打印机、根据某个返回的 PrintService 创建 PrintJob 并调用 print 方法。

FileInputStream psStream;

try {

psStream = new FileInputStream("file.ps");

} catch (FileNotFoundException ffne) {

}

if (psStream == null) {

return;

}

DocFlavor psInFormat = DocFlavor.INPUT_STREAM.POSTSCRIPT;

Doc myDoc = new SimpleDoc(psStream, psInFormat, null);

PrintRequestAttributeSet aset =

new HashPrintRequestAttributeSet();

aset.add(new Copies(5));

aset.add(MediaSize.A4);

aset.add(Sides.DUPLEX);

PrintService[] services =

PrintServiceLookup.lookupPrintServices(psInFormat, aset);

if (services.length > 0) {

DocPrintJob job = services[0].createPrintJob();

try {

job.print(myDoc, aset);

} catch (PrintException pe) {}

}

请注意:在 javax.print API 中,只有在方法中显式记录传递给方法的 null 引用参数具有有意义的解释时,该参数才是正确的。否则就是错误的编码方式,并且可能立即或在稍后某时导致运行时异常。IllegalArgumentException 和 NullPointerException 是典型的异常示例,并且是这种情况可接受的运行时异常。

从以下版本开始:

1.4

 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
© 2005- 王朝百科 版权所有