revise formatting, add docs
fix up some formatting from https://github.com/libvips/libvips/pull/1552 plus some other small changes
This commit is contained in:
parent
fefefdf3e2
commit
0a23bf3578
@ -11,6 +11,7 @@
|
|||||||
- add vips_pipe_read_limit_set(), --vips-pipe-read-limit,
|
- add vips_pipe_read_limit_set(), --vips-pipe-read-limit,
|
||||||
VIPS_PIPE_READ_LIMIT
|
VIPS_PIPE_READ_LIMIT
|
||||||
- revise gifload to fix BACKGROUND and PREVIOUS dispose [alon-ne]
|
- revise gifload to fix BACKGROUND and PREVIOUS dispose [alon-ne]
|
||||||
|
- add subsample_mode, deprecate no_subsample in jpegsave [Elad-Laufer]
|
||||||
|
|
||||||
31/1/19 started 8.9.2
|
31/1/19 started 8.9.2
|
||||||
- fix a deadlock with --vips-leak [DarthSim]
|
- fix a deadlock with --vips-leak [DarthSim]
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
*
|
*
|
||||||
* 24/11/11
|
* 24/11/11
|
||||||
* - wrap a class around the jpeg writer
|
* - wrap a class around the jpeg writer
|
||||||
|
* 18/2/20 Elad-Laufer
|
||||||
|
* - add subsample_mode, deprecate no_subsample
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -77,12 +79,12 @@ typedef struct _VipsForeignSaveJpeg {
|
|||||||
*/
|
*/
|
||||||
gboolean no_subsample;
|
gboolean no_subsample;
|
||||||
|
|
||||||
/* Select chroma subsampling mode:
|
/* Select chroma subsampling mode:
|
||||||
* auto will disable subsampling for Q >= 90
|
* auto will disable subsampling for Q >= 90
|
||||||
* on will always enable subsampling
|
* on will always enable subsampling
|
||||||
* off will always disable subsampling
|
* off will always disable subsampling
|
||||||
*/
|
*/
|
||||||
VipsForeignJpegSubsample subsample_mode;
|
VipsForeignJpegSubsample subsample_mode;
|
||||||
|
|
||||||
/* Apply trellis quantisation to each 8x8 block.
|
/* Apply trellis quantisation to each 8x8 block.
|
||||||
*/
|
*/
|
||||||
@ -113,26 +115,28 @@ G_DEFINE_ABSTRACT_TYPE( VipsForeignSaveJpeg, vips_foreign_save_jpeg,
|
|||||||
/* Type promotion for save ... just always go to uchar.
|
/* Type promotion for save ... just always go to uchar.
|
||||||
*/
|
*/
|
||||||
static int bandfmt_jpeg[10] = {
|
static int bandfmt_jpeg[10] = {
|
||||||
/* UC C US S UI I F X D DX */
|
/* UC C US S UI I F X D DX */
|
||||||
UC, UC, UC, UC, UC, UC, UC, UC, UC, UC
|
UC, UC, UC, UC, UC, UC, UC, UC, UC, UC
|
||||||
};
|
};
|
||||||
|
|
||||||
static int
|
static int
|
||||||
vips_foreign_save_jpeg_build( VipsObject *object )
|
vips_foreign_save_jpeg_build( VipsObject *object )
|
||||||
{
|
{
|
||||||
VipsForeignSaveJpeg *jpeg = (VipsForeignSaveJpeg *) object;
|
VipsForeignSaveJpeg *jpeg = (VipsForeignSaveJpeg *) object;
|
||||||
|
|
||||||
if( VIPS_OBJECT_CLASS( vips_foreign_save_jpeg_parent_class )->
|
if( VIPS_OBJECT_CLASS( vips_foreign_save_jpeg_parent_class )->
|
||||||
build( object ) )
|
build( object ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
/* no_subsample is deprecated, but we retain backwards compatibility
|
/* no_subsample is deprecated, but we retain backwards compatibility
|
||||||
* new code should use subsample_mode
|
* new code should use subsample_mode
|
||||||
*/
|
*/
|
||||||
if( vips_object_argument_isset(object, "no_subsample") )
|
if( vips_object_argument_isset( object, "no_subsample" ) )
|
||||||
jpeg->subsample_mode = jpeg->no_subsample ? VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF : VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO;
|
jpeg->subsample_mode = jpeg->no_subsample ?
|
||||||
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF :
|
||||||
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO;
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -148,7 +152,7 @@ vips_foreign_save_jpeg_class_init( VipsForeignSaveJpegClass *class )
|
|||||||
|
|
||||||
object_class->nickname = "jpegsave_base";
|
object_class->nickname = "jpegsave_base";
|
||||||
object_class->description = _( "save jpeg" );
|
object_class->description = _( "save jpeg" );
|
||||||
object_class->build = vips_foreign_save_jpeg_build;
|
object_class->build = vips_foreign_save_jpeg_build;
|
||||||
|
|
||||||
foreign_class->suffs = vips__jpeg_suffs;
|
foreign_class->suffs = vips__jpeg_suffs;
|
||||||
|
|
||||||
@ -220,19 +224,20 @@ vips_foreign_save_jpeg_class_init( VipsForeignSaveJpegClass *class )
|
|||||||
G_STRUCT_OFFSET( VipsForeignSaveJpeg, quant_table ),
|
G_STRUCT_OFFSET( VipsForeignSaveJpeg, quant_table ),
|
||||||
0, 8, 0 );
|
0, 8, 0 );
|
||||||
|
|
||||||
VIPS_ARG_ENUM( class, "subsample_mode", 19,
|
VIPS_ARG_ENUM( class, "subsample_mode", 19,
|
||||||
_( "Subsample mode" ),
|
_( "Subsample mode" ),
|
||||||
_( "Select chroma subsample operation mode" ),
|
_( "Select chroma subsample operation mode" ),
|
||||||
VIPS_ARGUMENT_OPTIONAL_INPUT,
|
VIPS_ARGUMENT_OPTIONAL_INPUT,
|
||||||
G_STRUCT_OFFSET( VipsForeignSaveJpeg, subsample_mode ),
|
G_STRUCT_OFFSET( VipsForeignSaveJpeg, subsample_mode ),
|
||||||
VIPS_TYPE_FOREIGN_JPEG_SUBSAMPLE,
|
VIPS_TYPE_FOREIGN_JPEG_SUBSAMPLE,
|
||||||
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO );
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO );
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
vips_foreign_save_jpeg_init( VipsForeignSaveJpeg *jpeg )
|
vips_foreign_save_jpeg_init( VipsForeignSaveJpeg *jpeg )
|
||||||
{
|
{
|
||||||
jpeg->Q = 75;
|
jpeg->Q = 75;
|
||||||
|
jpeg->subsample_mode = VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct _VipsForeignSaveJpegTarget {
|
typedef struct _VipsForeignSaveJpegTarget {
|
||||||
@ -524,7 +529,7 @@ vips_foreign_save_jpeg_mime_init( VipsForeignSaveJpegMime *mime )
|
|||||||
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
||||||
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
||||||
* * @strip: %gboolean, remove all metadata from image
|
* * @strip: %gboolean, remove all metadata from image
|
||||||
* * @no_subsample: %gboolean, disable chroma subsampling
|
* * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
|
||||||
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
||||||
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
||||||
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
||||||
@ -552,8 +557,8 @@ vips_foreign_save_jpeg_mime_init( VipsForeignSaveJpegMime *mime )
|
|||||||
* If @strip is set, no EXIF data, IPTC data, ICC profile or XMP metadata is
|
* If @strip is set, no EXIF data, IPTC data, ICC profile or XMP metadata is
|
||||||
* written into the output file.
|
* written into the output file.
|
||||||
*
|
*
|
||||||
* If @no_subsample is set, chrominance subsampling is disabled. This will
|
* Chroma subsampling is normally automatically disabled for Q > 90. You can
|
||||||
* improve quality at the cost of larger file size. Useful for high Q factors.
|
* force the subsampling mode with @@subsample_mode.
|
||||||
*
|
*
|
||||||
* If @trellis_quant is set and the version of libjpeg supports it
|
* If @trellis_quant is set and the version of libjpeg supports it
|
||||||
* (e.g. mozjpeg >= 3.0), apply trellis quantisation to each 8x8 block.
|
* (e.g. mozjpeg >= 3.0), apply trellis quantisation to each 8x8 block.
|
||||||
@ -640,7 +645,7 @@ vips_jpegsave( VipsImage *in, const char *filename, ... )
|
|||||||
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
||||||
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
||||||
* * @strip: %gboolean, remove all metadata from image
|
* * @strip: %gboolean, remove all metadata from image
|
||||||
* * @no_subsample: %gboolean, disable chroma subsampling
|
* * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
|
||||||
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
||||||
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
||||||
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
||||||
@ -679,7 +684,7 @@ vips_jpegsave_target( VipsImage *in, VipsTarget *target, ... )
|
|||||||
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
||||||
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
||||||
* * @strip: %gboolean, remove all metadata from image
|
* * @strip: %gboolean, remove all metadata from image
|
||||||
* * @no_subsample: %gboolean, disable chroma subsampling
|
* * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
|
||||||
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
||||||
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
||||||
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
||||||
@ -735,7 +740,7 @@ vips_jpegsave_buffer( VipsImage *in, void **buf, size_t *len, ... )
|
|||||||
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
* * @optimize_coding: %gboolean, compute optimal Huffman coding tables
|
||||||
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
* * @interlace: %gboolean, write an interlaced (progressive) jpeg
|
||||||
* * @strip: %gboolean, remove all metadata from image
|
* * @strip: %gboolean, remove all metadata from image
|
||||||
* * @no_subsample: %gboolean, disable chroma subsampling
|
* * @subsample_mode: #VipsForeignJpegSubsample, chroma subsampling mode
|
||||||
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
* * @trellis_quant: %gboolean, apply trellis quantisation to each 8x8 block
|
||||||
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
* * @overshoot_deringing: %gboolean, overshoot samples with extreme values
|
||||||
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
* * @optimize_scans: %gboolean, split DCT coefficients into separate scans
|
||||||
|
@ -49,7 +49,7 @@ void vips__tiff_init( void );
|
|||||||
|
|
||||||
int vips__tiff_write( VipsImage *in, const char *filename,
|
int vips__tiff_write( VipsImage *in, const char *filename,
|
||||||
VipsForeignTiffCompression compression, int Q,
|
VipsForeignTiffCompression compression, int Q,
|
||||||
VipsForeignTiffPredictor predictor,
|
VipsForeignTiffPredictor predictor,
|
||||||
char *profile,
|
char *profile,
|
||||||
gboolean tile, int tile_width, int tile_height,
|
gboolean tile, int tile_width, int tile_height,
|
||||||
gboolean pyramid,
|
gboolean pyramid,
|
||||||
|
@ -92,6 +92,8 @@
|
|||||||
* - ignore large XMP
|
* - ignore large XMP
|
||||||
* 14/10/19
|
* 14/10/19
|
||||||
* - revise for target IO
|
* - revise for target IO
|
||||||
|
* 18/2/20 Elad-Laufer
|
||||||
|
* - add subsample_mode, deprecate no_subsample
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -481,7 +483,7 @@ write_vips( Write *write, int qfac, const char *profile,
|
|||||||
gboolean optimize_coding, gboolean progressive, gboolean strip,
|
gboolean optimize_coding, gboolean progressive, gboolean strip,
|
||||||
gboolean trellis_quant, gboolean overshoot_deringing,
|
gboolean trellis_quant, gboolean overshoot_deringing,
|
||||||
gboolean optimize_scans, int quant_table,
|
gboolean optimize_scans, int quant_table,
|
||||||
VipsForeignJpegSubsample subsample_mode)
|
VipsForeignJpegSubsample subsample_mode )
|
||||||
{
|
{
|
||||||
VipsImage *in;
|
VipsImage *in;
|
||||||
J_COLOR_SPACE space;
|
J_COLOR_SPACE space;
|
||||||
@ -628,24 +630,15 @@ write_vips( Write *write, int qfac, const char *profile,
|
|||||||
if( progressive )
|
if( progressive )
|
||||||
jpeg_simple_progression( &write->cinfo );
|
jpeg_simple_progression( &write->cinfo );
|
||||||
|
|
||||||
switch ( subsample_mode ) {
|
if( subsample_mode == VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF ||
|
||||||
case VIPS_FOREIGN_JPEG_SUBSAMPLE_ON:
|
(subsample_mode == VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO &&
|
||||||
break;
|
qfac >= 90) ) {
|
||||||
case VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO:
|
int i;
|
||||||
/* Turn off chroma subsampling. Follow IM and do it automatically for
|
|
||||||
* high Q.
|
for( i = 0; i < in->Bands; i++ ) {
|
||||||
*/
|
write->cinfo.comp_info[i].h_samp_factor = 1;
|
||||||
if( qfac < 90 )
|
write->cinfo.comp_info[i].v_samp_factor = 1;
|
||||||
break;
|
}
|
||||||
case VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF:
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for ( i = 0; i < in->Bands; i++ ) {
|
|
||||||
write->cinfo.comp_info[i].h_samp_factor = 1;
|
|
||||||
write->cinfo.comp_info[i].v_samp_factor = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Don't write the APP0 JFIF headers if we are stripping.
|
/* Don't write the APP0 JFIF headers if we are stripping.
|
||||||
@ -783,8 +776,8 @@ vips__jpeg_write_target( VipsImage *in, VipsTarget *target,
|
|||||||
int Q, const char *profile,
|
int Q, const char *profile,
|
||||||
gboolean optimize_coding, gboolean progressive,
|
gboolean optimize_coding, gboolean progressive,
|
||||||
gboolean strip, gboolean trellis_quant,
|
gboolean strip, gboolean trellis_quant,
|
||||||
gboolean overshoot_deringing, gboolean optimize_scans,
|
gboolean overshoot_deringing, gboolean optimize_scans,
|
||||||
int quant_table, VipsForeignJpegSubsample subsample_mode)
|
int quant_table, VipsForeignJpegSubsample subsample_mode)
|
||||||
{
|
{
|
||||||
Write *write;
|
Write *write;
|
||||||
|
|
||||||
|
@ -369,11 +369,14 @@ int vips_openslideload( const char *filename, VipsImage **out, ... )
|
|||||||
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO: default preset
|
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO: default preset
|
||||||
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_ON: always perform subsampling
|
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_ON: always perform subsampling
|
||||||
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF: never perform subsampling
|
* @VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF: never perform subsampling
|
||||||
|
*
|
||||||
|
* Set jpeg subsampling mode.
|
||||||
*/
|
*/
|
||||||
typedef enum {
|
typedef enum {
|
||||||
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO,
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO,
|
||||||
VIPS_FOREIGN_JPEG_SUBSAMPLE_ON,
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_ON,
|
||||||
VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF,
|
||||||
|
VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST
|
||||||
} VipsForeignJpegSubsample;
|
} VipsForeignJpegSubsample;
|
||||||
|
|
||||||
int vips_jpegload( const char *filename, VipsImage **out, ... )
|
int vips_jpegload( const char *filename, VipsImage **out, ... )
|
||||||
|
@ -508,6 +508,7 @@ vips_foreign_jpeg_subsample_get_type( void )
|
|||||||
{VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO, "VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO", "auto"},
|
{VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO, "VIPS_FOREIGN_JPEG_SUBSAMPLE_AUTO", "auto"},
|
||||||
{VIPS_FOREIGN_JPEG_SUBSAMPLE_ON, "VIPS_FOREIGN_JPEG_SUBSAMPLE_ON", "on"},
|
{VIPS_FOREIGN_JPEG_SUBSAMPLE_ON, "VIPS_FOREIGN_JPEG_SUBSAMPLE_ON", "on"},
|
||||||
{VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF, "VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF", "off"},
|
{VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF, "VIPS_FOREIGN_JPEG_SUBSAMPLE_OFF", "off"},
|
||||||
|
{VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST, "VIPS_FOREIGN_JPEG_SUBSAMPLE_LAST", "last"},
|
||||||
{0, NULL, NULL}
|
{0, NULL, NULL}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user