Package javax.print.attribute
What is an Attribute?
When setting up a print job, a client specifies two things: print data and processing instructions. The print data is the actual content to be printed. The processing instructions tell the printer how to print the print data, such as: what media to use, how many copies to print, and whether to print on one or both sides of a sheet. The client specifies these processing instructions with the attribute definitions of the Java Print Service API.The print data and the processing instructions are separate entities. This means that:
- You can print the same print data at different times using different
   processing instructions.
   
 For example, you can print a slide presentation on US letter-sized white paper, double-sided, stapled, 20 copies to make handouts for a talk; and you could print the same slide presentation on US letter-sized transparencies, single-sided, one copy to make the actual slides for the talk.
- You can use the same processing instructions at different times to print different data. For example, you could set your default processing instructions to: US letter-sized paper, double sided, stapled. Whenever you print a job, it prints with these settings, unless you explicitly override them.
Attribute Categories and Values
Each printer has a set of capabilities, such as the ability to print on different paper sizes or the ability to print more than one copy. Each of the capabilities has a range of values. For example, a printer's orientation capability might have this range of values: [landscape, portrait]. For each print request, the capability is set to one of these values. The Java Print Service API uses the term attribute category to refer to a printer capability and the term attribute value to refer to the value of the capability.
 In the Java Print Service API, an attribute category is represented by a Java
 class implementing the Attribute interface.
 Attribute values are instances of such a class or one of its subclasses. For
 example, to specify the number of copies, an application constructs an
 instance of the Copies class with the
 number of desired copies and uses the Copies instance as part of the
 print request. In this case, the Copies class represents the
 attribute category, and the Copies instance represents the attribute
 value.
 
Attribute Roles
When submitting a print job to a printer, the client provides the attributes describing the characteristics of the print data, such as the document name, and how the print data should be printed, such as double-sided, five copies. If a print job consists of multiple pieces of print data, different pieces might have different processing instructions, such as 8 x 11 inch media for the first document, and 11 x 17 inch media for another document.Once the printer starts processing the print job, additional information about the job becomes available, which might include: the job state (such as completed or queued) and the number of pages printed so far. These pieces of information are also attributes. Attributes can also describe the printer itself, such as: the printer name, the printer location, and the number of jobs queued.
 The Java Print Service API defines these different kinds of attributes with
 five subinterfaces of Attribute:
 
- DocAttribute specifies a characteristic of an individual document and the print job settings to be applied to an individual document.
- PrintRequestAttribute specifies a setting applied to a whole print job and to all the documents in the print job.
- PrintJobAttribute reports the status of a print job.
- PrintServiceAttribute reports the status of a print service.
- SupportedValuesAttribute gives the supported values for another attribute.
DocAttribute or to an entire print job as a
 PrintRequestAttribute. Certain low-level attributes are never used on
 their own but are always aggregated into higher-level attributes. These
 low-level attribute classes only implement interface
 Attribute, not any of the tagging subinterfaces.
 
 The Java Print Service API defines a group of standard attribute classes
 modeled upon the attributes in the Internet Printing Protocol (IPP) version
 1.1. The standard attribute classes are in the subpackage
 javax.print.attribute.standard to keep the actual attribute classes
 conceptually separate from the generic apparatus defined in package
 javax.print.attribute.
 
Attribute Sets
A client usually needs to provide more than one processing instruction when submitting a print job. For example, the client might need to specify a media size of A4 and a landscape orientation. To send more than one processing instruction, the client collects the attributes into an attribute set, which the Java Print Service API represents with the AttributeSet interface.
 The AttributeSet interface is similar to the
 Map interface: it provides a map of
 key to values, in which each key is unique and can contain no more than one
 value. However, the AttributeSet interface is designed to
 specifically support the needs of the Java Print Service API. An
 AttributeSet requires that:
 
- Each key in an AttributeSetcorresponds to a category, and the value of the key can only be one of the attribute values that belong to the category represented by the key. Thus, unlike aMap, anAttributeSetrestricts the possible values of a key: an attribute category cannot be set to an attribute value that does not belong to that category.
- No two attributes from the same category can exist in the same set. For example, an attribute collection must not contain both a "one-sided" attribute and a "two-sided" attribute because these two attributes give the printer conflicting instructions.
- Only attributes implementing the Attributeinterface can be added to the set.
javax.print.attribute package includes
 HashAttributeSet as a concrete
 implementation of the attribute set interface. HashAttributeSet
 provides an attribute set based on a hash map. You can use this
 implementation or provide your own implementation of interface
 AttributeSet.
 The Java Print Service API provides four specializations of an attribute set that are restricted to contain just one of the four kinds of attributes, as discussed in the Attribute Roles section:
Notice that only four kinds of attribute sets are listed here, but there are five kinds of attributes. Interface SupportedValuesAttribute denotes an attribute that gives the supported values for another attribute. Supported-values attributes are never aggregated into attribute sets, so there is no attribute set subinterface defined for them.
 In some contexts, an attribute set is read-only, which means that the client
 is only allowed to examine an attribute set's contents but not change them.
 In other contexts, the attribute set is read-write, which means that the
 client is allowed both to examine and to change an attribute set's contents.
 For a read-only attribute set, calling a mutating operation throws an
 UnmodifiableSetException.
 
 Package javax.print.attribute includes one concrete implementation of
 each of the attribute set subinterfaces:
 
- HashDocAttributeSet
- HashPrintRequestAttributeSet,
- HashPrintJobAttributeSet,
- HashPrintServiceAttributeSet.
Attribute Class Design
An attribute value is a small, atomic data item, such as an integer or an enumerated value. The Java Print Service API does not use primitive data types, such as int, to represent attribute values for these reasons:- Primitive data types are not type-safe. For example, a compiler should not allow a "copies" attribute value to be used for a "sides" attribute.
- Some attributes must be represented as a record of several values. One example is printer resolution, which requires two numbers, such as 600 and 300 representing 600 x 300 dpi.
Copies, class Sides, and class
 PrinterResolution. Each
 attribute class wraps one or more primitive data items containing the
 attribute's value. Attribute set operations perform frequent comparisons
 between attribute category objects when adding attributes, finding existing
 attributes in the same category, and looking up an attribute given its
 category. Because an attribute category is represented by a class, fast
 attribute-value comparisons can be performed with the Class.equals
 method.
 Even though the Java Print Service API includes a large number of different attribute categories, there are only a few different types of attribute values. Most attributes can be represented by a small number of data types, such as: integer values, integer ranges, text, or an enumeration of integer values. The type of the attribute value that a category accepts is called the attribute's abstract syntax. To provide consistency and reduce code duplication, the Java Print Service API defines abstract syntax classes to represent each abstract syntax, and these classes are used as the parent of standard attributes whenever possible. The abstract syntax classes are:
- EnumSyntax provides a type-safe enumeration in which enumerated values are represented as singleton objects. Each enumeration singleton is an instance of the enumeration class that wraps a hidden int value.
- IntegerSyntax is the abstract syntax for integer-valued attributes.
- TextSyntax is the abstract syntax for text-valued attributes, and includes a locale giving the text string's natural language.
- SetOfIntegerSyntax is the abstract syntax for attributes representing a range or set of integers
- ResolutionSyntax is the abstract syntax for attributes representing resolution values, such as 600x300 dpi.
- Size2DSyntax is the abstract syntax for attributes representing a two-dimensional size, such as a paper size of 8.5 x 11 inches.
- DateTimeSyntax is the abstract syntax for attributes whose value is a date and time.
- URISyntax is the abstract syntax for attributes whose value is a Uniform Resource Indicator.
 Each attribute class implements the Attribute interface, either
 directly or indirectly, to mark it as a printing attribute. An attribute
 class that can appear in restricted attribute sets in certain contexts also
 implements one or more subinterfaces of Attribute. Most attribute
 classes also extend the appropriate abstract syntax class to get the
 implementation. Consider the Sides attribute class:
 
public class Sides extends EnumSyntax implements DocAttribute, PrintRequestAttribute, PrintJobAttribute { public final Object getCategory() { return Sides.class; } ... }
 Since every attribute class implements Attribute, every attribute
 class must provide an implementation for the
 getCategory method,
 which returns the attribute category. In the case of Sides, the
 getCategory method returns Sides.class. The
 getCategory method is final to ensure that any vendor-defined
 subclasses of a standard attribute class appear in the same category. Every
 attribute object is immutable once constructed so that attribute object
 references can be passed around freely. To get a different attribute value,
 construct a different attribute object.
 
Attribute Vendors
The Java Print Service API is designed so that vendors can:- define new vendor-specific values for any standard attribute defined in javax.print.attribute.standard.
- define new attribute categories representing the vendor printer's proprietary capabilities not already supported by the standard attributes.
EnumSyntax specifies all
 the possible attribute values at compile time as singleton instances of the
 attribute class. This means that new enumerated values cannot be constructed
 at run time. To define new vendor-specific values for a standard enumerated
 attribute, the vendor must define a new attribute class specifying the new
 singleton instances. To ensure that the new attribute values fall in the same
 category as the standard attribute values, the new attribute class must be a
 subclass of the standard attribute class.
 
 To define a new attribute category, a vendor defines a new attribute class.
 This attribute class, like the standard attribute classes, implements
 Attribute or one of its subinterfaces and extends an abstract syntax
 class. The vendor can either use an existing abstract syntax class or define
 a new one. The new vendor-defined attribute can be used wherever an
 Attribute is used, such as in an AttributeSet.
 
Using Attributes
A typical printing application uses thePrintRequestAttributeSet
 because print-request attributes are the types of attributes that client
 usually specifies. This example demonstrates creating an attribute set of
 print-request attributes and locating a printer that can print the document
 according to the specified attributes:
 FileInputStream psStream; try { psstream = new FileInputStream("file.ps"); } catch (FileNotFoundException ffne) { } if (psstream == null) { return; } //Set the document type. See the DocFlavor documentation for //more information. DocFlavor psInFormat = DocFlavor.INPUT_STREAM.POSTSCRIPT; Doc myDoc = new SimpleDoc(pstream, 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) {} }
 Please note: In the javax.print APIs, a null reference
 parameter to methods is incorrect unless explicitly documented on the method
 as having a meaningful interpretation. Usage to the contrary is incorrect
 coding and may result in a run time exception either immediately or at some
 later time. IllegalArgumentException and NullPointerException
 are examples of typical and acceptable run time exceptions for such cases.
- Since:
- 1.4
- 
Interface Summary Interface Description Attribute InterfaceAttributeis the base interface implemented by any and every printing attribute class to indicate that the class represents a printing attribute.AttributeSet InterfaceAttributeSetspecifies the interface for a set of printing attributes.DocAttribute InterfaceDocAttributeis a tagging interface which a printing attribute class implements to indicate the attribute denotes a setting for a doc.DocAttributeSet InterfaceDocAttributeSetspecifies the interface for a set of doc attributes, i.e. printing attributes that implement interfaceDocAttribute.PrintJobAttribute PrintJobAttributeis a tagging interface which a printing attribute class implements to indicate the attribute describes the status of a Print Job or some other characteristic of a Print Job.PrintJobAttributeSet InterfacePrintJobAttributeSetspecifies the interface for a set of print job attributes, i.e. printing attributes that implement interfacePrintJobAttribute.PrintRequestAttribute InterfacePrintRequestAttributeis a tagging interface which a printing attribute class implements to indicate the attribute denotes a requested setting for a print job.PrintRequestAttributeSet InterfacePrintRequestAttributeSetspecifies the interface for a set of print request attributes, i.e. printing attributes that implement interfacePrintRequestAttribute.PrintServiceAttribute InterfacePrintServiceAttributeis a tagging interface which a printing attribute class implements to indicate the attribute describes the status of a Print Service or some other characteristic of a Print Service.PrintServiceAttributeSet InterfacePrintServiceAttributeSetspecifies the interface for a set of print job attributes, i.e. printing attributes that implement interfacePrintServiceAttribute.SupportedValuesAttribute InterfaceSupportedValuesAttributeis a tagging interface which a printing attribute class implements to indicate the attribute describes the supported values for another attribute.
- 
Class Summary Class Description AttributeSetUtilities ClassAttributeSetUtilitiesprovides static methods for manipulatingAttributeSets.DateTimeSyntax ClassDateTimeSyntaxis an abstract base class providing the common implementation of all attributes whose value is a date and time.EnumSyntax ClassEnumSyntaxis an abstract base class providing the common implementation of all "type safe enumeration" objects.HashAttributeSet ClassHashAttributeSetprovides anAttributeSetimplementation with characteristics of a hash map.HashDocAttributeSet ClassHashDocAttributeSetprovides an attribute set which inherits its implementation from classHashAttributeSetand enforces the semantic restrictions of interfaceDocAttributeSet.HashPrintJobAttributeSet ClassHashPrintJobAttributeSetprovides an attribute set which inherits its implementation from classHashAttributeSetand enforces the semantic restrictions of interfacePrintJobAttributeSet.HashPrintRequestAttributeSet ClassHashPrintRequestAttributeSetinherits its implementation from classHashAttributeSetand enforces the semantic restrictions of interfacePrintRequestAttributeSet.HashPrintServiceAttributeSet ClassHashPrintServiceAttributeSetprovides an attribute set which inherits its implementation from classHashAttributeSetand enforces the semantic restrictions of interfacePrintServiceAttributeSet.IntegerSyntax ClassIntegerSyntaxis an abstract base class providing the common implementation of all attributes with integer values.ResolutionSyntax ClassResolutionSyntaxis an abstract base class providing the common implementation of all attributes denoting a printer resolution.SetOfIntegerSyntax ClassSetOfIntegerSyntaxis an abstract base class providing the common implementation of all attributes whose value is a set of nonnegative integers.Size2DSyntax ClassSize2DSyntaxis an abstract base class providing the common implementation of all attributes denoting a size in two dimensions.TextSyntax ClassTextSyntaxis an abstract base class providing the common implementation of all attributes whose value is a string.URISyntax ClassURISyntaxis an abstract base class providing the common implementation of all attributes whose value is a Uniform Resource Identifier (URI).
- 
Exception Summary Exception Description UnmodifiableSetException Thrown to indicate that the requested operation cannot be performed because the set is unmodifiable.