Class XpmImageParser
- java.lang.Object
-
- org.apache.commons.imaging.common.BinaryFileParser
-
- org.apache.commons.imaging.ImageParser
-
- org.apache.commons.imaging.formats.xpm.XpmImageParser
-
public class XpmImageParser extends ImageParser
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private static class
XpmImageParser.PaletteEntry
private static class
XpmImageParser.XpmHeader
private static class
XpmImageParser.XpmParseResult
-
Field Summary
Fields Modifier and Type Field Description private static java.lang.String[]
ACCEPTED_EXTENSIONS
private static java.util.Map<java.lang.String,java.lang.Integer>
colorNames
private static java.lang.String
DEFAULT_EXTENSION
private static char[]
WRITE_PALETTE
-
Constructor Summary
Constructors Constructor Description XpmImageParser()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description boolean
dumpImageFile(java.io.PrintWriter pw, ByteSource byteSource)
Write the ImageInfo and format-specific information for the image content of the specified byte source to a PrintWriterprotected java.lang.String[]
getAcceptedExtensions()
Get an array of all accepted extensionsprotected ImageFormat[]
getAcceptedTypes()
Get an array of ImageFormat objects describing all accepted typesjava.awt.image.BufferedImage
getBufferedImage(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params)
Gets a buffered image specified by the byte source (for sources that specify multiple images, choice of which image is returned is implementation dependent).java.lang.String
getDefaultExtension()
Get the default extension for the format specified by an implementation of ImageParser.byte[]
getICCProfileBytes(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params)
Get an array of bytes describing the International Color Consortium (ICC) specification for the color space of the image contained in the input byteSource.ImageInfo
getImageInfo(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params)
Get image information from the specified ByteSource.java.awt.Dimension
getImageSize(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params)
Get the size of the image described by the specified ByteSource.ImageMetadata
getMetadata(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params)
Get image metadata from the specified byte source.java.lang.String
getName()
Get a descriptive name for the implementation of an ImageParser.private static void
loadColorNames()
private int
parseColor(java.lang.String color)
private boolean
parseNextString(BasicCParser cParser, java.lang.StringBuilder stringBuilder)
private void
parsePaletteEntries(XpmImageParser.XpmHeader xpmHeader, BasicCParser cParser)
private XpmImageParser.XpmHeader
parseXpmHeader(BasicCParser cParser)
private XpmImageParser.XpmParseResult
parseXpmHeader(ByteSource byteSource)
private XpmImageParser.XpmHeader
parseXpmValuesSection(java.lang.String row)
private java.lang.String
pixelsForIndex(int index, int charsPerPixel)
private void
populatePaletteEntry(XpmImageParser.PaletteEntry paletteEntry, java.lang.String key, java.lang.String color)
private java.lang.String
randomName()
private XpmImageParser.XpmHeader
readXpmHeader(ByteSource byteSource)
private java.awt.image.BufferedImage
readXpmImage(XpmImageParser.XpmHeader xpmHeader, BasicCParser cParser)
private java.lang.String
toColor(int color)
void
writeImage(java.awt.image.BufferedImage src, java.io.OutputStream os, java.util.Map<java.lang.String,java.lang.Object> params)
Writes the content of a BufferedImage to the specified output stream.-
Methods inherited from class org.apache.commons.imaging.ImageParser
canAcceptExtension, canAcceptExtension, canAcceptType, dumpImageFile, dumpImageFile, dumpImageFile, getAllBufferedImages, getAllBufferedImages, getAllBufferedImages, getAllImageParsers, getBufferedImage, getBufferedImage, getBufferedImageFactory, getFormatCompliance, getFormatCompliance, getFormatCompliance, getICCProfileBytes, getICCProfileBytes, getICCProfileBytes, getICCProfileBytes, getImageInfo, getImageInfo, getImageInfo, getImageSize, getImageSize, getImageSize, getImageSize, getMetadata, getMetadata, getMetadata, getMetadata, getMetadata, isStrict
-
Methods inherited from class org.apache.commons.imaging.common.BinaryFileParser
debugNumber, debugNumber, getByteOrder, setByteOrder
-
-
-
-
Field Detail
-
DEFAULT_EXTENSION
private static final java.lang.String DEFAULT_EXTENSION
- See Also:
- Constant Field Values
-
ACCEPTED_EXTENSIONS
private static final java.lang.String[] ACCEPTED_EXTENSIONS
-
colorNames
private static java.util.Map<java.lang.String,java.lang.Integer> colorNames
-
WRITE_PALETTE
private static final char[] WRITE_PALETTE
-
-
Method Detail
-
loadColorNames
private static void loadColorNames() throws ImageReadException
- Throws:
ImageReadException
-
getName
public java.lang.String getName()
Description copied from class:ImageParser
Get a descriptive name for the implementation of an ImageParser.- Specified by:
getName
in classImageParser
- Returns:
- a valid, subject-matter-specific string.
-
getDefaultExtension
public java.lang.String getDefaultExtension()
Description copied from class:ImageParser
Get the default extension for the format specified by an implementation of ImageParser. Some parsers can support more than one extension (i.e. .JPEG, .JPG; .TIF, .TIFF, etc.).- Specified by:
getDefaultExtension
in classImageParser
- Returns:
- A valid string.
-
getAcceptedExtensions
protected java.lang.String[] getAcceptedExtensions()
Description copied from class:ImageParser
Get an array of all accepted extensions- Specified by:
getAcceptedExtensions
in classImageParser
- Returns:
- A valid array of one or more elements.
-
getAcceptedTypes
protected ImageFormat[] getAcceptedTypes()
Description copied from class:ImageParser
Get an array of ImageFormat objects describing all accepted types- Specified by:
getAcceptedTypes
in classImageParser
- Returns:
- A valid array of one or more elements.
-
getMetadata
public ImageMetadata getMetadata(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Get image metadata from the specified byte source. Format-specific ImageParser implementations are expected to return a valid IImageMetadata object or to throw an ImageReadException if unable to process the specified byte source.The params argument provides a mechanism for individual implementations to pass optional information into the parser. Not all formats will require this capability. Because the base class may call this method with a null params argument, implementations should always include logic for ignoring null input.
- Specified by:
getMetadata
in classImageParser
- Parameters:
byteSource
- A valid byte source.params
- Optional instructions for special-handling or interpretation of the input data (null objects are permitted and must be supported by implementations).- Returns:
- A valid, potentially subject-matter-specific implementation of the IImageMetadata interface describing the content extracted from the source content.
- Throws:
ImageReadException
- In the event that the ByteSource content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful data read operation.
-
getImageInfo
public ImageInfo getImageInfo(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Get image information from the specified ByteSource. Format-specific ImageParser implementations are expected to return a valid ImageInfo object or to throw an ImageReadException if unable to process the specified data.The params argument provides a mechanism for individual implementations to pass optional information into the parser. Not all formats will require this capability. Because the base class may call this method with a null params argument, implementations should always include logic for ignoring null input.
- Specified by:
getImageInfo
in classImageParser
- Parameters:
byteSource
- A valid ByteSource objectparams
- Optional instructions for special-handling or interpretation of the input data (null objects are permitted and must be supported by implementations).- Returns:
- A valid image information object describing the content extracted from the specified data.
- Throws:
ImageReadException
- In the event that the specified content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful data access operation.
-
getImageSize
public java.awt.Dimension getImageSize(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Get the size of the image described by the specified ByteSource.- Specified by:
getImageSize
in classImageParser
- Parameters:
byteSource
- A valid reference to a ByteSource.params
- Optional instructions for special-handling or interpretation of the input data.- Returns:
- A valid instance of Dimension.
- Throws:
ImageReadException
- In the event that the specified content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful read or access operation.
-
getICCProfileBytes
public byte[] getICCProfileBytes(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Get an array of bytes describing the International Color Consortium (ICC) specification for the color space of the image contained in the input byteSource. Not all formats support ICC profiles.- Specified by:
getICCProfileBytes
in classImageParser
- Parameters:
byteSource
- A valid ByteSource.params
- Optional instructions for special-handling or interpretation of the input data.- Returns:
- If available, a valid array of bytes; otherwise, a null
- Throws:
ImageReadException
- In the event that the specified content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful read or access operation.
-
readXpmHeader
private XpmImageParser.XpmHeader readXpmHeader(ByteSource byteSource) throws ImageReadException, java.io.IOException
- Throws:
ImageReadException
java.io.IOException
-
parseXpmHeader
private XpmImageParser.XpmParseResult parseXpmHeader(ByteSource byteSource) throws ImageReadException, java.io.IOException
- Throws:
ImageReadException
java.io.IOException
-
parseNextString
private boolean parseNextString(BasicCParser cParser, java.lang.StringBuilder stringBuilder) throws java.io.IOException, ImageReadException
- Throws:
java.io.IOException
ImageReadException
-
parseXpmValuesSection
private XpmImageParser.XpmHeader parseXpmValuesSection(java.lang.String row) throws ImageReadException
- Throws:
ImageReadException
-
parseColor
private int parseColor(java.lang.String color) throws ImageReadException
- Throws:
ImageReadException
-
populatePaletteEntry
private void populatePaletteEntry(XpmImageParser.PaletteEntry paletteEntry, java.lang.String key, java.lang.String color) throws ImageReadException
- Throws:
ImageReadException
-
parsePaletteEntries
private void parsePaletteEntries(XpmImageParser.XpmHeader xpmHeader, BasicCParser cParser) throws java.io.IOException, ImageReadException
- Throws:
java.io.IOException
ImageReadException
-
parseXpmHeader
private XpmImageParser.XpmHeader parseXpmHeader(BasicCParser cParser) throws ImageReadException, java.io.IOException
- Throws:
ImageReadException
java.io.IOException
-
readXpmImage
private java.awt.image.BufferedImage readXpmImage(XpmImageParser.XpmHeader xpmHeader, BasicCParser cParser) throws ImageReadException, java.io.IOException
- Throws:
ImageReadException
java.io.IOException
-
dumpImageFile
public boolean dumpImageFile(java.io.PrintWriter pw, ByteSource byteSource) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Write the ImageInfo and format-specific information for the image content of the specified byte source to a PrintWriter- Overrides:
dumpImageFile
in classImageParser
- Parameters:
pw
- print writer used for writing the ImageInfobyteSource
- A valid byte source.- Returns:
- A valid PrintWriter.
- Throws:
ImageReadException
- In the event that the specified content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful read or access operation.
-
getBufferedImage
public final java.awt.image.BufferedImage getBufferedImage(ByteSource byteSource, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageReadException, java.io.IOException
Description copied from class:ImageParser
Gets a buffered image specified by the byte source (for sources that specify multiple images, choice of which image is returned is implementation dependent).- Specified by:
getBufferedImage
in classImageParser
- Parameters:
byteSource
- A valid instance of ByteSourceparams
- Optional instructions for special-handling or interpretation of the input data (null objects are permitted and must be supported by implementations).- Returns:
- A valid instance of BufferedImage.
- Throws:
ImageReadException
- In the event that the specified content does not conform to the format of the specific parser implementation.java.io.IOException
- In the event of unsuccessful read or access operation.
-
randomName
private java.lang.String randomName()
-
pixelsForIndex
private java.lang.String pixelsForIndex(int index, int charsPerPixel)
-
toColor
private java.lang.String toColor(int color)
-
writeImage
public void writeImage(java.awt.image.BufferedImage src, java.io.OutputStream os, java.util.Map<java.lang.String,java.lang.Object> params) throws ImageWriteException, java.io.IOException
Description copied from class:ImageParser
Writes the content of a BufferedImage to the specified output stream.The params argument provides a mechanism for individual implementations to pass optional information into the parser. Not all formats will support this capability. Currently, some of the parsers do not check for null arguments. So in cases where no optional specifications are supported, application code should pass in an empty instance of an implementation of the map interface (i.e. an empty HashMap).
- Overrides:
writeImage
in classImageParser
- Parameters:
src
- An image giving the source content for outputos
- A valid output stream for storing the formatted imageparams
- A non-null Map implementation supplying optional, format-specific instructions for output (such as selections for data compression, color models, etc.)- Throws:
ImageWriteException
- In the event that the output format cannot handle the input image or invalid params are specified.java.io.IOException
- In the event of an write error from the output stream.
-
-