diff options
author | Pierre Ossman <ossman@cendio.se> | 2009-04-30 11:41:03 +0000 |
---|---|---|
committer | Pierre Ossman <ossman@cendio.se> | 2009-04-30 11:41:03 +0000 |
commit | 6f0ce588d170a530514ff4906e0f40cc71b6985d (patch) | |
tree | 0ca1cf1ae3f1840b3ed2dd9d55e95998fa2e9b10 /common | |
parent | 95594e082cfd9cfcce4868f75aaf80a928a3b0b3 (diff) | |
download | tigervnc-6f0ce588d170a530514ff4906e0f40cc71b6985d.tar.gz tigervnc-6f0ce588d170a530514ff4906e0f40cc71b6985d.zip |
The code to utilize our libjpeg's ability to input/output out native formatsv0.0.90
failed to consider everything but the ideal cases. Clean up the code and make
sure it handles everything.
git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@3795 3789f03b-4d11-0410-bbf8-ca57d06f2519
Diffstat (limited to 'common')
-rw-r--r-- | common/rfb/tightDecode.h | 41 | ||||
-rw-r--r-- | common/rfb/tightEncode.h | 40 |
2 files changed, 43 insertions, 38 deletions
diff --git a/common/rfb/tightDecode.h b/common/rfb/tightDecode.h index 394f044d..689a527a 100644 --- a/common/rfb/tightDecode.h +++ b/common/rfb/tightDecode.h @@ -230,7 +230,7 @@ DecompressJpegRect(const Rect& r, rdr::InStream* is, struct jpeg_error_mgr jerr; int w = r.width(); int h = r.height(); - int pixelsize = 3; + int pixelsize; rdr::U8 *dstBuf = NULL; bool dstBufIsTemp = false; const rfb::PixelFormat& pf = handler->cp.pf(); @@ -254,41 +254,44 @@ DecompressJpegRect(const Rect& r, rdr::InStream* is, JpegSetSrcManager(&cinfo, (char*)netbuf, compressedLen); jpeg_read_header(&cinfo, TRUE); - #ifdef JCS_EXTENSIONS - pixelsize = pf.bpp / 8; - if(pf.redMax == 255 && pf.greenMax == 255 && pf.blueMax == 255) { + cinfo.out_color_space = JCS_RGB; + pixelsize = 3; + +#ifdef JCS_EXTENSIONS + // Try to have libjpeg output directly to our native format + if (pf.is888()) { int redShift, greenShift, blueShift; + if(pf.bigEndian) { redShift = 24 - pf.redShift; greenShift = 24 - pf.greenShift; blueShift = 24 - pf.blueShift; - } - else { + } else { redShift = pf.redShift; greenShift = pf.greenShift; blueShift = pf.blueShift; } - if(redShift == 0 && greenShift == 8 && blueShift == 16 && pixelsize == 3) - cinfo.out_color_space = JCS_EXT_RGB; - if(redShift == 0 && greenShift == 8 && blueShift == 16 && pixelsize == 4) + + // libjpeg can only handle some "standard" formats + if(redShift == 0 && greenShift == 8 && blueShift == 16) cinfo.out_color_space = JCS_EXT_RGBX; - if(redShift == 16 && greenShift == 8 && blueShift == 0 && pixelsize == 3) - cinfo.out_color_space = JCS_EXT_BGR; - if(redShift == 16 && greenShift == 8 && blueShift == 0 && pixelsize == 4) + if(redShift == 16 && greenShift == 8 && blueShift == 0) cinfo.out_color_space = JCS_EXT_BGRX; - if(redShift == 24 && greenShift == 16 && blueShift == 8 && pixelsize == 4) + if(redShift == 24 && greenShift == 16 && blueShift == 8) cinfo.out_color_space = JCS_EXT_XBGR; - if(redShift == 8 && greenShift == 16 && blueShift == 24 && pixelsize == 4) + if(redShift == 8 && greenShift == 16 && blueShift == 24) cinfo.out_color_space = JCS_EXT_XRGB; - if(cinfo.out_color_space != JCS_RGB) + + if (cinfo.out_color_space != JCS_RGB) { dstBuf = (rdr::U8 *)buf; + pixelsize = 4; + } } - else - #endif - { +#endif + + if (cinfo.out_color_space == JCS_RGB) { dstBuf = new rdr::U8[w * h * pixelsize]; dstBufIsTemp = true; - cinfo.out_color_space = JCS_RGB; } JSAMPROW *rowPointer = new JSAMPROW[h]; diff --git a/common/rfb/tightEncode.h b/common/rfb/tightEncode.h index 0b4358b2..aa6e63aa 100644 --- a/common/rfb/tightEncode.h +++ b/common/rfb/tightEncode.h @@ -518,7 +518,7 @@ static void ENCODE_JPEG_RECT (rdr::OutStream *os, PIXEL_T *buf, { int w = r.width(); int h = r.height(); - int pixelsize = 3; + int pixelsize; rdr::U8 *srcBuf = NULL; bool srcBufIsTemp = false; @@ -530,44 +530,46 @@ static void ENCODE_JPEG_RECT (rdr::OutStream *os, PIXEL_T *buf, cinfo.image_width = w; cinfo.image_height = h; + cinfo.in_color_space = JCS_RGB; + pixelsize = 3; - #ifdef JCS_EXTENSIONS - pixelsize = pf.bpp / 8; - if(pf.redMax == 255 && pf.greenMax == 255 && pf.blueMax == 255) { +#ifdef JCS_EXTENSIONS + // Try to have libjpeg read directly from our native format + if(pf.is888()) { int redShift, greenShift, blueShift; + if(pf.bigEndian) { redShift = 24 - pf.redShift; greenShift = 24 - pf.greenShift; blueShift = 24 - pf.blueShift; - } - else { + } else { redShift = pf.redShift; greenShift = pf.greenShift; blueShift = pf.blueShift; } - if(redShift == 0 && greenShift == 8 && blueShift == 16 && pixelsize == 3) - cinfo.in_color_space = JCS_EXT_RGB; - if(redShift == 0 && greenShift == 8 && blueShift == 16 && pixelsize == 4) + + if(redShift == 0 && greenShift == 8 && blueShift == 16) cinfo.in_color_space = JCS_EXT_RGBX; - if(redShift == 16 && greenShift == 8 && blueShift == 0 && pixelsize == 3) - cinfo.in_color_space = JCS_EXT_BGR; - if(redShift == 16 && greenShift == 8 && blueShift == 0 && pixelsize == 4) + if(redShift == 16 && greenShift == 8 && blueShift == 0) cinfo.in_color_space = JCS_EXT_BGRX; - if(redShift == 24 && greenShift == 16 && blueShift == 8 && pixelsize == 4) + if(redShift == 24 && greenShift == 16 && blueShift == 8) cinfo.in_color_space = JCS_EXT_XBGR; - if(redShift == 8 && greenShift == 16 && blueShift == 24 && pixelsize == 4) + if(redShift == 8 && greenShift == 16 && blueShift == 24) cinfo.in_color_space = JCS_EXT_XRGB; - if(cinfo.in_color_space != JCS_RGB) + + if (cinfo.in_color_space != JCS_RGB) { srcBuf = (rdr::U8 *)buf; + pixelsize = 4; + } } - else - #endif - { +#endif + + if (cinfo.in_color_space == JCS_RGB) { srcBuf = new rdr::U8[w * h * pixelsize]; srcBufIsTemp = true; pf.rgbFromBuffer(srcBuf, (const rdr::U8 *)buf, w * h); - cinfo.in_color_space = JCS_RGB; } + cinfo.input_components = pixelsize; jpeg_set_defaults(&cinfo); |