| Index: core/src/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| diff --git a/core/src/fxcodec/codec/fx_codec_jpx_opj.cpp b/core/src/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| index 8e77cdaecef7e5fdd98d11f90ab0de0bbe01cb41..4494244410854eb4f86c30fc547747d932191ce4 100644
|
| --- a/core/src/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| +++ b/core/src/fxcodec/codec/fx_codec_jpx_opj.cpp
|
| @@ -582,83 +582,79 @@ CJPX_Decoder::~CJPX_Decoder()
|
| FX_BOOL CJPX_Decoder::Init(const unsigned char* src_data, int src_size)
|
| {
|
| opj_dparameters_t parameters;
|
| - try {
|
| + image = NULL;
|
| + m_SrcData = src_data;
|
| + m_SrcSize = src_size;
|
| + decodeData srcData;
|
| + srcData.offset = 0;
|
| + srcData.src_size = src_size;
|
| + srcData.src_data = src_data;
|
| + l_stream = fx_opj_stream_create_memory_stream(&srcData, OPJ_J2K_STREAM_CHUNK_SIZE, 1);
|
| + if (l_stream == NULL) {
|
| + return FALSE;
|
| + }
|
| + opj_set_default_decoder_parameters(¶meters);
|
| + parameters.decod_format = 0;
|
| + parameters.cod_format = 3;
|
| + if(FXSYS_memcmp32(m_SrcData, "\x00\x00\x00\x0c\x6a\x50\x20\x20\x0d\x0a\x87\x0a", 12) == 0) {
|
| + l_codec = opj_create_decompress(OPJ_CODEC_JP2);
|
| + parameters.decod_format = 1;
|
| + } else {
|
| + l_codec = opj_create_decompress(OPJ_CODEC_J2K);
|
| + }
|
| + if(!l_codec) {
|
| + return FALSE;
|
| + }
|
| + opj_set_info_handler(l_codec, fx_info_callback, 00);
|
| + opj_set_warning_handler(l_codec, fx_warning_callback, 00);
|
| + opj_set_error_handler(l_codec, fx_error_callback, 00);
|
| + if ( !opj_setup_decoder(l_codec, ¶meters) ) {
|
| + return FALSE;
|
| + }
|
| + if(! opj_read_header(l_stream, l_codec, &image)) {
|
| image = NULL;
|
| - m_SrcData = src_data;
|
| - m_SrcSize = src_size;
|
| - decodeData srcData;
|
| - srcData.offset = 0;
|
| - srcData.src_size = src_size;
|
| - srcData.src_data = src_data;
|
| - l_stream = fx_opj_stream_create_memory_stream(&srcData, OPJ_J2K_STREAM_CHUNK_SIZE, 1);
|
| - if (l_stream == NULL) {
|
| - return FALSE;
|
| - }
|
| - opj_set_default_decoder_parameters(¶meters);
|
| - parameters.decod_format = 0;
|
| - parameters.cod_format = 3;
|
| - if(FXSYS_memcmp32(m_SrcData, "\x00\x00\x00\x0c\x6a\x50\x20\x20\x0d\x0a\x87\x0a", 12) == 0) {
|
| - l_codec = opj_create_decompress(OPJ_CODEC_JP2);
|
| - parameters.decod_format = 1;
|
| - } else {
|
| - l_codec = opj_create_decompress(OPJ_CODEC_J2K);
|
| - }
|
| - if(!l_codec) {
|
| - return FALSE;
|
| - }
|
| - opj_set_info_handler(l_codec, fx_info_callback, 00);
|
| - opj_set_warning_handler(l_codec, fx_warning_callback, 00);
|
| - opj_set_error_handler(l_codec, fx_error_callback, 00);
|
| - if ( !opj_setup_decoder(l_codec, ¶meters) ) {
|
| + return FALSE;
|
| + }
|
| + if(this->m_useColorSpace) {
|
| + image->useColorSpace = 1;
|
| + } else {
|
| + image->useColorSpace = 0;
|
| + }
|
| + if (!parameters.nb_tile_to_decode) {
|
| + if (!opj_set_decode_area(l_codec, image, parameters.DA_x0,
|
| + parameters.DA_y0, parameters.DA_x1, parameters.DA_y1)) {
|
| + opj_image_destroy(image);
|
| + image = NULL;
|
| return FALSE;
|
| }
|
| - if(! opj_read_header(l_stream, l_codec, &image)) {
|
| + if (!(opj_decode(l_codec, l_stream, image) && opj_end_decompress(l_codec, l_stream))) {
|
| + opj_image_destroy(image);
|
| image = NULL;
|
| return FALSE;
|
| }
|
| - if(this->m_useColorSpace) {
|
| - image->useColorSpace = 1;
|
| - } else {
|
| - image->useColorSpace = 0;
|
| - }
|
| - if (!parameters.nb_tile_to_decode) {
|
| - if (!opj_set_decode_area(l_codec, image, parameters.DA_x0,
|
| - parameters.DA_y0, parameters.DA_x1, parameters.DA_y1)) {
|
| - opj_image_destroy(image);
|
| - image = NULL;
|
| - return FALSE;
|
| - }
|
| - if (!(opj_decode(l_codec, l_stream, image) && opj_end_decompress(l_codec, l_stream))) {
|
| - opj_image_destroy(image);
|
| - image = NULL;
|
| - return FALSE;
|
| - }
|
| - } else {
|
| - if (!opj_get_decoded_tile(l_codec, l_stream, image, parameters.tile_index)) {
|
| - return FALSE;
|
| - }
|
| - }
|
| - opj_stream_destroy(l_stream);
|
| - l_stream = NULL;
|
| - if( image->color_space != OPJ_CLRSPC_SYCC
|
| - && image->numcomps == 3 && image->comps[0].dx == image->comps[0].dy
|
| - && image->comps[1].dx != 1 ) {
|
| - image->color_space = OPJ_CLRSPC_SYCC;
|
| - } else if (image->numcomps <= 2) {
|
| - image->color_space = OPJ_CLRSPC_GRAY;
|
| - }
|
| - if(image->color_space == OPJ_CLRSPC_SYCC) {
|
| - color_sycc_to_rgb(image);
|
| - }
|
| - if(image->icc_profile_buf && !image->useColorSpace) {
|
| - FX_Free(image->icc_profile_buf);
|
| - image->icc_profile_buf = NULL;
|
| - image->icc_profile_len = 0;
|
| - }
|
| - if(!image) {
|
| + } else {
|
| + if (!opj_get_decoded_tile(l_codec, l_stream, image, parameters.tile_index)) {
|
| return FALSE;
|
| }
|
| - } catch (...) {
|
| + }
|
| + opj_stream_destroy(l_stream);
|
| + l_stream = NULL;
|
| + if( image->color_space != OPJ_CLRSPC_SYCC
|
| + && image->numcomps == 3 && image->comps[0].dx == image->comps[0].dy
|
| + && image->comps[1].dx != 1 ) {
|
| + image->color_space = OPJ_CLRSPC_SYCC;
|
| + } else if (image->numcomps <= 2) {
|
| + image->color_space = OPJ_CLRSPC_GRAY;
|
| + }
|
| + if(image->color_space == OPJ_CLRSPC_SYCC) {
|
| + color_sycc_to_rgb(image);
|
| + }
|
| + if(image->icc_profile_buf && !image->useColorSpace) {
|
| + FX_Free(image->icc_profile_buf);
|
| + image->icc_profile_buf = NULL;
|
| + image->icc_profile_len = 0;
|
| + }
|
| + if(!image) {
|
| return FALSE;
|
| }
|
| return TRUE;
|
| @@ -676,86 +672,80 @@ FX_BOOL CJPX_Decoder::Decode(FX_LPBYTE dest_buf, int pitch, FX_BOOL bTranslateCo
|
| int i, wid, hei, row, col, channel, src;
|
| FX_BOOL flag;
|
| FX_LPBYTE pChannel, pScanline, pPixel;
|
| - try {
|
| - if(image->comps[0].w != image->x1 || image->comps[0].h != image->y1) {
|
| - return FALSE;
|
| - }
|
| - if(pitch < (int)(image->comps[0].w * 8 * image->numcomps + 31) >> 5 << 2) {
|
| - return FALSE;
|
| - }
|
| - FXSYS_memset8(dest_buf, 0xff, image->y1 * pitch);
|
| - channel_bufs = FX_Alloc(FX_BYTE*, image->numcomps);
|
| - if (channel_bufs == NULL) {
|
| - return FALSE;
|
| - }
|
| - adjust_comps = FX_Alloc(int, image->numcomps);
|
| - if (adjust_comps == NULL) {
|
| - FX_Free(channel_bufs);
|
| - return FALSE;
|
| - }
|
| - flag = TRUE;
|
| - for (i = 0; i < (int)image->numcomps; i ++) {
|
| - channel_bufs[i] = dest_buf + offsets[i];
|
| - adjust_comps[i] = image->comps[i].prec - 8;
|
| - if(i > 0) {
|
| - if(image->comps[i].dx != image->comps[i - 1].dx
|
| - || image->comps[i].dy != image->comps[i - 1].dy
|
| - || image->comps[i].prec != image->comps[i - 1].prec) {
|
| - flag = FALSE;
|
| - goto failed;
|
| - }
|
| +
|
| + if(image->comps[0].w != image->x1 || image->comps[0].h != image->y1) {
|
| + return FALSE;
|
| + }
|
| + if(pitch < (int)(image->comps[0].w * 8 * image->numcomps + 31) >> 5 << 2) {
|
| + return FALSE;
|
| + }
|
| + FXSYS_memset8(dest_buf, 0xff, image->y1 * pitch);
|
| + channel_bufs = FX_Alloc(FX_BYTE*, image->numcomps);
|
| + if (channel_bufs == NULL) {
|
| + return FALSE;
|
| + }
|
| + adjust_comps = FX_Alloc(int, image->numcomps);
|
| + if (adjust_comps == NULL) {
|
| + FX_Free(channel_bufs);
|
| + return FALSE;
|
| + }
|
| + flag = TRUE;
|
| + for (i = 0; i < (int)image->numcomps; i ++) {
|
| + channel_bufs[i] = dest_buf + offsets[i];
|
| + adjust_comps[i] = image->comps[i].prec - 8;
|
| + if(i > 0) {
|
| + if(image->comps[i].dx != image->comps[i - 1].dx
|
| + || image->comps[i].dy != image->comps[i - 1].dy
|
| + || image->comps[i].prec != image->comps[i - 1].prec) {
|
| + flag = FALSE;
|
| + goto failed;
|
| }
|
| }
|
| - wid = image->comps[0].w;
|
| - hei = image->comps[0].h;
|
| - for (channel = 0; channel < (int)image->numcomps; channel++) {
|
| - pChannel = channel_bufs[channel];
|
| - if(adjust_comps[channel] < 0) {
|
| - for(row = 0; row < hei; row++) {
|
| - pScanline = pChannel + row * pitch;
|
| - for (col = 0; col < wid; col++) {
|
| - pPixel = pScanline + col * image->numcomps;
|
| - src = image->comps[channel].data[row * wid + col];
|
| - src += image->comps[channel].sgnd ? 1 << (image->comps[channel].prec - 1) : 0;
|
| - if (adjust_comps[channel] > 0) {
|
| - *pPixel = 0;
|
| - } else {
|
| - *pPixel = (FX_BYTE)(src << -adjust_comps[channel]);
|
| - }
|
| + }
|
| + wid = image->comps[0].w;
|
| + hei = image->comps[0].h;
|
| + for (channel = 0; channel < (int)image->numcomps; channel++) {
|
| + pChannel = channel_bufs[channel];
|
| + if(adjust_comps[channel] < 0) {
|
| + for(row = 0; row < hei; row++) {
|
| + pScanline = pChannel + row * pitch;
|
| + for (col = 0; col < wid; col++) {
|
| + pPixel = pScanline + col * image->numcomps;
|
| + src = image->comps[channel].data[row * wid + col];
|
| + src += image->comps[channel].sgnd ? 1 << (image->comps[channel].prec - 1) : 0;
|
| + if (adjust_comps[channel] > 0) {
|
| + *pPixel = 0;
|
| + } else {
|
| + *pPixel = (FX_BYTE)(src << -adjust_comps[channel]);
|
| }
|
| }
|
| - } else {
|
| - for(row = 0; row < hei; row++) {
|
| - pScanline = pChannel + row * pitch;
|
| - for (col = 0; col < wid; col++) {
|
| - pPixel = pScanline + col * image->numcomps;
|
| - if (!image->comps[channel].data) {
|
| - continue;
|
| - }
|
| - src = image->comps[channel].data[row * wid + col];
|
| - src += image->comps[channel].sgnd ? 1 << (image->comps[channel].prec - 1) : 0;
|
| - if (adjust_comps[channel] - 1 < 0) {
|
| - *pPixel = (FX_BYTE)((src >> adjust_comps[channel]));
|
| - } else {
|
| - int tmpPixel = (src >> adjust_comps[channel]) + ((src >> (adjust_comps[channel] - 1)) % 2);
|
| - if (tmpPixel > 255) {
|
| - tmpPixel = 255;
|
| - } else if (tmpPixel < 0) {
|
| - tmpPixel = 0;
|
| - }
|
| - *pPixel = (FX_BYTE)tmpPixel;
|
| + }
|
| + } else {
|
| + for(row = 0; row < hei; row++) {
|
| + pScanline = pChannel + row * pitch;
|
| + for (col = 0; col < wid; col++) {
|
| + pPixel = pScanline + col * image->numcomps;
|
| + if (!image->comps[channel].data) {
|
| + continue;
|
| + }
|
| + src = image->comps[channel].data[row * wid + col];
|
| + src += image->comps[channel].sgnd ? 1 << (image->comps[channel].prec - 1) : 0;
|
| + if (adjust_comps[channel] - 1 < 0) {
|
| + *pPixel = (FX_BYTE)((src >> adjust_comps[channel]));
|
| + } else {
|
| + int tmpPixel = (src >> adjust_comps[channel]) + ((src >> (adjust_comps[channel] - 1)) % 2);
|
| + if (tmpPixel > 255) {
|
| + tmpPixel = 255;
|
| + } else if (tmpPixel < 0) {
|
| + tmpPixel = 0;
|
| }
|
| + *pPixel = (FX_BYTE)tmpPixel;
|
| }
|
| }
|
| }
|
| }
|
| - } catch (...) {
|
| - if (channel_bufs) {
|
| - FX_Free(channel_bufs);
|
| - }
|
| - FX_Free(adjust_comps);
|
| - return FALSE;
|
| }
|
| +
|
| FX_Free(channel_bufs);
|
| FX_Free(adjust_comps);
|
| return TRUE;
|
|
|