Index: java/org/libjpegturbo/turbojpeg/TJCompressor.java |
diff --git a/java/org/libjpegturbo/turbojpeg/TJCompressor.java b/java/org/libjpegturbo/turbojpeg/TJCompressor.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2ff8e4d5ecd8b16e7f994ffeeab7124b64ef205e |
--- /dev/null |
+++ b/java/org/libjpegturbo/turbojpeg/TJCompressor.java |
@@ -0,0 +1,658 @@ |
+/* |
+ * Copyright (C)2011-2015 D. R. Commander. All Rights Reserved. |
+ * Copyright (C)2015 Viktor Szathmáry. All Rights Reserved. |
+ * |
+ * Redistribution and use in source and binary forms, with or without |
+ * modification, are permitted provided that the following conditions are met: |
+ * |
+ * - Redistributions of source code must retain the above copyright notice, |
+ * this list of conditions and the following disclaimer. |
+ * - Redistributions in binary form must reproduce the above copyright notice, |
+ * this list of conditions and the following disclaimer in the documentation |
+ * and/or other materials provided with the distribution. |
+ * - Neither the name of the libjpeg-turbo Project nor the names of its |
+ * contributors may be used to endorse or promote products derived from this |
+ * software without specific prior written permission. |
+ * |
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS", |
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE |
+ * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
+ * POSSIBILITY OF SUCH DAMAGE. |
+ */ |
+ |
+package org.libjpegturbo.turbojpeg; |
+ |
+import java.awt.image.*; |
+import java.nio.*; |
+import java.io.*; |
+ |
+/** |
+ * TurboJPEG compressor |
+ */ |
+public class TJCompressor implements Closeable { |
+ |
+ private static final String NO_ASSOC_ERROR = |
+ "No source image is associated with this instance"; |
+ |
+ /** |
+ * Create a TurboJPEG compressor instance. |
+ */ |
+ public TJCompressor() throws TJException { |
+ init(); |
+ } |
+ |
+ /** |
+ * Create a TurboJPEG compressor instance and associate the uncompressed |
+ * source image stored in <code>srcImage</code> with the newly created |
+ * instance. |
+ * |
+ * @param srcImage see {@link #setSourceImage} for description |
+ * |
+ * @param x see {@link #setSourceImage} for description |
+ * |
+ * @param y see {@link #setSourceImage} for description |
+ * |
+ * @param width see {@link #setSourceImage} for description |
+ * |
+ * @param pitch see {@link #setSourceImage} for description |
+ * |
+ * @param height see {@link #setSourceImage} for description |
+ * |
+ * @param pixelFormat pixel format of the source image (one of |
+ * {@link TJ#PF_RGB TJ.PF_*}) |
+ */ |
+ public TJCompressor(byte[] srcImage, int x, int y, int width, int pitch, |
+ int height, int pixelFormat) throws TJException { |
+ setSourceImage(srcImage, x, y, width, pitch, height, pixelFormat); |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #TJCompressor(byte[], int, int, int, int, int, int)} instead. |
+ */ |
+ @Deprecated |
+ public TJCompressor(byte[] srcImage, int width, int pitch, int height, |
+ int pixelFormat) throws TJException { |
+ setSourceImage(srcImage, width, pitch, height, pixelFormat); |
+ } |
+ |
+ /** |
+ * Create a TurboJPEG compressor instance and associate the uncompressed |
+ * source image stored in <code>srcImage</code> with the newly created |
+ * instance. |
+ * |
+ * @param srcImage see |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} for description |
+ * |
+ * @param x see |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} for description |
+ * |
+ * @param y see |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} for description |
+ * |
+ * @param width see |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} for description |
+ * |
+ * @param height see |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} for description |
+ */ |
+ public TJCompressor(BufferedImage srcImage, int x, int y, int width, |
+ int height) throws TJException { |
+ setSourceImage(srcImage, x, y, width, height); |
+ } |
+ |
+ /** |
+ * Associate an uncompressed RGB, grayscale, or CMYK source image with this |
+ * compressor instance. |
+ * |
+ * @param srcImage image buffer containing RGB, grayscale, or CMYK pixels to |
+ * be compressed or encoded. This buffer is not modified. |
+ * |
+ * @param x x offset (in pixels) of the region in the source image from which |
+ * the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param y y offset (in pixels) of the region in the source image from which |
+ * the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param width width (in pixels) of the region in the source image from |
+ * which the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param pitch bytes per line of the source image. Normally, this should be |
+ * <code>width * TJ.pixelSize(pixelFormat)</code> if the source image is |
+ * unpadded, but you can use this parameter to, for instance, specify that |
+ * the scanlines in the source image are padded to a 4-byte boundary or to |
+ * compress/encode a JPEG or YUV image from a region of a larger source |
+ * image. You can also be clever and use this parameter to skip lines, etc. |
+ * Setting this parameter to 0 is the equivalent of setting it to |
+ * <code>width * TJ.pixelSize(pixelFormat)</code>. |
+ * |
+ * @param height height (in pixels) of the region in the source image from |
+ * which the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param pixelFormat pixel format of the source image (one of |
+ * {@link TJ#PF_RGB TJ.PF_*}) |
+ */ |
+ public void setSourceImage(byte[] srcImage, int x, int y, int width, |
+ int pitch, int height, int pixelFormat) |
+ throws TJException { |
+ if (handle == 0) init(); |
+ if (srcImage == null || x < 0 || y < 0 || width < 1 || height < 1 || |
+ pitch < 0 || pixelFormat < 0 || pixelFormat >= TJ.NUMPF) |
+ throw new IllegalArgumentException("Invalid argument in setSourceImage()"); |
+ srcBuf = srcImage; |
+ srcWidth = width; |
+ if (pitch == 0) |
+ srcPitch = width * TJ.getPixelSize(pixelFormat); |
+ else |
+ srcPitch = pitch; |
+ srcHeight = height; |
+ srcPixelFormat = pixelFormat; |
+ srcX = x; |
+ srcY = y; |
+ srcBufInt = null; |
+ srcYUVImage = null; |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #setSourceImage(byte[], int, int, int, int, int, int)} instead. |
+ */ |
+ @Deprecated |
+ public void setSourceImage(byte[] srcImage, int width, int pitch, |
+ int height, int pixelFormat) throws TJException { |
+ setSourceImage(srcImage, 0, 0, width, pitch, height, pixelFormat); |
+ srcX = srcY = -1; |
+ } |
+ |
+ /** |
+ * Associate an uncompressed RGB or grayscale source image with this |
+ * compressor instance. |
+ * |
+ * @param srcImage a <code>BufferedImage</code> instance containing RGB or |
+ * grayscale pixels to be compressed or encoded. This image is not modified. |
+ * |
+ * @param x x offset (in pixels) of the region in the source image from which |
+ * the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param y y offset (in pixels) of the region in the source image from which |
+ * the JPEG or YUV image should be compressed/encoded |
+ * |
+ * @param width width (in pixels) of the region in the source image from |
+ * which the JPEG or YUV image should be compressed/encoded (0 = use the |
+ * width of the source image) |
+ * |
+ * @param height height (in pixels) of the region in the source image from |
+ * which the JPEG or YUV image should be compressed/encoded (0 = use the |
+ * height of the source image) |
+ */ |
+ public void setSourceImage(BufferedImage srcImage, int x, int y, int width, |
+ int height) throws TJException { |
+ if (handle == 0) init(); |
+ if (srcImage == null || x < 0 || y < 0 || width < 0 || height < 0) |
+ throw new IllegalArgumentException("Invalid argument in setSourceImage()"); |
+ srcX = x; |
+ srcY = y; |
+ srcWidth = (width == 0) ? srcImage.getWidth(): width; |
+ srcHeight = (height == 0) ? srcImage.getHeight() : height; |
+ if (x + width > srcImage.getWidth() || y + height > srcImage.getHeight()) |
+ throw new IllegalArgumentException("Compression region exceeds the bounds of the source image"); |
+ |
+ int pixelFormat; |
+ boolean intPixels = false; |
+ if (byteOrder == null) |
+ byteOrder = ByteOrder.nativeOrder(); |
+ switch(srcImage.getType()) { |
+ case BufferedImage.TYPE_3BYTE_BGR: |
+ pixelFormat = TJ.PF_BGR; break; |
+ case BufferedImage.TYPE_4BYTE_ABGR: |
+ case BufferedImage.TYPE_4BYTE_ABGR_PRE: |
+ pixelFormat = TJ.PF_XBGR; break; |
+ case BufferedImage.TYPE_BYTE_GRAY: |
+ pixelFormat = TJ.PF_GRAY; break; |
+ case BufferedImage.TYPE_INT_BGR: |
+ if (byteOrder == ByteOrder.BIG_ENDIAN) |
+ pixelFormat = TJ.PF_XBGR; |
+ else |
+ pixelFormat = TJ.PF_RGBX; |
+ intPixels = true; break; |
+ case BufferedImage.TYPE_INT_RGB: |
+ case BufferedImage.TYPE_INT_ARGB: |
+ case BufferedImage.TYPE_INT_ARGB_PRE: |
+ if (byteOrder == ByteOrder.BIG_ENDIAN) |
+ pixelFormat = TJ.PF_XRGB; |
+ else |
+ pixelFormat = TJ.PF_BGRX; |
+ intPixels = true; break; |
+ default: |
+ throw new IllegalArgumentException("Unsupported BufferedImage format"); |
+ } |
+ srcPixelFormat = pixelFormat; |
+ |
+ WritableRaster wr = srcImage.getRaster(); |
+ if (intPixels) { |
+ SinglePixelPackedSampleModel sm = |
+ (SinglePixelPackedSampleModel)srcImage.getSampleModel(); |
+ srcStride = sm.getScanlineStride(); |
+ DataBufferInt db = (DataBufferInt)wr.getDataBuffer(); |
+ srcBufInt = db.getData(); |
+ srcBuf = null; |
+ } else { |
+ ComponentSampleModel sm = |
+ (ComponentSampleModel)srcImage.getSampleModel(); |
+ int pixelSize = sm.getPixelStride(); |
+ if (pixelSize != TJ.getPixelSize(pixelFormat)) |
+ throw new IllegalArgumentException("Inconsistency between pixel format and pixel size in BufferedImage"); |
+ srcPitch = sm.getScanlineStride(); |
+ DataBufferByte db = (DataBufferByte)wr.getDataBuffer(); |
+ srcBuf = db.getData(); |
+ srcBufInt = null; |
+ } |
+ srcYUVImage = null; |
+ } |
+ |
+ /** |
+ * Associate an uncompressed YUV planar source image with this compressor |
+ * instance. |
+ * |
+ * @param srcImage YUV planar image to be compressed. This image is not |
+ * modified. |
+ */ |
+ public void setSourceImage(YUVImage srcImage) throws TJException { |
+ if (handle == 0) init(); |
+ if (srcImage == null) |
+ throw new IllegalArgumentException("Invalid argument in setSourceImage()"); |
+ srcYUVImage = srcImage; |
+ srcBuf = null; |
+ srcBufInt = null; |
+ } |
+ |
+ /** |
+ * Set the level of chrominance subsampling for subsequent compress/encode |
+ * operations. When pixels are converted from RGB to YCbCr (see |
+ * {@link TJ#CS_YCbCr}) or from CMYK to YCCK (see {@link TJ#CS_YCCK}) as part |
+ * of the JPEG compression process, some of the Cb and Cr (chrominance) |
+ * components can be discarded or averaged together to produce a smaller |
+ * image with little perceptible loss of image clarity (the human eye is more |
+ * sensitive to small changes in brightness than to small changes in color.) |
+ * This is called "chrominance subsampling". |
+ * <p> |
+ * NOTE: This method has no effect when compressing a JPEG image from a YUV |
+ * planar source. In that case, the level of chrominance subsampling in |
+ * the JPEG image is determined by the source. Further, this method has no |
+ * effect when encoding to a pre-allocated {@link YUVImage} instance. In |
+ * that case, the level of chrominance subsampling is determined by the |
+ * destination. |
+ * |
+ * @param newSubsamp the level of chrominance subsampling to use in |
+ * subsequent compress/encode oeprations (one of |
+ * {@link TJ#SAMP_444 TJ.SAMP_*}) |
+ */ |
+ public void setSubsamp(int newSubsamp) { |
+ if (newSubsamp < 0 || newSubsamp >= TJ.NUMSAMP) |
+ throw new IllegalArgumentException("Invalid argument in setSubsamp()"); |
+ subsamp = newSubsamp; |
+ } |
+ |
+ /** |
+ * Set the JPEG image quality level for subsequent compress operations. |
+ * |
+ * @param quality the new JPEG image quality level (1 to 100, 1 = worst, |
+ * 100 = best) |
+ */ |
+ public void setJPEGQuality(int quality) { |
+ if (quality < 1 || quality > 100) |
+ throw new IllegalArgumentException("Invalid argument in setJPEGQuality()"); |
+ jpegQuality = quality; |
+ } |
+ |
+ /** |
+ * Compress the uncompressed source image associated with this compressor |
+ * instance and output a JPEG image to the given destination buffer. |
+ * |
+ * @param dstBuf buffer that will receive the JPEG image. Use |
+ * {@link TJ#bufSize} to determine the maximum size for this buffer based on |
+ * the source image's width and height and the desired level of chrominance |
+ * subsampling. |
+ * |
+ * @param flags the bitwise OR of one or more of |
+ * {@link TJ#FLAG_BOTTOMUP TJ.FLAG_*} |
+ */ |
+ public void compress(byte[] dstBuf, int flags) throws TJException { |
+ if (dstBuf == null || flags < 0) |
+ throw new IllegalArgumentException("Invalid argument in compress()"); |
+ if (srcBuf == null && srcBufInt == null && srcYUVImage == null) |
+ throw new IllegalStateException(NO_ASSOC_ERROR); |
+ if (jpegQuality < 0) |
+ throw new IllegalStateException("JPEG Quality not set"); |
+ if (subsamp < 0 && srcYUVImage == null) |
+ throw new IllegalStateException("Subsampling level not set"); |
+ |
+ if (srcYUVImage != null) |
+ compressedSize = compressFromYUV(srcYUVImage.getPlanes(), |
+ srcYUVImage.getOffsets(), |
+ srcYUVImage.getWidth(), |
+ srcYUVImage.getStrides(), |
+ srcYUVImage.getHeight(), |
+ srcYUVImage.getSubsamp(), |
+ dstBuf, jpegQuality, flags); |
+ else if (srcBuf != null) { |
+ if (srcX >= 0 && srcY >= 0) |
+ compressedSize = compress(srcBuf, srcX, srcY, srcWidth, srcPitch, |
+ srcHeight, srcPixelFormat, dstBuf, subsamp, |
+ jpegQuality, flags); |
+ else |
+ compressedSize = compress(srcBuf, srcWidth, srcPitch, srcHeight, |
+ srcPixelFormat, dstBuf, subsamp, jpegQuality, |
+ flags); |
+ } else if (srcBufInt != null) { |
+ if (srcX >= 0 && srcY >= 0) |
+ compressedSize = compress(srcBufInt, srcX, srcY, srcWidth, srcStride, |
+ srcHeight, srcPixelFormat, dstBuf, subsamp, |
+ jpegQuality, flags); |
+ else |
+ compressedSize = compress(srcBufInt, srcWidth, srcStride, srcHeight, |
+ srcPixelFormat, dstBuf, subsamp, jpegQuality, |
+ flags); |
+ } |
+ } |
+ |
+ /** |
+ * Compress the uncompressed source image associated with this compressor |
+ * instance and return a buffer containing a JPEG image. |
+ * |
+ * @param flags the bitwise OR of one or more of |
+ * {@link TJ#FLAG_BOTTOMUP TJ.FLAG_*} |
+ * |
+ * @return a buffer containing a JPEG image. The length of this buffer will |
+ * not be equal to the size of the JPEG image. Use {@link |
+ * #getCompressedSize} to obtain the size of the JPEG image. |
+ */ |
+ public byte[] compress(int flags) throws TJException { |
+ checkSourceImage(); |
+ byte[] buf = new byte[TJ.bufSize(srcWidth, srcHeight, subsamp)]; |
+ compress(buf, flags); |
+ return buf; |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} and |
+ * {@link #compress(byte[], int)} instead. |
+ */ |
+ @Deprecated |
+ public void compress(BufferedImage srcImage, byte[] dstBuf, int flags) |
+ throws TJException { |
+ setSourceImage(srcImage, 0, 0, 0, 0); |
+ compress(dstBuf, flags); |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} and |
+ * {@link #compress(int)} instead. |
+ */ |
+ @Deprecated |
+ public byte[] compress(BufferedImage srcImage, int flags) |
+ throws TJException { |
+ setSourceImage(srcImage, 0, 0, 0, 0); |
+ return compress(flags); |
+ } |
+ |
+ /** |
+ * Encode the uncompressed source image associated with this compressor |
+ * instance into a YUV planar image and store it in the given |
+ * <code>YUVImage</code> instance. This method uses the accelerated color |
+ * conversion routines in TurboJPEG's underlying codec but does not execute |
+ * any of the other steps in the JPEG compression process. Encoding |
+ * CMYK source images to YUV is not supported. |
+ * |
+ * @param dstImage {@link YUVImage} instance that will receive the YUV planar |
+ * image |
+ * |
+ * @param flags the bitwise OR of one or more of |
+ * {@link TJ#FLAG_BOTTOMUP TJ.FLAG_*} |
+ */ |
+ public void encodeYUV(YUVImage dstImage, int flags) throws TJException { |
+ if (dstImage == null || flags < 0) |
+ throw new IllegalArgumentException("Invalid argument in encodeYUV()"); |
+ if (srcBuf == null && srcBufInt == null) |
+ throw new IllegalStateException(NO_ASSOC_ERROR); |
+ if (srcYUVImage != null) |
+ throw new IllegalStateException("Source image is not correct type"); |
+ checkSubsampling(); |
+ if (srcWidth != dstImage.getWidth() || srcHeight != dstImage.getHeight()) |
+ throw new IllegalStateException("Destination image is the wrong size"); |
+ |
+ if (srcBufInt != null) { |
+ encodeYUV(srcBufInt, srcX, srcY, srcWidth, srcStride, srcHeight, |
+ srcPixelFormat, dstImage.getPlanes(), dstImage.getOffsets(), |
+ dstImage.getStrides(), dstImage.getSubsamp(), flags); |
+ } else { |
+ encodeYUV(srcBuf, srcX, srcY, srcWidth, srcPitch, srcHeight, |
+ srcPixelFormat, dstImage.getPlanes(), dstImage.getOffsets(), |
+ dstImage.getStrides(), dstImage.getSubsamp(), flags); |
+ } |
+ compressedSize = 0; |
+ } |
+ |
+ /** |
+ * @deprecated Use {@link #encodeYUV(YUVImage, int)} instead. |
+ */ |
+ @Deprecated |
+ public void encodeYUV(byte[] dstBuf, int flags) throws TJException { |
+ if(dstBuf == null) |
+ throw new IllegalArgumentException("Invalid argument in encodeYUV()"); |
+ checkSourceImage(); |
+ checkSubsampling(); |
+ YUVImage yuvImage = new YUVImage(dstBuf, srcWidth, 4, srcHeight, subsamp); |
+ encodeYUV(yuvImage, flags); |
+ } |
+ |
+ /** |
+ * Encode the uncompressed source image associated with this compressor |
+ * instance into a unified YUV planar image buffer and return a |
+ * <code>YUVImage</code> instance containing the encoded image. This method |
+ * uses the accelerated color conversion routines in TurboJPEG's underlying |
+ * codec but does not execute any of the other steps in the JPEG compression |
+ * process. Encoding CMYK source images to YUV is not supported. |
+ * |
+ * @param pad the width of each line in each plane of the YUV image will be |
+ * padded to the nearest multiple of this number of bytes (must be a power of |
+ * 2.) |
+ * |
+ * @param flags the bitwise OR of one or more of |
+ * {@link TJ#FLAG_BOTTOMUP TJ.FLAG_*} |
+ * |
+ * @return a YUV planar image. |
+ */ |
+ public YUVImage encodeYUV(int pad, int flags) throws TJException { |
+ checkSourceImage(); |
+ checkSubsampling(); |
+ if(pad < 1 || ((pad & (pad - 1)) != 0)) |
+ throw new IllegalStateException("Invalid argument in encodeYUV()"); |
+ YUVImage yuvImage = new YUVImage(srcWidth, pad, srcHeight, subsamp); |
+ encodeYUV(yuvImage, flags); |
+ return yuvImage; |
+ } |
+ |
+ /** |
+ * Encode the uncompressed source image associated with this compressor |
+ * instance into separate Y, U (Cb), and V (Cr) image planes and return a |
+ * <code>YUVImage</code> instance containing the encoded image planes. This |
+ * method uses the accelerated color conversion routines in TurboJPEG's |
+ * underlying codec but does not execute any of the other steps in the JPEG |
+ * compression process. Encoding CMYK source images to YUV is not supported. |
+ * |
+ * @param strides an array of integers, each specifying the number of bytes |
+ * per line in the corresponding plane of the output image. Setting the |
+ * stride for any plane to 0 is the same as setting it to the component width |
+ * of the plane. If <code>strides</code> is null, then the strides for all |
+ * planes will be set to their respective component widths. You can adjust |
+ * the strides in order to add an arbitrary amount of line padding to each |
+ * plane. |
+ * |
+ * @param flags the bitwise OR of one or more of |
+ * {@link TJ#FLAG_BOTTOMUP TJ.FLAG_*} |
+ * |
+ * @return a YUV planar image. |
+ */ |
+ public YUVImage encodeYUV(int[] strides, int flags) throws TJException { |
+ checkSourceImage(); |
+ checkSubsampling(); |
+ YUVImage yuvImage = new YUVImage(srcWidth, strides, srcHeight, subsamp); |
+ encodeYUV(yuvImage, flags); |
+ return yuvImage; |
+ } |
+ |
+ /** |
+ * @deprecated Use {@link #encodeYUV(int, int)} instead. |
+ */ |
+ @Deprecated |
+ public byte[] encodeYUV(int flags) throws TJException { |
+ checkSourceImage(); |
+ checkSubsampling(); |
+ YUVImage yuvImage = new YUVImage(srcWidth, 4, srcHeight, subsamp); |
+ encodeYUV(yuvImage, flags); |
+ return yuvImage.getBuf(); |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} and |
+ * {@link #encodeYUV(byte[], int)} instead. |
+ */ |
+ @Deprecated |
+ public void encodeYUV(BufferedImage srcImage, byte[] dstBuf, int flags) |
+ throws TJException { |
+ setSourceImage(srcImage, 0, 0, 0, 0); |
+ encodeYUV(dstBuf, flags); |
+ } |
+ |
+ /** |
+ * @deprecated Use |
+ * {@link #setSourceImage(BufferedImage, int, int, int, int)} and |
+ * {@link #encodeYUV(int, int)} instead. |
+ */ |
+ @Deprecated |
+ public byte[] encodeYUV(BufferedImage srcImage, int flags) |
+ throws TJException { |
+ setSourceImage(srcImage, 0, 0, 0, 0); |
+ return encodeYUV(flags); |
+ } |
+ |
+ /** |
+ * Returns the size of the image (in bytes) generated by the most recent |
+ * compress operation. |
+ * |
+ * @return the size of the image (in bytes) generated by the most recent |
+ * compress operation. |
+ */ |
+ public int getCompressedSize() { |
+ return compressedSize; |
+ } |
+ |
+ /** |
+ * Free the native structures associated with this compressor instance. |
+ */ |
+ @Override |
+ public void close() throws TJException { |
+ if (handle != 0) |
+ destroy(); |
+ } |
+ |
+ @Override |
+ protected void finalize() throws Throwable { |
+ try { |
+ close(); |
+ } catch(TJException e) { |
+ } finally { |
+ super.finalize(); |
+ } |
+ }; |
+ |
+ private native void init() throws TJException; |
+ |
+ private native void destroy() throws TJException; |
+ |
+ // JPEG size in bytes is returned |
+ @Deprecated |
+ private native int compress(byte[] srcBuf, int width, int pitch, |
+ int height, int pixelFormat, byte[] dstBuf, int jpegSubsamp, int jpegQual, |
+ int flags) throws TJException; |
+ |
+ private native int compress(byte[] srcBuf, int x, int y, int width, |
+ int pitch, int height, int pixelFormat, byte[] dstBuf, int jpegSubsamp, |
+ int jpegQual, int flags) throws TJException; |
+ |
+ @Deprecated |
+ private native int compress(int[] srcBuf, int width, int stride, |
+ int height, int pixelFormat, byte[] dstBuf, int jpegSubsamp, int jpegQual, |
+ int flags) throws TJException; |
+ |
+ private native int compress(int[] srcBuf, int x, int y, int width, |
+ int stride, int height, int pixelFormat, byte[] dstBuf, int jpegSubsamp, |
+ int jpegQual, int flags) throws TJException; |
+ |
+ private native int compressFromYUV(byte[][] srcPlanes, int[] srcOffsets, |
+ int width, int[] srcStrides, int height, int subsamp, byte[] dstBuf, |
+ int jpegQual, int flags) |
+ throws TJException; |
+ |
+ @Deprecated |
+ private native void encodeYUV(byte[] srcBuf, int width, int pitch, |
+ int height, int pixelFormat, byte[] dstBuf, int subsamp, int flags) |
+ throws TJException; |
+ |
+ private native void encodeYUV(byte[] srcBuf, int x, int y, int width, |
+ int pitch, int height, int pixelFormat, byte[][] dstPlanes, |
+ int[] dstOffsets, int[] dstStrides, int subsamp, int flags) |
+ throws TJException; |
+ |
+ @Deprecated |
+ private native void encodeYUV(int[] srcBuf, int width, int stride, |
+ int height, int pixelFormat, byte[] dstBuf, int subsamp, int flags) |
+ throws TJException; |
+ |
+ private native void encodeYUV(int[] srcBuf, int x, int y, int width, |
+ int srcStride, int height, int pixelFormat, byte[][] dstPlanes, |
+ int[] dstOffsets, int[] dstStrides, int subsamp, int flags) |
+ throws TJException; |
+ |
+ static { |
+ TJLoader.load(); |
+ } |
+ |
+ private void checkSourceImage() { |
+ if (srcWidth < 1 || srcHeight < 1) |
+ throw new IllegalStateException(NO_ASSOC_ERROR); |
+ } |
+ |
+ private void checkSubsampling() { |
+ if (subsamp < 0) |
+ throw new IllegalStateException("Subsampling level not set"); |
+ } |
+ |
+ private long handle = 0; |
+ private byte[] srcBuf = null; |
+ private int[] srcBufInt = null; |
+ private int srcWidth = 0; |
+ private int srcHeight = 0; |
+ private int srcX = -1; |
+ private int srcY = -1; |
+ private int srcPitch = 0; |
+ private int srcStride = 0; |
+ private int srcPixelFormat = -1; |
+ private YUVImage srcYUVImage = null; |
+ private int subsamp = -1; |
+ private int jpegQuality = -1; |
+ private int compressedSize = 0; |
+ private int yuvPad = 4; |
+ private ByteOrder byteOrder = null; |
+} |