mirror of
https://github.com/webmproject/libwebp.git
synced 2025-01-15 17:18:23 +01:00
Merge "cwebp/tiffdec: add TIFF metadata extraction"
This commit is contained in:
commit
7c8111e4a8
@ -334,7 +334,7 @@ static int ReadPicture(const char* const filename, WebPPicture* const pic,
|
|||||||
} else if (format == JPEG_) {
|
} else if (format == JPEG_) {
|
||||||
ok = ReadJPEG(in_file, pic, metadata);
|
ok = ReadJPEG(in_file, pic, metadata);
|
||||||
} else if (format == TIFF_) {
|
} else if (format == TIFF_) {
|
||||||
ok = ReadTIFF(filename, pic, keep_alpha);
|
ok = ReadTIFF(filename, pic, keep_alpha, metadata);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// If image size is specified, infer it as YUV format.
|
// If image size is specified, infer it as YUV format.
|
||||||
|
@ -19,9 +19,51 @@
|
|||||||
#include <tiffio.h>
|
#include <tiffio.h>
|
||||||
|
|
||||||
#include "webp/encode.h"
|
#include "webp/encode.h"
|
||||||
|
#include "./metadata.h"
|
||||||
|
|
||||||
|
static const struct {
|
||||||
|
ttag_t tag;
|
||||||
|
size_t storage_offset;
|
||||||
|
} kTIFFMetadataMap[] = {
|
||||||
|
{ TIFFTAG_ICCPROFILE, METADATA_OFFSET(iccp) },
|
||||||
|
{ TIFFTAG_XMLPACKET, METADATA_OFFSET(xmp) },
|
||||||
|
{ 0, 0 },
|
||||||
|
};
|
||||||
|
|
||||||
|
// Returns true on success. The caller must use MetadataFree() on 'metadata' in
|
||||||
|
// all cases.
|
||||||
|
static int ExtractMetadataFromTIFF(TIFF* const tif, Metadata* const metadata) {
|
||||||
|
int i;
|
||||||
|
uint32 exif_ifd_offset;
|
||||||
|
|
||||||
|
for (i = 0; kTIFFMetadataMap[i].tag != 0; ++i) {
|
||||||
|
MetadataPayload* const payload =
|
||||||
|
(MetadataPayload*)((uint8_t*)metadata +
|
||||||
|
kTIFFMetadataMap[i].storage_offset);
|
||||||
|
void* tag_data;
|
||||||
|
uint32 tag_data_len;
|
||||||
|
|
||||||
|
if (TIFFGetField(tif, kTIFFMetadataMap[i].tag, &tag_data_len, &tag_data) &&
|
||||||
|
!MetadataCopy((const char*)tag_data, tag_data_len, payload)) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO(jzern): To extract the raw EXIF directory some parsing of it would be
|
||||||
|
// necessary to determine the overall size. In addition, value offsets in
|
||||||
|
// individual directory entries may need to be updated as, depending on the
|
||||||
|
// type, they are file based.
|
||||||
|
// Exif 2.2 Section 4.6.2 Tag Structure
|
||||||
|
// TIFF Revision 6.0 Part 1 Section 2 TIFF Structure #Image File Directory
|
||||||
|
if (TIFFGetField(tif, TIFFTAG_EXIFIFD, &exif_ifd_offset)) {
|
||||||
|
fprintf(stderr, "Warning: EXIF extraction from TIFF is unsupported.\n");
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
int ReadTIFF(const char* const filename,
|
int ReadTIFF(const char* const filename,
|
||||||
WebPPicture* const pic, int keep_alpha) {
|
WebPPicture* const pic, int keep_alpha,
|
||||||
|
Metadata* const metadata) {
|
||||||
TIFF* const tif = TIFFOpen(filename, "r");
|
TIFF* const tif = TIFFOpen(filename, "r");
|
||||||
uint32 width, height;
|
uint32 width, height;
|
||||||
uint32* raster;
|
uint32* raster;
|
||||||
@ -65,8 +107,18 @@ int ReadTIFF(const char* const filename,
|
|||||||
fprintf(stderr, "Error allocating TIFF RGBA memory!\n");
|
fprintf(stderr, "Error allocating TIFF RGBA memory!\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ok && keep_alpha == 2) {
|
if (ok) {
|
||||||
WebPCleanupTransparentArea(pic);
|
if (keep_alpha == 2) {
|
||||||
|
WebPCleanupTransparentArea(pic);
|
||||||
|
}
|
||||||
|
if (metadata != NULL) {
|
||||||
|
ok = ExtractMetadataFromTIFF(tif, metadata);
|
||||||
|
if (!ok) {
|
||||||
|
fprintf(stderr, "Error extracting TIFF metadata!\n");
|
||||||
|
MetadataFree(metadata);
|
||||||
|
WebPPictureFree(pic);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TIFFClose(tif);
|
TIFFClose(tif);
|
||||||
@ -74,10 +126,12 @@ int ReadTIFF(const char* const filename,
|
|||||||
}
|
}
|
||||||
#else // !WEBP_HAVE_TIFF
|
#else // !WEBP_HAVE_TIFF
|
||||||
int ReadTIFF(const char* const filename,
|
int ReadTIFF(const char* const filename,
|
||||||
struct WebPPicture* const pic, int keep_alpha) {
|
struct WebPPicture* const pic, int keep_alpha,
|
||||||
|
struct Metadata* const metadata) {
|
||||||
(void)filename;
|
(void)filename;
|
||||||
(void)pic;
|
(void)pic;
|
||||||
(void)keep_alpha;
|
(void)keep_alpha;
|
||||||
|
(void)metadata;
|
||||||
fprintf(stderr, "TIFF support not compiled. Please install the libtiff "
|
fprintf(stderr, "TIFF support not compiled. Please install the libtiff "
|
||||||
"development package before building.\n");
|
"development package before building.\n");
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
struct Metadata;
|
||||||
struct WebPPicture;
|
struct WebPPicture;
|
||||||
|
|
||||||
// Reads a TIFF from 'filename', returning the decoded output in 'pic'.
|
// Reads a TIFF from 'filename', returning the decoded output in 'pic'.
|
||||||
@ -21,7 +22,8 @@ struct WebPPicture;
|
|||||||
// otherwise it will be RGB.
|
// otherwise it will be RGB.
|
||||||
// Returns true on success.
|
// Returns true on success.
|
||||||
int ReadTIFF(const char* const filename,
|
int ReadTIFF(const char* const filename,
|
||||||
struct WebPPicture* const pic, int keep_alpha);
|
struct WebPPicture* const pic, int keep_alpha,
|
||||||
|
struct Metadata* const metadata);
|
||||||
|
|
||||||
#if defined(__cplusplus) || defined(c_plusplus)
|
#if defined(__cplusplus) || defined(c_plusplus)
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
Loading…
Reference in New Issue
Block a user