| Index: core/src/fxcodec/codec/fx_codec_tiff.cpp
|
| diff --git a/core/src/fxcodec/codec/fx_codec_tiff.cpp b/core/src/fxcodec/codec/fx_codec_tiff.cpp
|
| index 1f289bbb402dbea19cd644ac173c87bf79237e63..1efd2fbf70faf1ad52b90943c175d0d5397fc321 100644
|
| --- a/core/src/fxcodec/codec/fx_codec_tiff.cpp
|
| +++ b/core/src/fxcodec/codec/fx_codec_tiff.cpp
|
| @@ -256,42 +256,36 @@ void CCodec_TiffContext::GetFrames(int32_t& frames) {
|
| } \
|
| } \
|
| (key) = NULL;
|
| +
|
| +namespace {
|
| +
|
| template <class T>
|
| -static FX_BOOL Tiff_Exif_GetInfo(TIFF* tif_ctx,
|
| - ttag_t tag,
|
| - CFX_DIBAttributeExif* pExif) {
|
| - uint8_t* key = NULL;
|
| - T val = (T)0;
|
| +FX_BOOL Tiff_Exif_GetInfo(TIFF* tif_ctx, ttag_t tag, CFX_DIBAttribute* pAttr) {
|
| + T val = 0;
|
| TIFFGetField(tif_ctx, tag, &val);
|
| - if (val) {
|
| - (key) = FX_Alloc(uint8_t, sizeof(T));
|
| - if ((key) == NULL) {
|
| - return FALSE;
|
| - }
|
| - T* ptr = (T*)(key);
|
| - *ptr = val;
|
| - pExif->m_TagVal.SetAt(tag, (key));
|
| - return TRUE;
|
| - }
|
| - return FALSE;
|
| + if (!val)
|
| + return FALSE;
|
| + T* ptr = FX_Alloc(T, 1);
|
| + *ptr = val;
|
| + pAttr->m_Exif[tag] = (void*)ptr;
|
| + return TRUE;
|
| }
|
| -static void Tiff_Exif_GetStringInfo(TIFF* tif_ctx,
|
| - ttag_t tag,
|
| - CFX_DIBAttributeExif* pExif) {
|
| - FX_CHAR* buf = NULL;
|
| - uint8_t* key = NULL;
|
| +void Tiff_Exif_GetStringInfo(TIFF* tif_ctx,
|
| + ttag_t tag,
|
| + CFX_DIBAttribute* pAttr) {
|
| + FX_CHAR* buf = nullptr;
|
| TIFFGetField(tif_ctx, tag, &buf);
|
| - if (buf) {
|
| - int32_t size = (int32_t)FXSYS_strlen(buf);
|
| - (key) = FX_Alloc(uint8_t, size + 1);
|
| - if ((key) == NULL) {
|
| - return;
|
| - }
|
| - FXSYS_memcpy((key), buf, size);
|
| - key[size] = 0;
|
| - pExif->m_TagVal.SetAt(tag, (key));
|
| - }
|
| + if (!buf)
|
| + return;
|
| + FX_STRSIZE size = FXSYS_strlen(buf);
|
| + uint8_t* ptr = FX_Alloc(uint8_t, size + 1);
|
| + FXSYS_memcpy(ptr, buf, size);
|
| + ptr[size] = 0;
|
| + pAttr->m_Exif[tag] = ptr;
|
| }
|
| +
|
| +} // namespace
|
| +
|
| FX_BOOL CCodec_TiffContext::LoadFrameInfo(int32_t frame,
|
| FX_DWORD& width,
|
| FX_DWORD& height,
|
| @@ -322,22 +316,20 @@ FX_BOOL CCodec_TiffContext::LoadFrameInfo(int32_t frame,
|
| &pAttribute->m_wDPIUnit)) {
|
| pAttribute->m_wDPIUnit -= 1;
|
| }
|
| - CFX_DIBAttributeExif* pExif = (CFX_DIBAttributeExif*)pAttribute->m_pExif;
|
| - pExif->clear();
|
| - Tiff_Exif_GetInfo<FX_WORD>(tif_ctx, TIFFTAG_ORIENTATION, pExif);
|
| - if (Tiff_Exif_GetInfo<FX_FLOAT>(tif_ctx, TIFFTAG_XRESOLUTION, pExif)) {
|
| - FX_FLOAT fDpi = 0;
|
| - pExif->GetInfo(TIFFTAG_XRESOLUTION, &fDpi);
|
| + Tiff_Exif_GetInfo<FX_WORD>(tif_ctx, TIFFTAG_ORIENTATION, pAttribute);
|
| + if (Tiff_Exif_GetInfo<FX_FLOAT>(tif_ctx, TIFFTAG_XRESOLUTION, pAttribute)) {
|
| + void* val = pAttribute->m_Exif[TIFFTAG_XRESOLUTION];
|
| + FX_FLOAT fDpi = val ? *reinterpret_cast<FX_FLOAT*>(val) : 0;
|
| pAttribute->m_nXDPI = (int32_t)(fDpi + 0.5f);
|
| }
|
| - if (Tiff_Exif_GetInfo<FX_FLOAT>(tif_ctx, TIFFTAG_YRESOLUTION, pExif)) {
|
| - FX_FLOAT fDpi = 0;
|
| - pExif->GetInfo(TIFFTAG_YRESOLUTION, &fDpi);
|
| + if (Tiff_Exif_GetInfo<FX_FLOAT>(tif_ctx, TIFFTAG_YRESOLUTION, pAttribute)) {
|
| + void* val = pAttribute->m_Exif[TIFFTAG_YRESOLUTION];
|
| + FX_FLOAT fDpi = val ? *reinterpret_cast<FX_FLOAT*>(val) : 0;
|
| pAttribute->m_nYDPI = (int32_t)(fDpi + 0.5f);
|
| }
|
| - Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_IMAGEDESCRIPTION, pExif);
|
| - Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_MAKE, pExif);
|
| - Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_MODEL, pExif);
|
| + Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_IMAGEDESCRIPTION, pAttribute);
|
| + Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_MAKE, pAttribute);
|
| + Tiff_Exif_GetStringInfo(tif_ctx, TIFFTAG_MODEL, pAttribute);
|
| }
|
| bpc = tif_bpc;
|
| if (tif_rps > height) {
|
| @@ -346,9 +338,8 @@ FX_BOOL CCodec_TiffContext::LoadFrameInfo(int32_t frame,
|
| return TRUE;
|
| }
|
| void _TiffBGRA2RGBA(uint8_t* pBuf, int32_t pixel, int32_t spp) {
|
| - register uint8_t tmp;
|
| for (int32_t n = 0; n < pixel; n++) {
|
| - tmp = pBuf[0];
|
| + uint8_t tmp = pBuf[0];
|
| pBuf[0] = pBuf[2];
|
| pBuf[2] = tmp;
|
| pBuf += spp;
|
|
|