add changelog notes for region_shrink

This commit is contained in:
John Cupitt 2018-06-13 17:36:36 +01:00
parent 8a8a093523
commit a373d2c876
3 changed files with 76 additions and 61 deletions

View File

@ -29,6 +29,7 @@
- make members, getters and operators "const" in cpp API - make members, getters and operators "const" in cpp API
- composite has params for x/y position of sub-images [medakk] - composite has params for x/y position of sub-images [medakk]
- add Mitchell kernel - add Mitchell kernel
- pyramid builders have a choice of 2x2 shrinkers [harukizaemon]
12/3/18 started 8.6.4 12/3/18 started 8.6.4
- better fitting of fonts with overhanging edges [Adrià] - better fitting of fonts with overhanging edges [Adrià]

View File

@ -96,6 +96,9 @@ GType vips_argument_flags_get_type (void) G_GNUC_CONST;
/* enumerations from "../../../libvips/include/vips/operation.h" */ /* enumerations from "../../../libvips/include/vips/operation.h" */
GType vips_operation_flags_get_type (void) G_GNUC_CONST; GType vips_operation_flags_get_type (void) G_GNUC_CONST;
#define VIPS_TYPE_OPERATION_FLAGS (vips_operation_flags_get_type()) #define VIPS_TYPE_OPERATION_FLAGS (vips_operation_flags_get_type())
/* enumerations from "../../../libvips/include/vips/region.h" */
GType vips_region_shrink_get_type (void) G_GNUC_CONST;
#define VIPS_TYPE_REGION_SHRINK (vips_region_shrink_get_type())
/* enumerations from "../../../libvips/include/vips/resample.h" */ /* enumerations from "../../../libvips/include/vips/resample.h" */
GType vips_kernel_get_type (void) G_GNUC_CONST; GType vips_kernel_get_type (void) G_GNUC_CONST;
#define VIPS_TYPE_KERNEL (vips_kernel_get_type()) #define VIPS_TYPE_KERNEL (vips_kernel_get_type())

View File

@ -43,6 +43,8 @@
* - move on top of VipsObject, rename as VipsRegion * - move on top of VipsObject, rename as VipsRegion
* 23/2/17 * 23/2/17
* - multiply transparent images through alpha in vips_region_shrink() * - multiply transparent images through alpha in vips_region_shrink()
* 13/6/18 harukizaemon
* - add VipsRegionShrink parameter to vips_region_shrink()
*/ */
/* /*
@ -1204,65 +1206,6 @@ vips_region_shrink_labpack( VipsRegion *from,
q += ps; \ q += ps; \
} }
/* This method is implemented so as to perform well and to always select an
* output pixel from one of the input pixels. As such we make only the
* following guarantees:
*
* ONLY works for non-complex uncoded images pixel types
* ALWAYS draws from the input values
* NEVER interpolates
* NOT stable with respect to the ordered set of input values
* IS stable with respect to the initial arrangement of input values
*/
#define SHRINK_TYPE_MEDIAN( TYPE ) \
for( x = 0; x < target->width; x++ ) { \
TYPE *tp = (TYPE *) p; \
TYPE *tp1 = (TYPE *) (p + ls); \
TYPE *tq = (TYPE *) q; \
\
for( z = 0; z < nb; z++ ) { \
tq[z] = VIPS_MIN( \
VIPS_MAX( tp[z], tp[z + nb] ), \
VIPS_MAX( tp1[z], tp1[z + nb] ) \
); \
} \
\
/* Move on two pels in input. \
*/ \
p += ps << 1; \
q += ps; \
}
/* This method is implemented so as to perform well and to always select an
* output pixel from one of the input pixels. As such we make only the
* following guarantees:
*
* ONLY works for non-complex uncoded images pixel types
* ALWAYS draws from the input values
* NEVER interpolates
* NOT stable with respect to the ordered set of input values
* IS stable with respect to the initial arrangement of input values
*/
#define SHRINK_TYPE_MODE( TYPE ) \
for( x = 0; x < target->width; x++ ) { \
TYPE *tp = (TYPE *) p; \
TYPE *tp1 = (TYPE *) (p + ls); \
TYPE *tq = (TYPE *) q; \
\
for( z = 0; z < nb; z++ ) { \
TYPE v[] = {tp[z], tp[z + nb], tp1[z], tp1[z + nb]}; \
int b0 = (v[0] == v[1]) | (v[0] == v[2]) | (v[0] == v[3]); \
int b1 = (v[1] == v[0]) | (v[1] == v[2]) | (v[1] == v[3]); \
int index = ((~b0) & 0x1) + (~(b0 ^ b1) & 0x1); \
tq[z] = v[index]; \
} \
\
/* Move on two pels in input. \
*/ \
p += ps << 1; \
q += ps; \
}
/* Generate area @target in @to using pixels in @from. Non-complex. /* Generate area @target in @to using pixels in @from. Non-complex.
*/ */
static void static void
@ -1307,6 +1250,36 @@ vips_region_shrink_uncoded_mean( VipsRegion *from,
} }
} }
/* This method is implemented so as to perform well and to always select an
* output pixel from one of the input pixels. As such we make only the
* following guarantees:
*
* ONLY works for non-complex uncoded images pixel types
* ALWAYS draws from the input values
* NEVER interpolates
* NOT stable with respect to the ordered set of input values
* IS stable with respect to the initial arrangement of input values
*/
#define SHRINK_TYPE_MEDIAN( TYPE ) { \
for( x = 0; x < target->width; x++ ) { \
TYPE *tp = (TYPE *) p; \
TYPE *tp1 = (TYPE *) (p + ls); \
TYPE *tq = (TYPE *) q; \
\
for( z = 0; z < nb; z++ ) { \
tq[z] = VIPS_MIN( \
VIPS_MAX( tp[z], tp[z + nb] ), \
VIPS_MAX( tp1[z], tp1[z + nb] ) \
); \
} \
\
/* Move on two pels in input. \
*/ \
p += ps << 1; \
q += ps; \
} \
}
/* Generate area @target in @to using pixels in @from. Non-complex. /* Generate area @target in @to using pixels in @from. Non-complex.
*/ */
static void static void
@ -1351,6 +1324,42 @@ vips_region_shrink_uncoded_median( VipsRegion *from,
} }
} }
/* This method is implemented so as to perform well and to always select an
* output pixel from one of the input pixels. As such we make only the
* following guarantees:
*
* ONLY works for non-complex uncoded images pixel types
* ALWAYS draws from the input values
* NEVER interpolates
* NOT stable with respect to the ordered set of input values
* IS stable with respect to the initial arrangement of input values
*/
#define SHRINK_TYPE_MODE( TYPE ) { \
for( x = 0; x < target->width; x++ ) { \
TYPE *tp = (TYPE *) p; \
TYPE *tp1 = (TYPE *) (p + ls); \
TYPE *tq = (TYPE *) q; \
\
for( z = 0; z < nb; z++ ) { \
TYPE v[] = {tp[z], tp[z + nb], tp1[z], tp1[z + nb]}; \
int b0 = (v[0] == v[1]) | \
(v[0] == v[2]) | \
(v[0] == v[3]); \
int b1 = (v[1] == v[0]) | \
(v[1] == v[2]) | \
(v[1] == v[3]); \
int index = ((~b0) & 0x1) + (~(b0 ^ b1) & 0x1); \
\
tq[z] = v[index]; \
} \
\
/* Move on two pels in input. \
*/ \
p += ps << 1; \
q += ps; \
} \
}
/* Generate area @target in @to using pixels in @from. Non-complex. /* Generate area @target in @to using pixels in @from. Non-complex.
*/ */
static void static void
@ -1505,12 +1514,14 @@ vips_region_shrink_alpha( VipsRegion *from,
* @from: source region * @from: source region
* @to: (inout): destination region * @to: (inout): destination region
* @target: #VipsRect of pixels you need to copy * @target: #VipsRect of pixels you need to copy
* @method: #VipsRegionShrink method to use when generating target pixels * @method: method to use when generating target pixels
* *
* Write the pixels @target in @to from the x2 larger area in @from. * Write the pixels @target in @to from the x2 larger area in @from.
* Non-complex uncoded images and LABQ only. Images with alpha (see * Non-complex uncoded images and LABQ only. Images with alpha (see
* vips_image_hasalpha()) shrink with pixels scaled by alpha to avoid fringing. * vips_image_hasalpha()) shrink with pixels scaled by alpha to avoid fringing.
* *
* @method selects the method used to do the 2x2 shrink.
*
* See also: vips_region_copy(). * See also: vips_region_copy().
*/ */
int int