Merge branch '8.13'

This commit is contained in:
John Cupitt 2022-08-14 10:31:09 +01:00
commit aa109f102d
3 changed files with 57 additions and 3 deletions

View File

@ -13,6 +13,8 @@ master
- add a summary table at the end of configure in meson - add a summary table at the end of configure in meson
- fix libpng fallback when spng is disabled in meson - fix libpng fallback when spng is disabled in meson
- add "unlimited" to jpegload - add "unlimited" to jpegload
- better 0 detection in unpremultiply
- fix low bitdepth spng save [jeffska]
21/11/21 started 8.13 21/11/21 started 8.13
- configure fails for requested but unmet dependencies [remicollet] - configure fails for requested but unmet dependencies [remicollet]

View File

@ -9,6 +9,8 @@
* - match normalised alpha to output type * - match normalised alpha to output type
* 27/2/21 jjonesrs * 27/2/21 jjonesrs
* - revise range clipping and 1/x, again * - revise range clipping and 1/x, again
* 8/8/22
* - look for alpha near 0, not just exactly 0
*/ */
/* /*
@ -123,6 +125,55 @@ G_DEFINE_TYPE( VipsUnpremultiply, vips_unpremultiply, VIPS_TYPE_CONVERSION );
} \ } \
} }
/* For float-style images, we need to check for alpha near zero, or we'll get
* +/- Inf in the output.
*/
#define FUNPRE_MANY( IN, OUT ) { \
IN * restrict p = (IN *) in; \
OUT * restrict q = (OUT *) out; \
\
for( x = 0; x < width; x++ ) { \
IN alpha = p[alpha_band]; \
OUT factor = VIPS_ABS( alpha ) < 0.01 ? 0 : max_alpha / alpha; \
\
for( i = 0; i < alpha_band; i++ ) \
q[i] = factor * p[i]; \
q[alpha_band] = VIPS_CLIP( 0, alpha, max_alpha ); \
for( i = alpha_band + 1; i < bands; i++ ) \
q[i] = p[i]; \
\
p += bands; \
q += bands; \
} \
}
#define FUNPRE_RGBA( IN, OUT ) { \
IN * restrict p = (IN *) in; \
OUT * restrict q = (OUT *) out; \
\
for( x = 0; x < width; x++ ) { \
IN alpha = p[3]; \
OUT factor = VIPS_ABS( alpha ) < 0.01 ? 0 : max_alpha / alpha; \
\
q[0] = factor * p[0]; \
q[1] = factor * p[1]; \
q[2] = factor * p[2]; \
q[3] = VIPS_CLIP( 0, alpha, max_alpha ); \
\
p += 4; \
q += 4; \
} \
}
#define FUNPRE( IN, OUT ) { \
if( bands == 4 ) { \
FUNPRE_RGBA( IN, OUT ); \
} \
else { \
FUNPRE_MANY( IN, OUT ); \
} \
}
static int static int
vips_unpremultiply_gen( VipsRegion *or, void *vseq, void *a, void *b, vips_unpremultiply_gen( VipsRegion *or, void *vseq, void *a, void *b,
gboolean *stop ) gboolean *stop )
@ -171,11 +222,11 @@ vips_unpremultiply_gen( VipsRegion *or, void *vseq, void *a, void *b,
break; break;
case VIPS_FORMAT_FLOAT: case VIPS_FORMAT_FLOAT:
UNPRE( float, float ); FUNPRE( float, float );
break; break;
case VIPS_FORMAT_DOUBLE: case VIPS_FORMAT_DOUBLE:
UNPRE( double, double ); FUNPRE( double, double );
break; break;
case VIPS_FORMAT_COMPLEX: case VIPS_FORMAT_COMPLEX:

View File

@ -270,6 +270,7 @@ vips_foreign_save_spng_pack( VipsForeignSaveSpng *spng,
VipsPel *q, VipsPel *p, size_t n ) VipsPel *q, VipsPel *p, size_t n )
{ {
int pixel_mask = 8 / spng->bitdepth - 1; int pixel_mask = 8 / spng->bitdepth - 1;
int shift = 8 - spng->bitdepth;
VipsPel bits; VipsPel bits;
size_t x; size_t x;
@ -277,7 +278,7 @@ vips_foreign_save_spng_pack( VipsForeignSaveSpng *spng,
bits = 0; bits = 0;
for( x = 0; x < n; x++ ) { for( x = 0; x < n; x++ ) {
bits <<= spng->bitdepth; bits <<= spng->bitdepth;
bits |= p[x]; bits |= p[x] >> shift;
if( (x & pixel_mask) == pixel_mask ) if( (x & pixel_mask) == pixel_mask )
*q++ = bits; *q++ = bits;