javax.imageio

Interface ImageTranscoder

  • All Known Implementing Classes:
    ImageWriter

    public interface ImageTranscoder
    An interface providing metadata transcoding capability.

    Any image may be transcoded (written to a different format than the one it was originally stored in) simply by performing a read operation followed by a write operation. However, loss of data may occur in this process due to format differences.

    In general, the best results will be achieved when format-specific metadata objects can be created to encapsulate as much information about the image and its associated metadata as possible, in terms that are understood by the specific ImageWriter used to perform the encoding.

    An ImageTranscoder may be used to convert the IIOMetadata objects supplied by the ImageReader (representing per-stream and per-image metadata) into corresponding objects suitable for encoding by a particular ImageWriter. In the case where the methods of this interface are being called directly on an ImageWriter, the output will be suitable for that writer.

    The internal details of converting an IIOMetadata object into a writer-specific format will vary according to the context of the operation. Typically, an ImageWriter will inspect the incoming object to see if it implements additional interfaces with which the writer is familiar. This might be the case, for example, if the object was obtained by means of a read operation on a reader plug-in written by the same vendor as the writer. In this case, the writer may access the incoming object by means of its plug-in specific interfaces. In this case, the re-encoding may be close to lossless if the image file format is kept constant. If the format is changing, the writer may still attempt to preserve as much information as possible.

    If the incoming object does not implement any additional interfaces known to the writer, the writer has no choice but to access it via the standard IIOMetadata interfaces such as the tree view provided by IIOMetadata.getAsTree. In this case, there is likely to be significant loss of information.

    An independent ImageTranscoder essentially takes on the same role as the writer plug-in in the above examples. It must be familiar with the private interfaces used by both the reader and writer plug-ins, and manually instantiate an object that will be usable by the writer. The resulting metadata objects may be used by the writer directly.

    No independent implementations of ImageTranscoder are provided as part of the standard API. Instead, the intention of this interface is to provide a way for implementations to be created and discovered by applications as the need arises.

    • Method Detail

      • convertStreamMetadata

        IIOMetadata convertStreamMetadata(IIOMetadata inData,
                                        ImageWriteParam param)
        Returns an IIOMetadata object that may be used for encoding and optionally modified using its document interfaces or other interfaces specific to the writer plug-in that will be used for encoding.

        An optional ImageWriteParam may be supplied for cases where it may affect the structure of the stream metadata.

        If the supplied ImageWriteParam contains optional setting values not understood by this writer or transcoder, they will be ignored.

        Parameters:
        inData - an IIOMetadata object representing stream metadata, used to initialize the state of the returned object.
        param - an ImageWriteParam that will be used to encode the image, or null.
        Returns:
        an IIOMetadata object, or null if the plug-in does not provide metadata encoding capabilities.
        Throws:
        IllegalArgumentException - if inData is null.
      • convertImageMetadata

        IIOMetadata convertImageMetadata(IIOMetadata inData,
                                       ImageTypeSpecifier imageType,
                                       ImageWriteParam param)
        Returns an IIOMetadata object that may be used for encoding and optionally modified using its document interfaces or other interfaces specific to the writer plug-in that will be used for encoding.

        An optional ImageWriteParam may be supplied for cases where it may affect the structure of the image metadata.

        If the supplied ImageWriteParam contains optional setting values not understood by this writer or transcoder, they will be ignored.

        Parameters:
        inData - an IIOMetadata object representing image metadata, used to initialize the state of the returned object.
        imageType - an ImageTypeSpecifier indicating the layout and color information of the image with which the metadata will be associated.
        param - an ImageWriteParam that will be used to encode the image, or null.
        Returns:
        an IIOMetadata object, or null if the plug-in does not provide metadata encoding capabilities.
        Throws:
        IllegalArgumentException - if either of inData or imageType is null.

Traduction non disponible

Les API Java ne sont pas encore traduites en français sur l'infobrol. Seule la version anglaise est disponible pour l'instant.

Version en cache

18/01/2025 07:01:42 Cette version de la page est en cache (à la date du 18/01/2025 07:01:42) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.

Document créé le 30/08/2006, dernière modification le 04/03/2020
Source du document imprimé : https://www.gaudry.be/java-api-rf-javax/imageio/imagetranscoder.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Références

  1. Consulter le document html Langue du document :fr Manuel PHP : https://docs.oracle.com, ImageTranscoder

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.

Table des matières Haut