From c4053bb0de4fd3cd2a1c4b204a066140edfe0651 Mon Sep 17 00:00:00 2001 From: Brian Hinz Date: Sun, 5 Feb 2012 21:46:32 +0000 Subject: Improved Tight JPEG decode time by ~25% using PixelGrabber rather than getting each pixel manually. git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4844 3789f03b-4d11-0410-bbf8-ca57d06f2519 --- java/com/tigervnc/rfb/TightDecoder.java | 32 +++++++++++++------------------- 1 file changed, 13 insertions(+), 19 deletions(-) (limited to 'java/com/tigervnc') diff --git a/java/com/tigervnc/rfb/TightDecoder.java b/java/com/tigervnc/rfb/TightDecoder.java index 3e894c0b..cfc259e5 100644 --- a/java/com/tigervnc/rfb/TightDecoder.java +++ b/java/com/tigervnc/rfb/TightDecoder.java @@ -22,10 +22,9 @@ package com.tigervnc.rfb; import com.tigervnc.rdr.InStream; import com.tigervnc.rdr.ZlibInStream; import java.util.ArrayList; -import java.awt.image.BufferedImage; -import java.io.ByteArrayInputStream; -import javax.imageio.ImageIO; import java.io.InputStream; +import java.awt.image.PixelGrabber; +import java.awt.*; public class TightDecoder extends Decoder { @@ -43,6 +42,8 @@ public class TightDecoder extends Decoder { final static int rfbTightFilterGradient = 0x02; final static int rfbTightMinToCompress = 12; + final static Toolkit tk = Toolkit.getDefaultToolkit(); + public TightDecoder(CMsgReader reader_) { reader = reader_; zis = new ZlibInStream[4]; @@ -247,26 +248,19 @@ public class TightDecoder extends Decoder { is.readBytes(netbuf, 0, compressedLen); // Create an Image object from the JPEG data. - int imageType = BufferedImage.TYPE_4BYTE_ABGR_PRE; + Image jpeg = tk.createImage(netbuf); int w = r.width(); int h = r.height(); - BufferedImage jpeg = - new BufferedImage(w, h, imageType); - jpeg.setAccelerationPriority(1); - try { - jpeg = ImageIO.read(new ByteArrayInputStream(netbuf)); - } catch (java.io.IOException e) { - e.printStackTrace(); - } + int[] buf = reader.getImageBuf(w*h); - int[] pix = new int[3]; - for (int y=0; y < h; y++) { - for (int x=0; x < w; x++) { - jpeg.getRaster().getPixel(x, y, pix); - buf[y*w+x] = (0xff << 24) | (pix[0] & 0xff) << 16 | (pix[1] & 0xff) << 8 | pix[2]; - } - } + PixelGrabber pg = new PixelGrabber(jpeg, 0, 0, w, h, buf, 0, w); + try { + pg.grabPixels(0); + } catch (InterruptedException e) { + System.out.println("Tight Decoding: Wrong JPEG data received."); + } + jpeg.flush(); handler.imageRect(r, buf); } -- cgit v1.2.3