2008-10-21 14:00:00 +00:00
|
|
|
/*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright ownership.
|
|
|
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
|
|
* (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @author Rustem V. Rafikov
|
|
|
|
* @version $Revision: 1.3 $
|
|
|
|
*/
|
2008-12-18 02:05:43 +00:00
|
|
|
|
2008-10-21 14:00:00 +00:00
|
|
|
package javax.imageio.spi;
|
|
|
|
|
|
|
|
import org.apache.harmony.x.imageio.metadata.IIOMetadataUtils;
|
|
|
|
|
|
|
|
import javax.imageio.metadata.IIOMetadataFormat;
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* The ImageReaderWriterSpi class is a superclass for the ImageReaderSpi and
|
|
|
|
* ImageWriterSpi SPIs.
|
|
|
|
*
|
|
|
|
* @since Android 1.0
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
2008-12-18 02:05:43 +00:00
|
|
|
public abstract class ImageReaderWriterSpi extends IIOServiceProvider implements
|
|
|
|
RegisterableService {
|
2008-10-21 14:00:00 +00:00
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
/**
|
|
|
|
* The names.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] names;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The suffixes.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] suffixes;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The MIME types.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] MIMETypes;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The plug-in class name.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String pluginClassName;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the reader/writer supports standard stream metadata format.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected boolean supportsStandardStreamMetadataFormat;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The native stream metadata format name.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String nativeStreamMetadataFormatName;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The native stream metadata format class name.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String nativeStreamMetadataFormatClassName;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The extra stream metadata format names.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] extraStreamMetadataFormatNames;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The extra stream metadata format class names.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] extraStreamMetadataFormatClassNames;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the reader/writer supports standard image metadata format.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected boolean supportsStandardImageMetadataFormat;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The native image metadata format name.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String nativeImageMetadataFormatName;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The native image metadata format class name.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String nativeImageMetadataFormatClassName;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The extra image metadata format names.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] extraImageMetadataFormatNames;
|
2008-12-18 02:05:43 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The extra image metadata format class names.
|
|
|
|
*/
|
2008-10-21 14:00:00 +00:00
|
|
|
protected String[] extraImageMetadataFormatClassNames;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instantiates a new ImageReaderWriterSpi.
|
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @param vendorName
|
|
|
|
* the vendor name.
|
|
|
|
* @param version
|
|
|
|
* the version.
|
|
|
|
* @param names
|
|
|
|
* the format names.
|
|
|
|
* @param suffixes
|
|
|
|
* the array of strings representing the file suffixes.
|
|
|
|
* @param MIMETypes
|
|
|
|
* the an array of strings representing MIME types.
|
|
|
|
* @param pluginClassName
|
|
|
|
* the plug-in class name.
|
|
|
|
* @param supportsStandardStreamMetadataFormat
|
|
|
|
* the value indicating if stream metadata can be described by
|
|
|
|
* standard metadata format.
|
|
|
|
* @param nativeStreamMetadataFormatName
|
|
|
|
* the native stream metadata format name, returned by
|
|
|
|
* getNativeStreamMetadataFormatName.
|
|
|
|
* @param nativeStreamMetadataFormatClassName
|
|
|
|
* the native stream metadata format class name, returned by
|
|
|
|
* getNativeStreamMetadataFormat.
|
|
|
|
* @param extraStreamMetadataFormatNames
|
|
|
|
* the extra stream metadata format names, returned by
|
|
|
|
* getExtraStreamMetadataFormatNames.
|
|
|
|
* @param extraStreamMetadataFormatClassNames
|
|
|
|
* the extra stream metadata format class names, returned by
|
|
|
|
* getStreamMetadataFormat.
|
|
|
|
* @param supportsStandardImageMetadataFormat
|
|
|
|
* the value indicating if image metadata can be described by
|
|
|
|
* standard metadata format.
|
|
|
|
* @param nativeImageMetadataFormatName
|
|
|
|
* the native image metadata format name, returned by
|
|
|
|
* getNativeImageMetadataFormatName.
|
|
|
|
* @param nativeImageMetadataFormatClassName
|
|
|
|
* the native image metadata format class name, returned by
|
|
|
|
* getNativeImageMetadataFormat.
|
|
|
|
* @param extraImageMetadataFormatNames
|
|
|
|
* the extra image metadata format names, returned by
|
|
|
|
* getExtraImageMetadataFormatNames.
|
|
|
|
* @param extraImageMetadataFormatClassNames
|
|
|
|
* the extra image metadata format class names, returned by
|
|
|
|
* getImageMetadataFormat.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public ImageReaderWriterSpi(String vendorName, String version, String[] names,
|
2008-12-18 02:05:43 +00:00
|
|
|
String[] suffixes, String[] MIMETypes, String pluginClassName,
|
|
|
|
boolean supportsStandardStreamMetadataFormat, String nativeStreamMetadataFormatName,
|
|
|
|
String nativeStreamMetadataFormatClassName, String[] extraStreamMetadataFormatNames,
|
|
|
|
String[] extraStreamMetadataFormatClassNames,
|
|
|
|
boolean supportsStandardImageMetadataFormat, String nativeImageMetadataFormatName,
|
|
|
|
String nativeImageMetadataFormatClassName, String[] extraImageMetadataFormatNames,
|
|
|
|
String[] extraImageMetadataFormatClassNames) {
|
2008-10-21 14:00:00 +00:00
|
|
|
super(vendorName, version);
|
|
|
|
|
|
|
|
if (names == null || names.length == 0) {
|
|
|
|
throw new NullPointerException("format names array cannot be NULL or empty");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pluginClassName == null) {
|
|
|
|
throw new NullPointerException("Plugin class name cannot be NULL");
|
|
|
|
}
|
|
|
|
|
|
|
|
// We clone all the arrays to be consistent with the fact that
|
|
|
|
// some methods of this class must return clones of the arrays
|
|
|
|
// as it is stated in the spec.
|
|
|
|
this.names = names.clone();
|
|
|
|
this.suffixes = suffixes == null ? null : suffixes.clone();
|
|
|
|
this.MIMETypes = MIMETypes == null ? null : MIMETypes.clone();
|
|
|
|
this.pluginClassName = pluginClassName;
|
|
|
|
this.supportsStandardStreamMetadataFormat = supportsStandardStreamMetadataFormat;
|
|
|
|
this.nativeStreamMetadataFormatName = nativeStreamMetadataFormatName;
|
|
|
|
this.nativeStreamMetadataFormatClassName = nativeStreamMetadataFormatClassName;
|
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
this.extraStreamMetadataFormatNames = extraStreamMetadataFormatNames == null ? null
|
|
|
|
: extraStreamMetadataFormatNames.clone();
|
2008-10-21 14:00:00 +00:00
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
this.extraStreamMetadataFormatClassNames = extraStreamMetadataFormatClassNames == null ? null
|
|
|
|
: extraStreamMetadataFormatClassNames.clone();
|
2008-10-21 14:00:00 +00:00
|
|
|
|
|
|
|
this.supportsStandardImageMetadataFormat = supportsStandardImageMetadataFormat;
|
|
|
|
this.nativeImageMetadataFormatName = nativeImageMetadataFormatName;
|
|
|
|
this.nativeImageMetadataFormatClassName = nativeImageMetadataFormatClassName;
|
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
this.extraImageMetadataFormatNames = extraImageMetadataFormatNames == null ? null
|
|
|
|
: extraImageMetadataFormatNames.clone();
|
2008-10-21 14:00:00 +00:00
|
|
|
|
2008-12-18 02:05:43 +00:00
|
|
|
this.extraImageMetadataFormatClassNames = extraImageMetadataFormatClassNames == null ? null
|
|
|
|
: extraImageMetadataFormatClassNames.clone();
|
2008-10-21 14:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instantiates a new ImageReaderWriterSpi.
|
|
|
|
*/
|
2008-12-18 02:05:43 +00:00
|
|
|
public ImageReaderWriterSpi() {
|
|
|
|
}
|
2008-10-21 14:00:00 +00:00
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an array of strings representing names of the formats that can be
|
|
|
|
* used by the ImageReader or ImageWriter implementation associated with
|
|
|
|
* this service provider.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return the array of supported format names.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public String[] getFormatNames() {
|
|
|
|
return names.clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an array of strings representing file suffixes associated with the
|
|
|
|
* formats that can be used by the ImageReader or ImageWriter implementation
|
|
|
|
* of this service provider.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return the array of file suffixes.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public String[] getFileSuffixes() {
|
|
|
|
return suffixes == null ? null : suffixes.clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an array of strings with the names of additional formats of the
|
|
|
|
* image metadata objects produced or consumed by this plug-in.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
|
|
|
* @return the array of extra image metadata format names.
|
|
|
|
*/
|
|
|
|
public String[] getExtraImageMetadataFormatNames() {
|
|
|
|
return extraImageMetadataFormatNames == null ? null : extraImageMetadataFormatNames.clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an array of strings with the names of additional formats of the
|
|
|
|
* stream metadata objects produced or consumed by this plug-in.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
|
|
|
* @return the array of extra stream metadata format names.
|
|
|
|
*/
|
|
|
|
public String[] getExtraStreamMetadataFormatNames() {
|
2008-12-18 02:05:43 +00:00
|
|
|
return extraStreamMetadataFormatNames == null ? null : extraStreamMetadataFormatNames
|
|
|
|
.clone();
|
2008-10-21 14:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an IIOMetadataFormat object for the specified image metadata format
|
|
|
|
* name.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @param formatName
|
|
|
|
* the format name.
|
2008-10-21 14:00:00 +00:00
|
|
|
* @return the IIOMetadataFormat, or null.
|
|
|
|
*/
|
|
|
|
public IIOMetadataFormat getImageMetadataFormat(String formatName) {
|
2008-12-18 02:05:43 +00:00
|
|
|
return IIOMetadataUtils.instantiateMetadataFormat(formatName,
|
|
|
|
supportsStandardImageMetadataFormat, nativeImageMetadataFormatName,
|
|
|
|
nativeImageMetadataFormatClassName, extraImageMetadataFormatNames,
|
|
|
|
extraImageMetadataFormatClassNames);
|
2008-10-21 14:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an IIOMetadataFormat object for the specified stream metadata format
|
|
|
|
* name.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @param formatName
|
|
|
|
* the format name.
|
2008-10-21 14:00:00 +00:00
|
|
|
* @return the IIOMetadataFormat, or null.
|
|
|
|
*/
|
|
|
|
public IIOMetadataFormat getStreamMetadataFormat(String formatName) {
|
2008-12-18 02:05:43 +00:00
|
|
|
return IIOMetadataUtils.instantiateMetadataFormat(formatName,
|
|
|
|
supportsStandardStreamMetadataFormat, nativeStreamMetadataFormatName,
|
|
|
|
nativeStreamMetadataFormatClassName, extraStreamMetadataFormatNames,
|
|
|
|
extraStreamMetadataFormatClassNames);
|
2008-10-21 14:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets an array of strings representing the MIME types of the formats that
|
|
|
|
* are supported by the ImageReader or ImageWriter implementation of this
|
2008-10-21 14:00:00 +00:00
|
|
|
* service provider.
|
|
|
|
*
|
|
|
|
* @return the array MIME types.
|
|
|
|
*/
|
|
|
|
public String[] getMIMETypes() {
|
|
|
|
return MIMETypes == null ? null : MIMETypes.clone();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets the name of the native image metadata format for this reader/writer,
|
|
|
|
* which allows for lossless encoding or decoding of the image metadata with
|
|
|
|
* the format.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return the string with native image metadata format name, or null.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public String getNativeImageMetadataFormatName() {
|
|
|
|
return nativeImageMetadataFormatName;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets the name of the native stream metadata format for this
|
|
|
|
* reader/writer, which allows for lossless encoding or decoding of the
|
|
|
|
* stream metadata with the format.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return the string with native stream metadata format name, or null.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public String getNativeStreamMetadataFormatName() {
|
|
|
|
return nativeStreamMetadataFormatName;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Gets the class name of the ImageReader or ImageWriter associated with
|
|
|
|
* this service provider.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
|
|
|
* @return the class name.
|
|
|
|
*/
|
|
|
|
public String getPluginClassName() {
|
|
|
|
return pluginClassName;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Checks if the standard metadata format is supported by the getAsTree and
|
|
|
|
* setFromTree methods for the image metadata objects produced or consumed
|
|
|
|
* by this reader or writer.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return true, if standard image metadata format is supported, false
|
|
|
|
* otherwise.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public boolean isStandardImageMetadataFormatSupported() {
|
|
|
|
return supportsStandardImageMetadataFormat;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-12-18 02:05:43 +00:00
|
|
|
* Checks if the standard metadata format is supported by the getAsTree and
|
|
|
|
* setFromTree methods for the stream metadata objects produced or consumed
|
|
|
|
* by this reader or writer.
|
2008-10-21 14:00:00 +00:00
|
|
|
*
|
2008-12-18 02:05:43 +00:00
|
|
|
* @return true, if standard stream metadata format is supported, false
|
|
|
|
* otherwise.
|
2008-10-21 14:00:00 +00:00
|
|
|
*/
|
|
|
|
public boolean isStandardStreamMetadataFormatSupported() {
|
|
|
|
return supportsStandardStreamMetadataFormat;
|
|
|
|
}
|
|
|
|
}
|