web-dev-qa-db-ja.com

Java)を使用してjpegEXIFデータを編集する

コメント、タイトル、撮影日、カメラメーカーなどのjpgファイルのプロパティを編集したい。

enter image description here

これらのデータを読み取るためのライブラリを見つけました。しかし、editの例を含むfreeライブラリが必要です。

私はApacheのイメージング(sanselan)を知っています。しかし、それでデータを編集することはできませんでした。以前に自分で使用したことがある場合は、Webサイトにあるもの以外のサンプルコードを提供した場合にのみ、回答として受け入れます。彼らの例を使っても、GPSデータ以外のプロパティを編集できなかったからです。コードを実行した後も、file-properties-detailsの値は同じです。

ありがとう!

注:JHeader( https://sourceforge.net/projects/jheader/ )も試しましたが、-clオプションを指定したプロセスとして使用しても、プロパティリストは変更されませんでした。

6
Null Pointer

Apache commonsImagingは私のために機能します。

提供されたサンプルを拡張しました ここ

だから明らかに私のクライアントコードはこのように見えます

public static void main(String[] args) throws ImageWriteException, ImageReadException, IOException {
    new WriteExifMetadataExample().changeExifMetadata(new File("somefilename.jpg"), new File("result_file.jpg"));
}

およびWriteExifMetadataExampleの拡張メソッド

public void changeExifMetadata(final File jpegImageFile, final File dst)
        throws IOException, ImageReadException, ImageWriteException {
    OutputStream os = null;
    boolean canThrow = false;
    try {
        TiffOutputSet outputSet = null;

        // note that metadata might be null if no metadata is found.
        final ImageMetadata metadata = Imaging.getMetadata(jpegImageFile);
        final JpegImageMetadata jpegMetadata = (JpegImageMetadata) metadata;
        if (null != jpegMetadata) {
            // note that exif might be null if no Exif metadata is found.
            final TiffImageMetadata exif = jpegMetadata.getExif();

            if (null != exif) {
                // TiffImageMetadata class is immutable (read-only).
                // TiffOutputSet class represents the Exif data to write.
                //
                // Usually, we want to update existing Exif metadata by
                // changing
                // the values of a few fields, or adding a field.
                // In these cases, it is easiest to use getOutputSet() to
                // start with a "copy" of the fields read from the image.
                outputSet = exif.getOutputSet();
            }
        }

        // if file does not contain any exif metadata, we create an empty
        // set of exif metadata. Otherwise, we keep all of the other
        // existing tags.
        if (null == outputSet) {
            outputSet = new TiffOutputSet();
        }

        {
            // Example of how to add a field/tag to the output set.
            //
            // Note that you should first remove the field/tag if it already
            // exists in this directory, or you may end up with duplicate
            // tags. See above.
            //
            // Certain fields/tags are expected in certain Exif directories;
            // Others can occur in more than one directory (and often have a
            // different meaning in different directories).
            //
            // TagInfo constants often contain a description of what
            // directories are associated with a given tag.
            //
            final TiffOutputDirectory exifDirectory = outputSet
                    .getOrCreateExifDirectory();
            // make sure to remove old value if present (this method will
            // not fail if the tag does not exist).
            exifDirectory
                    .removeField(ExifTagConstants.EXIF_TAG_APERTURE_VALUE);
            exifDirectory.add(ExifTagConstants.EXIF_TAG_APERTURE_VALUE,
                    new RationalNumber(3, 10));
        }

        {
            // Example of how to add/update GPS info to output set.

            // New York City
            final double longitude = -74.0; // 74 degrees W (in Degrees East)
            final double latitude = 40 + 43 / 60.0; // 40 degrees N (in Degrees
            // North)

            outputSet.setGPSInDegrees(longitude, latitude);
        }



        final TiffOutputDirectory exifDirectory = outputSet
                .getOrCreateRootDirectory();
        exifDirectory
                .removeField(ExifTagConstants.EXIF_TAG_SOFTWARE);
        exifDirectory.add(ExifTagConstants.EXIF_TAG_SOFTWARE,
                "SomeKind");

        os = new FileOutputStream(dst);
        os = new BufferedOutputStream(os);

        new ExifRewriter().updateExifMetadataLossless(jpegImageFile, os,
                outputSet);

        canThrow = true;
    } finally {
        IoUtils.closeQuietly(canThrow, os);
    }
}

タグを追加する行にのみ注意してください

final TiffOutputDirectory exifDirectory = outputSet
                .getOrCreateRootDirectory();
        exifDirectory
                .removeField(ExifTagConstants.EXIF_TAG_SOFTWARE);
        exifDirectory.add(ExifTagConstants.EXIF_TAG_SOFTWARE,
                "SomeKind");

その結果、EXIFタグが適切に追加されました

enter image description here


コメントタグを変更するには、次のようにします

        final TiffOutputDirectory exifDirectory = outputSet.getOrCreateRootDirectory();
        exifDirectory.removeField(MicrosoftTagConstants.EXIF_TAG_XPCOMMENT);
        exifDirectory.add(MicrosoftTagConstants.EXIF_TAG_XPCOMMENT, "SomeKind");

使用可能な定数の完全なリストは、パッケージに含まれています。

org.Apache.commons.imaging.formats.tiff.constants

enter image description here

10
yurko

これはあなたのために働きますか? のような例でしょうか

Org.Apache.commons.imaging.util.IoUtilsのようなパッケージを使用し、org.Apache.commons.imaging.Imagingをインポートすると、ここで非常に役立つと思います。

2
John Oss

コメントタグを変更するには、次のようにします

        final TiffOutputDirectory exifDirectory = outputSet.getOrCreateRootDirectory();
        exifDirectory.removeField(MicrosoftTagConstants.EXIF_TAG_XPCOMMENT);
        exifDirectory.add(MicrosoftTagConstants.EXIF_TAG_XPCOMMENT, "SomeKind");

使用可能な定数の完全なリストは、パッケージに含まれています。

org.Apache.commons.imaging.formats.tiff.constants

enter image description here

2
yurko