public class JPEGHuffmanTable extends Object
A class encapsulating a single JPEG Huffman table. Fields are provided for the "standard" tables taken from Annex K of the JPEG specification. These are the tables used as defaults.
For more information about the operation of the standard JPEG plug-in, see the JPEG metadata format specification and usage notes
public static final JPEGHuffmanTable StdDCLuminance
The standard DC luminance Huffman table.
public static final JPEGHuffmanTable StdDCChrominance
The standard DC chrominance Huffman table.
public static final JPEGHuffmanTable StdACLuminance
The standard AC luminance Huffman table.
public static final JPEGHuffmanTable StdACChrominance
The standard AC chrominance Huffman table.
public JPEGHuffmanTable(short[] lengths, short[] values)
Creates a Huffman table and initializes it. The input arrays are copied. The arrays must describe a possible Huffman table. For example, 3 codes cannot be expressed with a single bit.
lengths
- an array of short
s where lengths[k]
is equal to the number of values with corresponding codes of length k + 1
bits.values
- an array of shorts containing the values in order of increasing code length.IllegalArgumentException
- if lengths
or values
are null, the length of lengths
is greater than 16, the length of values
is greater than 256, if any value in lengths
or values
is less than zero, or if the arrays do not describe a valid Huffman table.public short[] getLengths()
Returns an array of short
s containing the number of values for each length in the Huffman table. The returned array is a copy.
short
array where array[k-1]
is equal to the number of values in the table of length k
.getValues()
public short[] getValues()
Returns an array of short
s containing the values arranged by increasing length of their corresponding codes. The interpretation of the array is dependent on the values returned from getLengths
. The returned array is a copy.
short
array of values.getLengths()
public String toString()
Returns a String
representing this Huffman table.
© 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.