AttributeSet (Java SE 15 & JDK 15) (original) (raw)

All Known Subinterfaces:

[DocAttributeSet](DocAttributeSet.html "interface in javax.print.attribute"), [PrintJobAttributeSet](PrintJobAttributeSet.html "interface in javax.print.attribute"), [PrintRequestAttributeSet](PrintRequestAttributeSet.html "interface in javax.print.attribute"), [PrintServiceAttributeSet](PrintServiceAttributeSet.html "interface in javax.print.attribute")

All Known Implementing Classes:

[HashAttributeSet](HashAttributeSet.html "class in javax.print.attribute"), [HashDocAttributeSet](HashDocAttributeSet.html "class in javax.print.attribute"), [HashPrintJobAttributeSet](HashPrintJobAttributeSet.html "class in javax.print.attribute"), [HashPrintRequestAttributeSet](HashPrintRequestAttributeSet.html "class in javax.print.attribute"), [HashPrintServiceAttributeSet](HashPrintServiceAttributeSet.html "class in javax.print.attribute")


public interface AttributeSet

Interface AttributeSet specifies the interface for a set of printing attributes. A printing attribute is an object whose class implements interface Attribute.

An attribute set contains a group of attribute values, where duplicate values are not allowed in the set. Furthermore, each value in an attribute set is a member of some category, and at most one value in any particular category is allowed in the set. For an attribute set, the values are Attribute objects, and the categories areClass objects. An attribute's category is the class (or interface) at the root of the class hierarchy for that kind of attribute. Note that an attribute object's category may be a superclass of the attribute object's class rather than the attribute object's class itself. An attribute object's category is determined by calling thegetCategory() method defined in interfaceAttribute.

The interfaces of an AttributeSet resemble those of the Java Collections API's java.util.Map interface, but is more restrictive in the types it will accept, and combines keys and values into anAttribute.

Attribute sets are used in several places in the Print Service API. In each context, only certain kinds of attributes are allowed to appear in the attribute set, as determined by the tagging interfaces which the attribute class implements -- DocAttribute,PrintRequestAttribute,PrintJobAttribute, andPrintServiceAttribute. There are four specializations of an attribute set that are restricted to contain just one of the four kinds of attribute --DocAttributeSet,PrintRequestAttributeSet,PrintJobAttributeSet, andPrintServiceAttributeSet, respectively. Note that many attribute classes implement more than one tagging interface and so may appear in more than one context.

In some contexts, the client is only allowed to examine an attribute set's contents but not change them (the set is read-only). In other places, the client is allowed both to examine and to change an attribute set's contents (the set is read-write). For a read-only attribute set, calling a mutating operation throws an UnmodifiableSetException.

The Print Service API provides one implementation of interfaceAttributeSet, class HashAttributeSet. A client can use class HashAttributeSet or provide its own implementation of interface AttributeSet. The Print Service API also provides implementations of interface AttributeSet's subinterfaces -- classesHashDocAttributeSet,HashPrintRequestAttributeSet,HashPrintJobAttributeSet, andHashPrintServiceAttributeSet.

Modifier and Type Method Description
boolean add​(Attribute attribute) Adds the specified attribute to this attribute set if it is not already present, first removing any existing value in the same attribute category as the specified attribute value.
boolean addAll​(AttributeSet attributes) Adds all of the elements in the specified set to this attribute.
void clear() Removes all attributes from this attribute set.
boolean containsKey​(Class<?> category) Returns true if this attribute set contains an attribute for the specified category.
boolean containsValue​(Attribute attribute) Returns true if this attribute set contains the given attribute value.
boolean equals​(Object object) Compares the specified object with this attribute set for equality.
Attribute get​(Class<?> category) Returns the attribute value which this attribute set contains in the given attribute category.
int hashCode() Returns the hash code value for this attribute set.
boolean isEmpty() Returns true if this attribute set contains no attributes.
boolean remove​(Class<?> category) Removes any attribute for this category from this attribute set if present.
boolean remove​(Attribute attribute) Removes the specified attribute from this attribute set if present.
int size() Returns the number of attributes in this attribute set.
Attribute[] toArray() Returns an array of the attributes contained in this set.