| java.lang.Object com.sun.media.imageio.plugins.tiff.TIFFField
TIFFField | public class TIFFField implements Comparable(Code) | | A class representing a field in a TIFF 6.0 Image File Directory.
A field in a TIFF Image File Directory (IFD) is defined as a
tag number accompanied by a sequence of values of identical data type.
TIFF 6.0 defines 12 data types; a 13th type IFD is
defined in TIFF Tech Note 1 of TIFF Specification Supplement 1. These
TIFF data types are referred to by Java constants and mapped internally
onto Java language data types and type names as follows:
See Also: TIFFDirectory See Also: TIFFTag |
Method Summary | |
public int | compareTo(Object o) Compares this TIFFField with another
TIFFField by comparing the tags. | public static Object | createArrayForType(int dataType, int count) Creates an array appropriate for the indicated data type. | public static TIFFField | createFromMetadataNode(TIFFTagSet tagSet, Node node) Creates a TIFFField from a TIFF native image
metadata node. | public byte[] | getAsBytes() Returns the data as an uninterpreted array of
byte s. | public char[] | getAsChars() Returns TIFFTag.TIFF_SHORT data as an array of
char s (unsigned 16-bit integers). | public double | getAsDouble(int index) Returns data in any format as a double . | public double[] | getAsDoubles() Returns TIFFTag.TIFF_DOUBLE data as an array of
double s (64-bit floating-point values). | public float | getAsFloat(int index) Returns data in any format as a float . | public float[] | getAsFloats() Returns TIFFTag.TIFF_FLOAT data as an array of
float s (32-bit floating-point values). | public int | getAsInt(int index) Returns data in any format as an int .
TIFFTag.TIFF_BYTE values are treated as unsigned; that
is, no sign extension will take place and the returned value
will be in the range [0, 255]. | public int[] | getAsInts() Returns TIFFTag.TIFF_SLONG data as an array of
int s (signed 32-bit integers). | public long | getAsLong(int index) Returns data in any format as a long . | public long[] | getAsLongs() Returns TIFFTag.TIFF_LONG or
TIFF_IFD_POINTER data as an array of
long s (signed 64-bit integers). | public Node | getAsNativeNode() Returns the TIFFField as a node named either
"TIFFField" or "TIFFIFD" as described in the
TIFF native image metadata specification. | public long[] | getAsRational(int index) Returns a TIFFTag.TIFF_RATIONAL data item as a two-element array
of ints. | public long[][] | getAsRationals() Returns TIFFTag.TIFF_RATIONAL data as an array of
2-element arrays of long s. | public int[] | getAsSRational(int index) Returns a TIFFTag.TIFF_SRATIONAL data item as a
two-element array of int s. | public int[][] | getAsSRationals() Returns TIFFTag.TIFF_SRATIONAL data as an array of
2-element arrays of int s. | public short[] | getAsShorts() Returns TIFFTag.TIFF_SSHORT data as an array of
short s (signed 16-bit integers). | public String | getAsString(int index) Returns a TIFFTag.TIFF_ASCII value as a
String . | public int | getCount() Returns the number of data items present in the field. | public Object | getData() Returns a reference to the data object associated with the field. | public TIFFTag | getTag() Retrieves the tag associated with this field. | public int | getTagNumber() Retrieves the tag number in the range [0, 65535] . | public int | getType() Returns the type of the data stored in the field. | public static int | getTypeByName(String typeName) Returns the data type constant corresponding to the supplied data
type name. | public static String | getTypeName(int dataType) Returns the name of the supplied data type constant.
Parameters: dataType - One of the TIFFTag.TIFF_* constantsindicating the data type of the field as written to the TIFF stream. | public String | getValueAsString(int index) Returns a String containing a human-readable
version of the data item. | public boolean | isIntegral() Indicates whether the value associated with the field is of
integral data type. |
TIFFField | public TIFFField(TIFFTag tag, int type, int count, Object data)(Code) | | Constructs a TIFFField with arbitrary data. The
type parameter must be a value for which
TIFFTag.isDataTypeOK tag.isDataTypeOK() returns true . The data parameter must
be an array of a Java type appropriate for the type of the TIFF
field unless
TIFFTag.isIFDPointertag.isIFDPointer() returns true in
which case it must be a TIFFDirectory instance.
Neither the legality of type with respect to
tag nor that or data with respect to
type is verified by this constructor. The methods
TIFFTag.isDataTypeOK TIFFTag.isDataTypeOK() and
TIFFField.createArrayForType createArrayForType() should be used programmatically to ensure that subsequent errors
such as ClassCastException s do not occur as a result
of providing inconsitent parameters to this constructor.
Note that the value (data) of the TIFFField
will always be the actual field value regardless of the number of
bytes required for that value. This is the case despite the fact
that the TIFF IFD Entry corresponding to the field may
actually contain the offset to the field's value rather than
the value itself (the latter occurring if and only if the
value fits into 4 bytes). In other words, the value of the
field will already have been read from the TIFF stream. This
subsumes the case where tag.isIFDPointer() returns
true and the value will be a TIFFDirectory
rather than an array.
Parameters: tag - The tag to associated with this field. Parameters: type - One of the TIFFTag.TIFF_* constantsindicating the data type of the field as written to the TIFF stream. Parameters: count - The number of data values. Parameters: data - The actual data content of the field. throws: IllegalArgumentException - if tag == null . throws: IllegalArgumentException - if dataType is notone of the TIFFTag.TIFF_* data type constants. throws: IllegalArgumentException - if count < 0 . |
TIFFField | public TIFFField(TIFFTag tag, int value)(Code) | | Constructs a TIFFField with a single integral value.
The field will have type
TIFFTag.TIFF_SHORT TIFF_SHORT if
val < 65536 and type
TIFFTag.TIFF_LONG TIFF_LONG otherwise.
It is not verified whether the resulting type is
legal for tag .
Parameters: tag - The tag to associate with this field. Parameters: value - The value to associate with this field. throws: IllegalArgumentException - if tag == null . throws: IllegalArgumentException - if value < 0 . |
compareTo | public int compareTo(Object o)(Code) | | Compares this TIFFField with another
TIFFField by comparing the tags.
Note: this class has a natural ordering that is inconsistent
with equals() .
throws: IllegalArgumentException - if the parameter is null . throws: ClassCastException - if the parameter is not aTIFFField . |
createArrayForType | public static Object createArrayForType(int dataType, int count)(Code) | | Creates an array appropriate for the indicated data type.
Parameters: dataType - One of the TIFFTag.TIFF_* data typeconstants. Parameters: count - The number of values in the array. throws: IllegalArgumentException - if dataType is notone of the TIFFTag.TIFF_* data type constants. throws: IllegalArgumentException - if count < 0 . |
createFromMetadataNode | public static TIFFField createFromMetadataNode(TIFFTagSet tagSet, Node node)(Code) | | Creates a TIFFField from a TIFF native image
metadata node. If the value of the "tagNumber" attribute
of the node is not found in tagSet then a new
TIFFTag with name "unknown" will be
created and assigned to the field.
Parameters: tagSet - The TIFFTagSet to which theTIFFTag of the field belongs. Parameters: node - A native TIFF image metadata TIFFField node. throws: IllegalArgumentException - if node isnull . throws: IllegalArgumentException - if the name of the node is not"TIFFField" . |
getAsBytes | public byte[] getAsBytes()(Code) | | Returns the data as an uninterpreted array of
byte s. The type of the field must be one of
TIFFTag.TIFF_BYTE , TIFF_SBYTE , or
TIFF_UNDEFINED .
For data in TIFFTag.TIFF_BYTE format, the application
must take care when promoting the data to longer integral types
to avoid sign extension.
throws: ClassCastException - if the field is not of typeTIFF_BYTE , TIFF_SBYTE , orTIFF_UNDEFINED . |
getAsChars | public char[] getAsChars()(Code) | | Returns TIFFTag.TIFF_SHORT data as an array of
char s (unsigned 16-bit integers).
throws: ClassCastException - if the field is not of typeTIFF_SHORT . |
getAsDouble | public double getAsDouble(int index)(Code) | | Returns data in any format as a double .
TIFFTag.TIFF_BYTE and TIFF_UNDEFINED data
are treated as unsigned; that is, no sign extension will take
place and the returned value will be in the range [0, 255].
TIFF_SBYTE data will be returned in the range
[-128, 127].
Data in TIFF_SRATIONAL or
TIFF_RATIONAL format are evaluated by dividing the
numerator into the denominator using double-precision
arithmetic.
Data in TIFF_ASCII format will be parsed as by
the Double.parseDouble method.
|
getAsDoubles | public double[] getAsDoubles()(Code) | | Returns TIFFTag.TIFF_DOUBLE data as an array of
double s (64-bit floating-point values).
throws: ClassCastException - if the field is not of typeTIFF_DOUBLE . |
getAsFloat | public float getAsFloat(int index)(Code) | | Returns data in any format as a float .
TIFFTag.TIFF_BYTE and TIFF_UNDEFINED data
are treated as unsigned; that is, no sign extension will take
place and the returned value will be in the range [0, 255].
TIFF_SBYTE data will be returned in the range
[-128, 127].
Data in TIFF_SLONG , TIFF_LONG ,
TIFF_DOUBLE , or TIFF_IFD_POINTER format are
simply cast to float and may suffer from
truncation.
Data in TIFF_SRATIONAL or
TIFF_RATIONAL format are evaluated by dividing the
numerator into the denominator using double-precision
arithmetic and then casting to float .
Data in TIFF_ASCII format will be parsed as by
the Double.parseDouble method, with the result
cast to float .
|
getAsFloats | public float[] getAsFloats()(Code) | | Returns TIFFTag.TIFF_FLOAT data as an array of
float s (32-bit floating-point values).
throws: ClassCastException - if the field is not of typeTIFF_FLOAT . |
getAsInt | public int getAsInt(int index)(Code) | | Returns data in any format as an int .
TIFFTag.TIFF_BYTE values are treated as unsigned; that
is, no sign extension will take place and the returned value
will be in the range [0, 255]. TIFF_SBYTE data
will be returned in the range [-128, 127].
A TIFF_UNDEFINED value is treated as though
it were a TIFF_BYTE .
Data in TIFF_SLONG , TIFF_LONG ,
TIFF_FLOAT , TIFF_DOUBLE or
TIFF_IFD_POINTER format are simply cast to
int and may suffer from truncation.
Data in TIFF_SRATIONAL or
TIFF_RATIONAL format are evaluated by dividing the
numerator into the denominator using double-precision
arithmetic and then casting to int . Loss of
precision and truncation may occur.
Data in TIFF_ASCII format will be parsed as by
the Double.parseDouble method, with the result
case to int .
|
getAsInts | public int[] getAsInts()(Code) | | Returns TIFFTag.TIFF_SLONG data as an array of
int s (signed 32-bit integers).
throws: ClassCastException - if the field is not of typeTIFF_SHORT , TIFF_SSHORT , orTIFF_SLONG . |
getAsLong | public long getAsLong(int index)(Code) | | Returns data in any format as a long .
TIFFTag.TIFF_BYTE and TIFF_UNDEFINED data
are treated as unsigned; that is, no sign extension will take
place and the returned value will be in the range [0, 255].
TIFF_SBYTE data will be returned in the range
[-128, 127].
Data in TIFF_ASCII format will be parsed as by
the Double.parseDouble method, with the result
cast to long .
|
getAsLongs | public long[] getAsLongs()(Code) | | Returns TIFFTag.TIFF_LONG or
TIFF_IFD_POINTER data as an array of
long s (signed 64-bit integers).
throws: ClassCastException - if the field is not of typeTIFF_LONG or TIFF_IFD_POINTER . |
getAsNativeNode | public Node getAsNativeNode()(Code) | | Returns the TIFFField as a node named either
"TIFFField" or "TIFFIFD" as described in the
TIFF native image metadata specification. The node will be named
"TIFFIFD" if and only if the field's data object is an
instance of
TIFFDirectory or equivalently
TIFFTag.isIFDPointer getTag.isIFDPointer() returns
true .
a Node named "TIFFField" or"TIFFIFD". |
getAsRational | public long[] getAsRational(int index)(Code) | | Returns a TIFFTag.TIFF_RATIONAL data item as a two-element array
of ints.
throws: ClassCastException - if the field is not of typeTIFF_RATIONAL . |
getAsRationals | public long[][] getAsRationals()(Code) | | Returns TIFFTag.TIFF_RATIONAL data as an array of
2-element arrays of long s.
throws: ClassCastException - if the field is not of typeTIFF_RATIONAL . |
getAsSRational | public int[] getAsSRational(int index)(Code) | | Returns a TIFFTag.TIFF_SRATIONAL data item as a
two-element array of int s.
throws: ClassCastException - if the field is not of typeTIFF_SRATIONAL . |
getAsSRationals | public int[][] getAsSRationals()(Code) | | Returns TIFFTag.TIFF_SRATIONAL data as an array of
2-element arrays of int s.
throws: ClassCastException - if the field is not of typeTIFF_SRATIONAL . |
getAsShorts | public short[] getAsShorts()(Code) | | Returns TIFFTag.TIFF_SSHORT data as an array of
short s (signed 16-bit integers).
throws: ClassCastException - if the field is not of typeTIFF_SSHORT . |
getAsString | public String getAsString(int index)(Code) | | Returns a TIFFTag.TIFF_ASCII value as a
String .
throws: ClassCastException - if the field is not of typeTIFF_ASCII . |
getCount | public int getCount()(Code) | | Returns the number of data items present in the field. For
TIFFTag.TIFF_ASCII fields, the value returned is the
number of String s, not the total length of the
data as in the file representation.
|
getData | public Object getData()(Code) | | Returns a reference to the data object associated with the field.
The data object of the field. |
getTag | public TIFFTag getTag()(Code) | | Retrieves the tag associated with this field.
The associated TIFFTag . |
getTagNumber | public int getTagNumber()(Code) | | Retrieves the tag number in the range [0, 65535] .
The tag number. |
getType | public int getType()(Code) | | Returns the type of the data stored in the field. For a TIFF 6.0
stream, the value will equal one of the TIFFTag.TIFF_*
constants. For future revisions of TIFF, higher values are possible.
The data type of the field value. |
getTypeByName | public static int getTypeByName(String typeName)(Code) | | Returns the data type constant corresponding to the supplied data
type name. If the name is unknown -1 will be returned.
One of the TIFFTag.TIFF_* constants or-1 if the name is not recognized. |
getTypeName | public static String getTypeName(int dataType)(Code) | | Returns the name of the supplied data type constant.
Parameters: dataType - One of the TIFFTag.TIFF_* constantsindicating the data type of the field as written to the TIFF stream. The type name corresponding to the supplied type constant. throws: IllegalArgumentException - if dataType is notone of the TIFFTag.TIFF_* data type constants. |
getValueAsString | public String getValueAsString(int index)(Code) | | Returns a String containing a human-readable
version of the data item. Data of type
TIFFTag.TIFF_RATIONAL or TIFF_SRATIONAL are
represented as a pair of integers separated by a
'/' character.
throws: ClassCastException - if the field is not of one of thelegal field types. |
isIntegral | public boolean isIntegral()(Code) | | Indicates whether the value associated with the field is of
integral data type.
Whether the field type is integral. |
|
|