1 /*
2  * Copyright (C)2011-2013 D. R. Commander.  All Rights Reserved.
3  * Copyright (C)2015 Viktor Szathmáry.  All Rights Reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * - Redistributions of source code must retain the above copyright notice,
9  *   this list of conditions and the following disclaimer.
10  * - Redistributions in binary form must reproduce the above copyright notice,
11  *   this list of conditions and the following disclaimer in the documentation
12  *   and/or other materials provided with the distribution.
13  * - Neither the name of the libjpeg-turbo Project nor the names of its
14  *   contributors may be used to endorse or promote products derived from this
15  *   software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS",
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 package org.libjpegturbo.turbojpeg;
31 
32 /**
33  * TurboJPEG utility class (cannot be instantiated)
34  */
35 public final class TJ {
36 
37 
38   /**
39    * The number of chrominance subsampling options
40    */
41   public static final int NUMSAMP   = 6;
42   /**
43    * 4:4:4 chrominance subsampling (no chrominance subsampling).  The JPEG
44    * or YUV image will contain one chrominance component for every pixel in the
45    * source image.
46    */
47   public static final int SAMP_444  = 0;
48   /**
49    * 4:2:2 chrominance subsampling.  The JPEG or YUV image will contain one
50    * chrominance component for every 2x1 block of pixels in the source image.
51    */
52   public static final int SAMP_422  = 1;
53   /**
54    * 4:2:0 chrominance subsampling.  The JPEG or YUV image will contain one
55    * chrominance component for every 2x2 block of pixels in the source image.
56    */
57   public static final int SAMP_420  = 2;
58   /**
59    * Grayscale.  The JPEG or YUV image will contain no chrominance components.
60    */
61   public static final int SAMP_GRAY = 3;
62   /**
63    * 4:4:0 chrominance subsampling.  The JPEG or YUV image will contain one
64    * chrominance component for every 1x2 block of pixels in the source image.
65    * Note that 4:4:0 subsampling is not fully accelerated in libjpeg-turbo.
66    */
67   public static final int SAMP_440  = 4;
68   /**
69    * 4:1:1 chrominance subsampling.  The JPEG or YUV image will contain one
70    * chrominance component for every 4x1 block of pixels in the source image.
71    * JPEG images compressed with 4:1:1 subsampling will be almost exactly the
72    * same size as those compressed with 4:2:0 subsampling, and in the
73    * aggregate, both subsampling methods produce approximately the same
74    * perceptual quality.  However, 4:1:1 is better able to reproduce sharp
75    * horizontal features.  Note that 4:1:1 subsampling is not fully accelerated
76    * in libjpeg-turbo.
77    */
78   public static final int SAMP_411  = 5;
79 
80 
81   /**
82    * Returns the MCU block width for the given level of chrominance
83    * subsampling.
84    *
85    * @param subsamp the level of chrominance subsampling (one of
86    * <code>SAMP_*</code>)
87    *
88    * @return the MCU block width for the given level of chrominance
89    * subsampling.
90    */
getMCUWidth(int subsamp)91   public static int getMCUWidth(int subsamp) {
92     checkSubsampling(subsamp);
93     return mcuWidth[subsamp];
94   }
95 
96   private static final int[] mcuWidth = {
97     8, 16, 16, 8, 8, 32
98   };
99 
100 
101   /**
102    * Returns the MCU block height for the given level of chrominance
103    * subsampling.
104    *
105    * @param subsamp the level of chrominance subsampling (one of
106    * <code>SAMP_*</code>)
107    *
108    * @return the MCU block height for the given level of chrominance
109    * subsampling.
110    */
getMCUHeight(int subsamp)111   public static int getMCUHeight(int subsamp) {
112     checkSubsampling(subsamp);
113     return mcuHeight[subsamp];
114   }
115 
116   private static final int[] mcuHeight = {
117     8, 8, 16, 8, 16, 8
118   };
119 
120 
121   /**
122    * The number of pixel formats
123    */
124   public static final int NUMPF   = 12;
125   /**
126    * RGB pixel format.  The red, green, and blue components in the image are
127    * stored in 3-byte pixels in the order R, G, B from lowest to highest byte
128    * address within each pixel.
129    */
130   public static final int PF_RGB  = 0;
131   /**
132    * BGR pixel format.  The red, green, and blue components in the image are
133    * stored in 3-byte pixels in the order B, G, R from lowest to highest byte
134    * address within each pixel.
135    */
136   public static final int PF_BGR  = 1;
137   /**
138    * RGBX pixel format.  The red, green, and blue components in the image are
139    * stored in 4-byte pixels in the order R, G, B from lowest to highest byte
140    * address within each pixel.  The X component is ignored when compressing
141    * and undefined when decompressing.
142    */
143   public static final int PF_RGBX = 2;
144   /**
145    * BGRX pixel format.  The red, green, and blue components in the image are
146    * stored in 4-byte pixels in the order B, G, R from lowest to highest byte
147    * address within each pixel.  The X component is ignored when compressing
148    * and undefined when decompressing.
149    */
150   public static final int PF_BGRX = 3;
151   /**
152    * XBGR pixel format.  The red, green, and blue components in the image are
153    * stored in 4-byte pixels in the order R, G, B from highest to lowest byte
154    * address within each pixel.  The X component is ignored when compressing
155    * and undefined when decompressing.
156    */
157   public static final int PF_XBGR = 4;
158   /**
159    * XRGB pixel format.  The red, green, and blue components in the image are
160    * stored in 4-byte pixels in the order B, G, R from highest to lowest byte
161    * address within each pixel.  The X component is ignored when compressing
162    * and undefined when decompressing.
163    */
164   public static final int PF_XRGB = 5;
165   /**
166    * Grayscale pixel format.  Each 1-byte pixel represents a luminance
167    * (brightness) level from 0 to 255.
168    */
169   public static final int PF_GRAY = 6;
170   /**
171    * RGBA pixel format.  This is the same as {@link #PF_RGBX}, except that when
172    * decompressing, the X byte is guaranteed to be 0xFF, which can be
173    * interpreted as an opaque alpha channel.
174    */
175   public static final int PF_RGBA = 7;
176   /**
177    * BGRA pixel format.  This is the same as {@link #PF_BGRX}, except that when
178    * decompressing, the X byte is guaranteed to be 0xFF, which can be
179    * interpreted as an opaque alpha channel.
180    */
181   public static final int PF_BGRA = 8;
182   /**
183    * ABGR pixel format.  This is the same as {@link #PF_XBGR}, except that when
184    * decompressing, the X byte is guaranteed to be 0xFF, which can be
185    * interpreted as an opaque alpha channel.
186    */
187   public static final int PF_ABGR = 9;
188   /**
189    * ARGB pixel format.  This is the same as {@link #PF_XRGB}, except that when
190    * decompressing, the X byte is guaranteed to be 0xFF, which can be
191    * interpreted as an opaque alpha channel.
192    */
193   public static final int PF_ARGB = 10;
194   /**
195    * CMYK pixel format.  Unlike RGB, which is an additive color model used
196    * primarily for display, CMYK (Cyan/Magenta/Yellow/Key) is a subtractive
197    * color model used primarily for printing.  In the CMYK color model, the
198    * value of each color component typically corresponds to an amount of cyan,
199    * magenta, yellow, or black ink that is applied to a white background.  In
200    * order to convert between CMYK and RGB, it is necessary to use a color
201    * management system (CMS.)  A CMS will attempt to map colors within the
202    * printer's gamut to perceptually similar colors in the display's gamut and
203    * vice versa, but the mapping is typically not 1:1 or reversible, nor can it
204    * be defined with a simple formula.  Thus, such a conversion is out of scope
205    * for a codec library.  However, the TurboJPEG API allows for compressing
206    * CMYK pixels into a YCCK JPEG image (see {@link #CS_YCCK}) and
207    * decompressing YCCK JPEG images into CMYK pixels.
208    */
209   public static final int PF_CMYK = 11;
210 
211 
212   /**
213    * Returns the pixel size (in bytes) for the given pixel format.
214    *
215    * @param pixelFormat the pixel format (one of <code>PF_*</code>)
216    *
217    * @return the pixel size (in bytes) for the given pixel format.
218    */
getPixelSize(int pixelFormat)219   public static int getPixelSize(int pixelFormat) {
220     checkPixelFormat(pixelFormat);
221     return pixelSize[pixelFormat];
222   }
223 
224   private static final int[] pixelSize = {
225     3, 3, 4, 4, 4, 4, 1, 4, 4, 4, 4, 4
226   };
227 
228 
229   /**
230    * For the given pixel format, returns the number of bytes that the red
231    * component is offset from the start of the pixel.  For instance, if a pixel
232    * of format <code>TJ.PF_BGRX</code> is stored in <code>char pixel[]</code>,
233    * then the red component will be
234    * <code>pixel[TJ.getRedOffset(TJ.PF_BGRX)]</code>.
235    *
236    * @param pixelFormat the pixel format (one of <code>PF_*</code>)
237    *
238    * @return the red offset for the given pixel format.
239    */
getRedOffset(int pixelFormat)240   public static int getRedOffset(int pixelFormat) {
241     checkPixelFormat(pixelFormat);
242     return redOffset[pixelFormat];
243   }
244 
245   private static final int[] redOffset = {
246     0, 2, 0, 2, 3, 1, 0, 0, 2, 3, 1, -1
247   };
248 
249 
250   /**
251    * For the given pixel format, returns the number of bytes that the green
252    * component is offset from the start of the pixel.  For instance, if a pixel
253    * of format <code>TJ.PF_BGRX</code> is stored in <code>char pixel[]</code>,
254    * then the green component will be
255    * <code>pixel[TJ.getGreenOffset(TJ.PF_BGRX)]</code>.
256    *
257    * @param pixelFormat the pixel format (one of <code>PF_*</code>)
258    *
259    * @return the green offset for the given pixel format.
260    */
getGreenOffset(int pixelFormat)261   public static int getGreenOffset(int pixelFormat) {
262     checkPixelFormat(pixelFormat);
263     return greenOffset[pixelFormat];
264   }
265 
266   private static final int[] greenOffset = {
267     1, 1, 1, 1, 2, 2, 0, 1, 1, 2, 2, -1
268   };
269 
270 
271   /**
272    * For the given pixel format, returns the number of bytes that the blue
273    * component is offset from the start of the pixel.  For instance, if a pixel
274    * of format <code>TJ.PF_BGRX</code> is stored in <code>char pixel[]</code>,
275    * then the blue component will be
276    * <code>pixel[TJ.getBlueOffset(TJ.PF_BGRX)]</code>.
277    *
278    * @param pixelFormat the pixel format (one of <code>PF_*</code>)
279    *
280    * @return the blue offset for the given pixel format.
281    */
getBlueOffset(int pixelFormat)282   public static int getBlueOffset(int pixelFormat) {
283     checkPixelFormat(pixelFormat);
284     return blueOffset[pixelFormat];
285   }
286 
287   private static final int[] blueOffset = {
288     2, 0, 2, 0, 1, 3, 0, 2, 0, 1, 3, -1
289   };
290 
291 
292   /**
293    * The number of JPEG colorspaces
294    */
295   public static final int NUMCS = 5;
296   /**
297    * RGB colorspace.  When compressing the JPEG image, the R, G, and B
298    * components in the source image are reordered into image planes, but no
299    * colorspace conversion or subsampling is performed.  RGB JPEG images can be
300    * decompressed to any of the extended RGB pixel formats or grayscale, but
301    * they cannot be decompressed to YUV images.
302    */
303   public static final int CS_RGB = 0;
304   /**
305    * YCbCr colorspace.  YCbCr is not an absolute colorspace but rather a
306    * mathematical transformation of RGB designed solely for storage and
307    * transmission.  YCbCr images must be converted to RGB before they can
308    * actually be displayed.  In the YCbCr colorspace, the Y (luminance)
309    * component represents the black & white portion of the original image, and
310    * the Cb and Cr (chrominance) components represent the color portion of the
311    * original image.  Originally, the analog equivalent of this transformation
312    * allowed the same signal to drive both black & white and color televisions,
313    * but JPEG images use YCbCr primarily because it allows the color data to be
314    * optionally subsampled for the purposes of reducing bandwidth or disk
315    * space.  YCbCr is the most common JPEG colorspace, and YCbCr JPEG images
316    * can be compressed from and decompressed to any of the extended RGB pixel
317    * formats or grayscale, or they can be decompressed to YUV planar images.
318    */
319   public static final int CS_YCbCr = 1;
320   /**
321    * Grayscale colorspace.  The JPEG image retains only the luminance data (Y
322    * component), and any color data from the source image is discarded.
323    * Grayscale JPEG images can be compressed from and decompressed to any of
324    * the extended RGB pixel formats or grayscale, or they can be decompressed
325    * to YUV planar images.
326    */
327   public static final int CS_GRAY = 2;
328   /**
329    * CMYK colorspace.  When compressing the JPEG image, the C, M, Y, and K
330    * components in the source image are reordered into image planes, but no
331    * colorspace conversion or subsampling is performed.  CMYK JPEG images can
332    * only be decompressed to CMYK pixels.
333    */
334   public static final int CS_CMYK = 3;
335   /**
336    * YCCK colorspace.  YCCK (AKA "YCbCrK") is not an absolute colorspace but
337    * rather a mathematical transformation of CMYK designed solely for storage
338    * and transmission.  It is to CMYK as YCbCr is to RGB.  CMYK pixels can be
339    * reversibly transformed into YCCK, and as with YCbCr, the chrominance
340    * components in the YCCK pixels can be subsampled without incurring major
341    * perceptual loss.  YCCK JPEG images can only be compressed from and
342    * decompressed to CMYK pixels.
343    */
344   public static final int CS_YCCK = 4;
345 
346 
347   /**
348    * The uncompressed source/destination image is stored in bottom-up (Windows,
349    * OpenGL) order, not top-down (X11) order.
350    */
351   public static final int FLAG_BOTTOMUP     = 2;
352 
353   @Deprecated
354   public static final int FLAG_FORCEMMX     = 8;
355   @Deprecated
356   public static final int FLAG_FORCESSE     = 16;
357   @Deprecated
358   public static final int FLAG_FORCESSE2    = 32;
359   @Deprecated
360   public static final int FLAG_FORCESSE3    = 128;
361 
362   /**
363    * When decompressing an image that was compressed using chrominance
364    * subsampling, use the fastest chrominance upsampling algorithm available in
365    * the underlying codec.  The default is to use smooth upsampling, which
366    * creates a smooth transition between neighboring chrominance components in
367    * order to reduce upsampling artifacts in the decompressed image.
368    */
369   public static final int FLAG_FASTUPSAMPLE = 256;
370   /**
371    * Use the fastest DCT/IDCT algorithm available in the underlying codec.  The
372    * default if this flag is not specified is implementation-specific.  For
373    * example, the implementation of TurboJPEG for libjpeg[-turbo] uses the fast
374    * algorithm by default when compressing, because this has been shown to have
375    * only a very slight effect on accuracy, but it uses the accurate algorithm
376    * when decompressing, because this has been shown to have a larger effect.
377    */
378   public static final int FLAG_FASTDCT      =  2048;
379   /**
380    * Use the most accurate DCT/IDCT algorithm available in the underlying
381    * codec.  The default if this flag is not specified is
382    * implementation-specific.  For example, the implementation of TurboJPEG for
383    * libjpeg[-turbo] uses the fast algorithm by default when compressing,
384    * because this has been shown to have only a very slight effect on accuracy,
385    * but it uses the accurate algorithm when decompressing, because this has
386    * been shown to have a larger effect.
387    */
388   public static final int FLAG_ACCURATEDCT  =  4096;
389 
390 
391   /**
392    * Returns the maximum size of the buffer (in bytes) required to hold a JPEG
393    * image with the given width, height, and level of chrominance subsampling.
394    *
395    * @param width the width (in pixels) of the JPEG image
396    *
397    * @param height the height (in pixels) of the JPEG image
398    *
399    * @param jpegSubsamp the level of chrominance subsampling to be used when
400    * generating the JPEG image (one of {@link TJ TJ.SAMP_*})
401    *
402    * @return the maximum size of the buffer (in bytes) required to hold a JPEG
403    * image with the given width, height, and level of chrominance subsampling.
404    */
bufSize(int width, int height, int jpegSubsamp)405   public static native int bufSize(int width, int height, int jpegSubsamp);
406 
407   /**
408    * Returns the size of the buffer (in bytes) required to hold a YUV planar
409    * image with the given width, height, and level of chrominance subsampling.
410    *
411    * @param width the width (in pixels) of the YUV image
412    *
413    * @param pad the width of each line in each plane of the image is padded to
414    * the nearest multiple of this number of bytes (must be a power of 2.)
415    *
416    * @param height the height (in pixels) of the YUV image
417    *
418    * @param subsamp the level of chrominance subsampling used in the YUV
419    * image (one of {@link TJ TJ.SAMP_*})
420    *
421    * @return the size of the buffer (in bytes) required to hold a YUV planar
422    * image with the given width, height, and level of chrominance subsampling.
423    */
bufSizeYUV(int width, int pad, int height, int subsamp)424   public static native int bufSizeYUV(int width, int pad, int height,
425                                       int subsamp);
426 
427   /**
428    * @deprecated Use {@link #bufSizeYUV(int, int, int, int)} instead.
429    */
430   @Deprecated
bufSizeYUV(int width, int height, int subsamp)431   public static native int bufSizeYUV(int width, int height, int subsamp);
432 
433   /**
434    * Returns the size of the buffer (in bytes) required to hold a YUV image
435    * plane with the given parameters.
436    *
437    * @param componentID ID number of the image plane (0 = Y, 1 = U/Cb,
438    * 2 = V/Cr)
439    *
440    * @param width width (in pixels) of the YUV image.  NOTE: this is the width
441    * of the whole image, not the plane width.
442    *
443    * @param stride bytes per line in the image plane.
444    *
445    * @param height height (in pixels) of the YUV image.  NOTE: this is the
446    * height of the whole image, not the plane height.
447    *
448    * @param subsamp the level of chrominance subsampling used in the YUV
449    * image (one of {@link TJ TJ.SAMP_*})
450    *
451    * @return the size of the buffer (in bytes) required to hold a YUV planar
452    * image with the given parameters.
453    */
planeSizeYUV(int componentID, int width, int stride, int height, int subsamp)454   public static native int planeSizeYUV(int componentID, int width, int stride,
455                                         int height, int subsamp);
456 
457   /**
458    * Returns the plane width of a YUV image plane with the given parameters.
459    * Refer to {@link YUVImage YUVImage} for a description of plane width.
460    *
461    * @param componentID ID number of the image plane (0 = Y, 1 = U/Cb,
462    * 2 = V/Cr)
463    *
464    * @param width width (in pixels) of the YUV image
465    *
466    * @param subsamp the level of chrominance subsampling used in the YUV image
467    * (one of {@link TJ TJ.SAMP_*})
468    *
469    * @return the plane width of a YUV image plane with the given parameters.
470    */
planeWidth(int componentID, int width, int subsamp)471   public static native int planeWidth(int componentID, int width, int subsamp);
472 
473   /**
474    * Returns the plane height of a YUV image plane with the given parameters.
475    * Refer to {@link YUVImage YUVImage} for a description of plane height.
476    *
477    * @param componentID ID number of the image plane (0 = Y, 1 = U/Cb,
478    * 2 = V/Cr)
479    *
480    * @param height height (in pixels) of the YUV image
481    *
482    * @param subsamp the level of chrominance subsampling used in the YUV image
483    * (one of {@link TJ TJ.SAMP_*})
484    *
485    * @return the plane height of a YUV image plane with the given parameters.
486    */
planeHeight(int componentID, int height, int subsamp)487   public static native int planeHeight(int componentID, int height,
488                                        int subsamp);
489 
490   /**
491    * Returns a list of fractional scaling factors that the JPEG decompressor in
492    * this implementation of TurboJPEG supports.
493    *
494    * @return a list of fractional scaling factors that the JPEG decompressor in
495    * this implementation of TurboJPEG supports.
496    */
getScalingFactors()497   public static native TJScalingFactor[] getScalingFactors();
498 
499   static {
TJLoader.load()500     TJLoader.load();
501   }
502 
checkPixelFormat(int pixelFormat)503   private static void checkPixelFormat(int pixelFormat) {
504     if (pixelFormat < 0 || pixelFormat >= NUMPF)
505       throw new IllegalArgumentException("Invalid pixel format");
506   }
507 
checkSubsampling(int subsamp)508   private static void checkSubsampling(int subsamp) {
509     if (subsamp < 0 || subsamp >= NUMSAMP)
510       throw new IllegalArgumentException("Invalid subsampling type");
511   }
512 
513 }
514