public interface AttributeSet
A collection of unique attributes. This is a read-only, immutable interface. An attribute is basically a key and a value assigned to the key. The collection may represent something like a style run, a logical style, etc. These are generally used to describe features that will contribute to some graphical representation such as a font. The set of possible keys is unbounded and can be anything. Typically View implementations will respond to attribute definitions and render something to represent the attributes.
Attributes can potentially resolve in a hierarchy. If a key doesn't resolve locally, and a resolving parent exists, the key will be resolved through the parent.
MutableAttributeSet
Modifier and Type | Interface and Description |
---|---|
static interface |
AttributeSet.CharacterAttribute This interface is the type signature that is expected to be present on any attribute key that contributes to character level presentation. |
static interface |
AttributeSet.ColorAttribute This interface is the type signature that is expected to be present on any attribute key that contributes to presentation of color. |
static interface |
AttributeSet.FontAttribute This interface is the type signature that is expected to be present on any attribute key that contributes to the determination of what font to use to render some text. |
static interface |
AttributeSet.ParagraphAttribute This interface is the type signature that is expected to be present on any attribute key that contributes to the paragraph level presentation. |
static final Object NameAttribute
Attribute name used to name the collection of attributes.
static final Object ResolveAttribute
Attribute name used to identify the resolving parent set of attributes, if one is defined.
int getAttributeCount()
Returns the number of attributes that are defined locally in this set. Attributes that are defined in the parent set are not included.
boolean isDefined(Object attrName)
Checks whether the named attribute has a value specified in the set without resolving through another attribute set.
attrName
- the attribute nameboolean isEqual(AttributeSet attr)
Determines if the two attribute sets are equivalent.
attr
- an attribute setAttributeSet copyAttributes()
Returns an attribute set that is guaranteed not to change over time.
Object getAttribute(Object key)
Fetches the value of the given attribute. If the value is not found locally, the search is continued upward through the resolving parent (if one exists) until the value is either found or there are no more parents. If the value is not found, null is returned.
key
- the non-null key of the attribute bindingnull
if not foundEnumeration<?> getAttributeNames()
Returns an enumeration over the names of the attributes that are defined locally in the set. Names of attributes defined in the resolving parent, if any, are not included. The values of the Enumeration
may be anything and are not constrained to a particular Object
type.
This method never returns null
. For a set with no attributes, it returns an empty Enumeration
.
boolean containsAttribute(Object name, Object value)
Returns true
if this set defines an attribute with the same name and an equal value. If such an attribute is not found locally, it is searched through in the resolving parent hierarchy.
name
- the non-null attribute namevalue
- the valuetrue
if the set defines the attribute with an equal value, either locally or through its resolving parentNullPointerException
- if either name
or value
is null
boolean containsAttributes(AttributeSet attributes)
Returns true
if this set defines all the attributes from the given set with equal values. If an attribute is not found locally, it is searched through in the resolving parent hierarchy.
attributes
- the set of attributes to check againsttrue
if this set defines all the attributes with equal values, either locally or through its resolving parentNullPointerException
- if attributes
is null
AttributeSet getResolveParent()
Gets the resolving parent.
© 1993–2017, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.