- java.lang.Object
-
- javax.print.SimpleDoc
-
- All Implemented Interfaces:
- Doc
public final class SimpleDoc extends Object implements Doc
This class is an implementation of interfaceDoc
that can be used in many common printing requests. It can handle all of the presently defined "pre-defined" doc flavors defined as static variables in the DocFlavor class.In particular this class implements certain required semantics of the Doc specification as follows:
- constructs a stream for the service if requested and appropriate.
- ensures the same object is returned for each call on a method.
- ensures multiple threads can access the Doc
- performs some validation of that the data matches the doc flavor.
If the print data is a stream, or a print job requests data as a stream, then
SimpleDoc
does not monitor if the service properly closes the stream after data transfer completion or job termination. Clients may prefer to use provide their own implementation of doc that adds a listener to monitor job completion and to validate that resources such as streams are freed (ie closed).
-
-
Constructor Summary
Constructors Constructor and Description SimpleDoc(Object printData, DocFlavor flavor, DocAttributeSet attributes)
Constructs aSimpleDoc
with the specified print data, doc flavor and doc attribute set.
-
Method Summary
Methods Modifier and Type Method and Description DocAttributeSet
getAttributes()
Obtains the set of printing attributes for this doc object.DocFlavor
getDocFlavor()
Determines the doc flavor in which this doc object will supply its piece of print data.Object
getPrintData()
Obtains the print data representation object that contains this doc object's piece of print data in the format corresponding to the supported doc flavor.Reader
getReaderForText()
Obtains a reader for extracting character print data from this doc.InputStream
getStreamForBytes()
Obtains an input stream for extracting byte print data from this doc.
-
-
-
Constructor Detail
-
SimpleDoc
public SimpleDoc(Object printData, DocFlavor flavor, DocAttributeSet attributes)
Constructs aSimpleDoc
with the specified print data, doc flavor and doc attribute set.- Parameters:
printData
- the print data objectflavor
- theDocFlavor
objectattributes
- aDocAttributeSet
, which can benull
- Throws:
IllegalArgumentException
- ifflavor
orprintData
isnull
, or theprintData
does not correspond to the specified doc flavor--for example, the data is not of the type specified as the representation in theDocFlavor
.
-
-
Method Detail
-
getDocFlavor
public DocFlavor getDocFlavor()
Determines the doc flavor in which this doc object will supply its piece of print data.- Specified by:
getDocFlavor
in interfaceDoc
- Returns:
- Doc flavor.
-
getAttributes
public DocAttributeSet getAttributes()
Obtains the set of printing attributes for this doc object. If the returned attribute set includes an instance of a particular attribute X, the printer must use that attribute value for this doc, overriding any value of attribute X in the job's attribute set. If the returned attribute set does not include an instance of a particular attribute X or if null is returned, the printer must consult the job's attribute set to obtain the value for attribute X, and if not found there, the printer must use an implementation-dependent default value. The returned attribute set is unmodifiable.- Specified by:
getAttributes
in interfaceDoc
- Returns:
- Unmodifiable set of printing attributes for this doc, or null to obtain all attribute values from the job's attribute set.
-
getPrintData
public Object getPrintData() throws IOException
Description copied from interface:Doc
Obtains the print data representation object that contains this doc object's piece of print data in the format corresponding to the supported doc flavor. ThegetPrintData()
method returns an instance of the representation class whose name is given by
, and the return value can be cast from class Object to that representation class.getDocFlavor()
.getRepresentationClassName()
- Specified by:
getPrintData
in interfaceDoc
- Returns:
- Print data representation object.
- Throws:
IOException
- Thrown if the representation class is a stream and there was an I/O error while constructing the stream.
-
getReaderForText
public Reader getReaderForText() throws IOException
Obtains a reader for extracting character print data from this doc. TheDoc
implementation is required to support this method if theDocFlavor
has one of the following print data representation classes, and returnnull
otherwise:-
char[]
-
java.lang.String
-
java.io.Reader
Reader
for reading the print data as a stream of characters from the print data representation object. However, if the print data representation object is itself aReader
then the print data representation object is simply returned.- Specified by:
getReaderForText
in interfaceDoc
- Returns:
- a
Reader
for reading the print data characters from this doc. If a reader cannot be provided because this doc does not meet the criteria stated above,null
is returned. - Throws:
IOException
- if there was an I/O error while creating the reader.
-
-
getStreamForBytes
public InputStream getStreamForBytes() throws IOException
Obtains an input stream for extracting byte print data from this doc. TheDoc
implementation is required to support this method if theDocFlavor
has one of the following print data representation classes; otherwise this method returnsnull
:-
byte[]
-
java.io.InputStream
- Specified by:
getStreamForBytes
in interfaceDoc
- Returns:
- an
InputStream
for reading the print data bytes from this doc. If an input stream cannot be provided because this doc does not meet the criteria stated above,null
is returned. - Throws:
IOException
- if there was an I/O error while creating the input stream.
-
-
-
Deutsche Übersetzung
Sie haben gebeten, diese Seite auf Deutsch zu besuchen. Momentan ist nur die Oberfläche übersetzt, aber noch nicht der gesamte Inhalt.Wenn Sie mir bei Übersetzungen helfen wollen, ist Ihr Beitrag willkommen. Alles, was Sie tun müssen, ist, sich auf der Website zu registrieren und mir eine Nachricht zu schicken, in der Sie gebeten werden, Sie der Gruppe der Übersetzer hinzuzufügen, die Ihnen die Möglichkeit gibt, die gewünschten Seiten zu übersetzen. Ein Link am Ende jeder übersetzten Seite zeigt an, dass Sie der Übersetzer sind und einen Link zu Ihrem Profil haben.
Vielen Dank im Voraus.
Dokument erstellt 11/06/2005, zuletzt geändert 04/03/2020
Quelle des gedruckten Dokuments:https://www.gaudry.be/de/java-api-rf-javax/print/simpledoc.html
Die Infobro ist eine persönliche Seite, deren Inhalt in meiner alleinigen Verantwortung liegt. Der Text ist unter der CreativeCommons-Lizenz (BY-NC-SA) verfügbar. Weitere Informationen auf die Nutzungsbedingungen und dem Autor.
Referenzen
Diese Verweise und Links verweisen auf Dokumente, die während des Schreibens dieser Seite konsultiert wurden, oder die zusätzliche Informationen liefern können, aber die Autoren dieser Quellen können nicht für den Inhalt dieser Seite verantwortlich gemacht werden.
Der Autor Diese Website ist allein dafür verantwortlich, wie die verschiedenen Konzepte und Freiheiten, die mit den Nachschlagewerken gemacht werden, hier dargestellt werden. Denken Sie daran, dass Sie mehrere Quellinformationen austauschen müssen, um das Risiko von Fehlern zu reduzieren.