-
- All Known Subinterfaces:
- DocAttributeSet, PrintJobAttributeSet, PrintRequestAttributeSet, PrintServiceAttributeSet
- All Known Implementing Classes:
- HashAttributeSet, HashDocAttributeSet, HashPrintJobAttributeSet, HashPrintRequestAttributeSet, HashPrintServiceAttributeSet
public interface AttributeSet
Interface AttributeSet specifies the interface for a set of printing attributes. A printing attribute is an object whose class implements interfaceAttribute
.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 the
method defined in interfacegetCategory()
Attribute
.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 an Attribute.
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.-
A
DocAttributeSet
, containingDocAttribute
s, specifies the characteristics of an individual doc and the print job settings to be applied to an individual doc. -
A
PrintRequestAttributeSet
, containingPrintRequestAttribute
s, specifies the settings to be applied to a whole print job and to all the docs in the print job. -
A
PrintJobAttributeSet
, containingPrintJobAttribute
s, reports the status of a print job. -
A
PrintServiceAttributeSet
, containingPrintServiceAttribute
s, reports the status of a Print Service instance.
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 interface AttributeSet, class
HashAttributeSet
. A client can use classHashAttributeSet
or provide its own implementation of interface AttributeSet. The Print Service API also provides implementations of interface AttributeSet's subinterfaces -- classesHashDocAttributeSet
,HashPrintRequestAttributeSet
,HashPrintJobAttributeSet
, andHashPrintServiceAttributeSet
.
-
-
Method Summary
Methods Modifier and Type Method and 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(Attribute attribute)
Removes the specified attribute from this attribute set if present.boolean
remove(Class<?> category)
Removes any attribute for this category 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.
-
-
-
Method Detail
-
get
Attribute get(Class<?> category)
Returns the attribute value which this attribute set contains in the given attribute category. Returns null if this attribute set does not contain any attribute value in the given attribute category.- Parameters:
category
- Attribute category whose associated attribute value is to be returned. It must be aClass
that implements interfaceAttribute
.- Returns:
- The attribute value in the given attribute category contained in this attribute set, or null if this attribute set does not contain any attribute value in the given attribute category.
- Throws:
NullPointerException
- (unchecked exception) Thrown if thecategory
is null.ClassCastException
- (unchecked exception) Thrown if thecategory
is not aClass
that implements interfaceAttribute
.
-
add
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.- Parameters:
attribute
- Attribute value to be added to this attribute set.- Returns:
- true if this attribute set changed as a result of the call, i.e., the given attribute value was not already a member of this attribute set.
- Throws:
NullPointerException
- (unchecked exception) Thrown if theattribute
is null.UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support theadd()
operation.
-
remove
boolean remove(Class<?> category)
Removes any attribute for this category from this attribute set if present. Ifcategory
is null, thenremove()
does nothing and returns false.- Parameters:
category
- Attribute category to be removed from this attribute set.- Returns:
- true if this attribute set changed as a result of the call, i.e., the given attribute value had been a member of this attribute set.
- Throws:
UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support theremove()
operation.
-
remove
boolean remove(Attribute attribute)
Removes the specified attribute from this attribute set if present. Ifattribute
is null, thenremove()
does nothing and returns false.- Parameters:
attribute
- Attribute value to be removed from this attribute set.- Returns:
- true if this attribute set changed as a result of the call, i.e., the given attribute value had been a member of this attribute set.
- Throws:
UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support theremove()
operation.
-
containsKey
boolean containsKey(Class<?> category)
Returns true if this attribute set contains an attribute for the specified category.- Parameters:
category
- whose presence in this attribute set is to be tested.- Returns:
- true if this attribute set contains an attribute value for the specified category.
-
containsValue
boolean containsValue(Attribute attribute)
Returns true if this attribute set contains the given attribute value.- Parameters:
attribute
- Attribute value whose presence in this attribute set is to be tested.- Returns:
- true if this attribute set contains the given attribute value.
-
addAll
boolean addAll(AttributeSet attributes)
Adds all of the elements in the specified set to this attribute. The outcome is the same as if the =
operation had been applied to this attribute set successively with each element from the specified set. The behavior of theadd(Attribute)
addAll(AttributeSet)
operation is unspecified if the specified set is modified while the operation is in progress.If the
addAll(AttributeSet)
operation throws an exception, the effect on this attribute set's state is implementation dependent; elements from the specified set before the point of the exception may or may not have been added to this attribute set.- Parameters:
attributes
- whose elements are to be added to this attribute set.- Returns:
- true if this attribute set changed as a result of the call.
- Throws:
UnmodifiableSetException
- (Unchecked exception) Thrown if this attribute set does not support the addAll(AttributeSet) method.NullPointerException
- (Unchecked exception) Thrown if some element in the specified set is null.- See Also:
add(Attribute)
-
size
int size()
Returns the number of attributes in this attribute set. If this attribute set contains more than Integer.MAX_VALUE elements, returns Integer.MAX_VALUE.- Returns:
- The number of attributes in this attribute set.
-
toArray
Attribute[] toArray()
Returns an array of the attributes contained in this set.- Returns:
- the Attributes contained in this set as an array, zero length if the AttributeSet is empty.
-
clear
void clear()
Removes all attributes from this attribute set.- Throws:
UnmodifiableSetException
- (unchecked exception) Thrown if this attribute set does not support theclear()
operation.
-
isEmpty
boolean isEmpty()
Returns true if this attribute set contains no attributes.- Returns:
- true if this attribute set contains no attributes.
-
equals
boolean equals(Object object)
Compares the specified object with this attribute set for equality. Returns true if the given object is also an attribute set and the two attribute sets contain the same attribute category-attribute value mappings. This ensures that the equals() method works properly across different implementations of the AttributeSet interface.- Overrides:
equals
in classObject
- Parameters:
object
- to be compared for equality with this attribute set.- Returns:
- true if the specified object is equal to this attribute set.
- See Also:
Object.hashCode()
,HashMap
-
hashCode
int hashCode()
Returns the hash code value for this attribute set. The hash code of an attribute set is defined to be the sum of the hash codes of each entry in the AttributeSet. This ensures that t1.equals(t2) implies that t1.hashCode()==t2.hashCode() for any two attribute sets t1 and t2, as required by the general contract of
.Object.hashCode()
- Overrides:
hashCode
in classObject
- Returns:
- The hash code value for this attribute set.
- See Also:
Object.equals(java.lang.Object)
,System.identityHashCode(java.lang.Object)
-
-
Document created the 11/06/2005, last modified the 04/03/2020
Source of the printed document:https://www.gaudry.be/en/java-api-rf-javax/print/attribute/attributeset.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.
References
These references and links indicate documents consulted during the writing of this page, or which may provide additional information, but the authors of these sources can not be held responsible for the content of this page.
The author This site is solely responsible for the way in which the various concepts, and the freedoms that are taken with the reference works, are presented here. Remember that you must cross multiple source information to reduce the risk of errors.