author | ohair |
Wed, 26 May 2010 20:28:04 -0700 | |
changeset 5551 | 327690766109 |
parent 5506 | 202f599c92aa |
child 21254 | f6d36ee3f269 |
permissions | -rw-r--r-- |
2 | 1 |
<html> |
2 |
<head> |
|
3 |
<title>javax.print package</title> |
|
4 |
<!-- |
|
5506 | 5 |
Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved. |
2 | 6 |
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
7 |
||
8 |
This code is free software; you can redistribute it and/or modify it |
|
9 |
under the terms of the GNU General Public License version 2 only, as |
|
5506 | 10 |
published by the Free Software Foundation. Oracle designates this |
2 | 11 |
particular file as subject to the "Classpath" exception as provided |
5506 | 12 |
by Oracle in the LICENSE file that accompanied this code. |
2 | 13 |
|
14 |
This code is distributed in the hope that it will be useful, but WITHOUT |
|
15 |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
16 |
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
17 |
version 2 for more details (a copy is included in the LICENSE file that |
|
18 |
accompanied this code). |
|
19 |
||
20 |
You should have received a copy of the GNU General Public License version |
|
21 |
2 along with this work; if not, write to the Free Software Foundation, |
|
22 |
Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
23 |
||
5551
327690766109
6956202: Fix a few missed rebranding issues, please contact lines etc.
ohair
parents:
5506
diff
changeset
|
24 |
Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
327690766109
6956202: Fix a few missed rebranding issues, please contact lines etc.
ohair
parents:
5506
diff
changeset
|
25 |
or visit www.oracle.com if you need additional information or have any |
327690766109
6956202: Fix a few missed rebranding issues, please contact lines etc.
ohair
parents:
5506
diff
changeset
|
26 |
questions. |
2 | 27 |
--> |
28 |
</head> |
|
29 |
<body bgcolor="white"> |
|
30 |
Provides the principal classes and interfaces for the |
|
31 |
Java<sup><font size="-2">TM</font></sup> Print Service API. |
|
32 |
The Java Print Service API enables client and server applications to: |
|
33 |
<ul> |
|
34 |
<li>Discover and select print services based on their capabilities |
|
35 |
<li>Specify the format of print data |
|
36 |
<li>Submit print jobs to services that support the document type to |
|
37 |
be printed. |
|
38 |
</ul> |
|
39 |
||
40 |
||
41 |
<h3>Print Service Discovery</h3> |
|
42 |
<p> |
|
43 |
An application invokes the static methods of the abstract class |
|
44 |
{@link javax.print.PrintServiceLookup PrintServiceLookup} to locate print |
|
45 |
services that have the capabilities to satisfy the application's print |
|
46 |
request. For example, to print a double-sided document, the application |
|
47 |
first needs to find printers that have the double-sided printing capability. |
|
48 |
<p> |
|
49 |
The JDK includes <code>PrintServiceLookup</code> implementations that |
|
50 |
can locate the standard platform printers. To locate other types of printers, |
|
51 |
such as IPP printers or JINI printers, a print-service provider can write |
|
52 |
implementations of <code>PrintServiceLookup</code>. The print-service provider |
|
53 |
can dynamically install these <code>PrintServiceLookup</code> implementations |
|
54 |
using the |
|
55 |
<a href="../../../technotes/guides/jar/jar.html#Service Provider"> |
|
56 |
SPI JAR file specification</a>. |
|
57 |
||
58 |
<h3>Attribute Definitions</h3> |
|
59 |
||
60 |
The {@link javax.print.attribute} and {@link javax.print.attribute.standard} |
|
61 |
packages define print attributes, which describe the capabilities of a print |
|
62 |
service, specify the requirements of a print job, and track the progress of |
|
63 |
a print job. |
|
64 |
<p> |
|
65 |
The <code>javax.print.attribute</code> package describes the types of attributes and |
|
66 |
how they can be collected into sets. The <code>javax.print.attribute.standard</code> |
|
67 |
package enumerates all of the standard attributes supported by the API, most |
|
68 |
of which are implementations of attributes specified in the IETF Specification, |
|
69 |
<a href="http://www.ietf.org/rfc/rfc2911.txt"> |
|
70 |
RFC 2911 Internet Printing Protocol, 1.1: Model and Semantics</a>, dated |
|
71 |
September 2000. The attributes specified in <code>javax.print.attribute.standard</code> |
|
72 |
include common capabilites, such as: resolution, copies, media sizes, |
|
73 |
job priority, and page ranges. |
|
74 |
||
75 |
<h3>Document Type Specification</h3> |
|
76 |
||
77 |
The {@link javax.print.DocFlavor DocFlavor} class represents the print data |
|
78 |
format, such as JPEG or PostScript. A <code>DocFlavor</code> object |
|
79 |
consists of a MIME type, which describes the format, and a document |
|
80 |
representation class name that indicates how the document is delivered |
|
81 |
to the printer or output stream. An application uses the |
|
82 |
<code>DocFlavor</code> and an attribute set to find printers that can |
|
83 |
print the document type specified by the <code>DocFlavor</code> and have |
|
84 |
the capabilities specified by the attribute set. |
|
85 |
||
86 |
<h3>Using the API</h3> |
|
87 |
||
88 |
A typical application using the Java Print Service API performs these steps |
|
89 |
to process a print request: |
|
90 |
<ol> |
|
91 |
<li>Chooses a <code>DocFlavor</code>.</li> |
|
92 |
<li>Creates a set of attributes.</li> |
|
93 |
<li>Locates a print service that can handle the print request as specified |
|
94 |
by the <code>DocFlavor</code> and the attribute set.</li> |
|
95 |
<li>Creates a {@link javax.print.Doc Doc} object encapsulating the |
|
96 |
<code>DocFlavor</code> |
|
97 |
and the actual print data, which can take many forms including: a Postscript |
|
98 |
file, a JPEG image, a URL, or plain text.</li> |
|
99 |
<li>Gets a print job, represented by {@link javax.print.DocPrintJob DocPrintJob}, |
|
100 |
from the print service.</li> |
|
101 |
<li>Calls the print method of the print job.</li> |
|
102 |
</ol> |
|
103 |
The following code sample demonstrates a typical use of the Java Print |
|
104 |
Service API: locating printers that can print five double-sided copies |
|
105 |
of a Postscript document on size A4 paper, creating a print job from |
|
106 |
one of the returned print services, and calling print. |
|
107 |
||
108 |
<p> |
|
109 |
<pre> |
|
110 |
<blockquote> |
|
111 |
FileInputStream psStream; |
|
112 |
try { |
|
113 |
psStream = new FileInputStream("file.ps"); |
|
114 |
} catch (FileNotFoundException ffne) { |
|
115 |
} |
|
116 |
if (psStream == null) { |
|
117 |
return; |
|
118 |
} |
|
119 |
||
120 |
DocFlavor psInFormat = DocFlavor.INPUT_STREAM.POSTSCRIPT; |
|
121 |
Doc myDoc = new SimpleDoc(psStream, psInFormat, null); |
|
122 |
PrintRequestAttributeSet aset = |
|
123 |
new HashPrintRequestAttributeSet(); |
|
124 |
aset.add(new Copies(5)); |
|
125 |
aset.add(MediaSize.A4); |
|
126 |
aset.add(Sides.DUPLEX); |
|
127 |
PrintService[] services = |
|
128 |
PrintServiceLookup.lookupPrintServices(psInFormat, aset); |
|
129 |
if (services.length > 0) { |
|
130 |
DocPrintJob job = services[0].createPrintJob(); |
|
131 |
try { |
|
132 |
job.print(myDoc, aset); |
|
133 |
} catch (PrintException pe) {} |
|
134 |
} |
|
135 |
</blockquote> |
|
136 |
</pre> |
|
137 |
<P> |
|
138 |
Please note: In the javax.print APIs, a null reference parameter to methods |
|
139 |
is incorrect unless explicitly documented on the method as having a meaningful |
|
140 |
interpretation. Usage to the contrary is incorrect coding and may result |
|
141 |
in a run time exception either immediately or at some later time. |
|
142 |
IllegalArgumentException and NullPointerException are examples of |
|
143 |
typical and acceptable run time exceptions for such cases. |
|
144 |
<P> |
|
145 |
@since 1.4 |
|
146 |
</body> |
|
147 |
</html> |