stuff
This commit is contained in:
parent
64eaeeb6c3
commit
8200afcbb6
4
TODO
4
TODO
@ -2,6 +2,10 @@
|
|||||||
|
|
||||||
avg is different? used to 120.134, now 120.151
|
avg is different? used to 120.134, now 120.151
|
||||||
|
|
||||||
|
- segment should be in morph
|
||||||
|
|
||||||
|
- insertplaceset should be with insert in conversion
|
||||||
|
|
||||||
- _raw() variants should be deprecated?
|
- _raw() variants should be deprecated?
|
||||||
|
|
||||||
- look through more sections for stuff in the wrong place
|
- look through more sections for stuff in the wrong place
|
||||||
|
@ -53,11 +53,11 @@
|
|||||||
<xi:include href="xml/other.xml"/>
|
<xi:include href="xml/other.xml"/>
|
||||||
<xi:include href="xml/video.xml"/>
|
<xi:include href="xml/video.xml"/>
|
||||||
<xi:include href="xml/cimg_funcs.xml"/>
|
<xi:include href="xml/cimg_funcs.xml"/>
|
||||||
|
<xi:include href="xml/interpolate.xml"/>
|
||||||
</chapter>
|
</chapter>
|
||||||
|
|
||||||
<chapter>
|
<chapter>
|
||||||
<title>Other API (no gtkdoc comments yet)</title>
|
<title>Other API (no gtkdoc comments yet)</title>
|
||||||
<xi:include href="xml/interpolate.xml"/>
|
|
||||||
<xi:include href="xml/object.xml"/>
|
<xi:include href="xml/object.xml"/>
|
||||||
<xi:include href="xml/transform.xml"/>
|
<xi:include href="xml/transform.xml"/>
|
||||||
<xi:include href="xml/util.xml"/>
|
<xi:include href="xml/util.xml"/>
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
#include <vips/vips.h>
|
#include <vips/vips.h>
|
||||||
#include <vips/vips.h>
|
#include <vips/internal.h>
|
||||||
|
|
||||||
#ifdef WITH_DMALLOC
|
#ifdef WITH_DMALLOC
|
||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
|
@ -9,6 +9,7 @@ libdeprecated_la_SOURCES = \
|
|||||||
im_printlines.c \
|
im_printlines.c \
|
||||||
im_convsub.c \
|
im_convsub.c \
|
||||||
im_line.c \
|
im_line.c \
|
||||||
|
im_resize_linear.c \
|
||||||
im_debugim.c \
|
im_debugim.c \
|
||||||
im_gfadd.c \
|
im_gfadd.c \
|
||||||
im_setbox.c \
|
im_setbox.c \
|
||||||
|
@ -723,9 +723,41 @@ static im_function line_desc = {
|
|||||||
line_args /* Arg list */
|
line_args /* Arg list */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Args for im_resize_linear.
|
||||||
|
*/
|
||||||
|
static im_arg_desc resize_linear_args[] = {
|
||||||
|
IM_INPUT_IMAGE( "in" ),
|
||||||
|
IM_OUTPUT_IMAGE( "out" ),
|
||||||
|
IM_INPUT_INT( "X" ),
|
||||||
|
IM_INPUT_INT( "Y" )
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Call im_resize_linear via arg vector.
|
||||||
|
*/
|
||||||
|
static int
|
||||||
|
resize_linear_vec( im_object *argv )
|
||||||
|
{
|
||||||
|
int X = *((int *) argv[2]);
|
||||||
|
int Y = *((int *) argv[3]);
|
||||||
|
|
||||||
|
return( im_resize_linear( argv[0], argv[1], X, Y ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Description of im_resize_linear.
|
||||||
|
*/
|
||||||
|
static im_function resize_linear_desc = {
|
||||||
|
"im_resize_linear", /* Name */
|
||||||
|
"resize to X by Y pixels with linear interpolation",
|
||||||
|
0, /* Flags */
|
||||||
|
resize_linear_vec, /* Dispatch function */
|
||||||
|
IM_NUMBER( resize_linear_args ), /* Size of arg list */
|
||||||
|
resize_linear_args /* Arg list */
|
||||||
|
};
|
||||||
|
|
||||||
/* Package up all these functions.
|
/* Package up all these functions.
|
||||||
*/
|
*/
|
||||||
static im_function *deprecated_list[] = {
|
static im_function *deprecated_list[] = {
|
||||||
|
&resize_linear_desc,
|
||||||
&cmulnorm_desc,
|
&cmulnorm_desc,
|
||||||
&remainderconst_vec_desc,
|
&remainderconst_vec_desc,
|
||||||
&fav4_desc,
|
&fav4_desc,
|
||||||
|
@ -347,6 +347,8 @@ int im_convsub( IMAGE *in, IMAGE *out, INTMASK *mask, int xskip, int yskip );
|
|||||||
|
|
||||||
int im_bernd( const char *tiffname, int x, int y, int w, int h );
|
int im_bernd( const char *tiffname, int x, int y, int w, int h );
|
||||||
|
|
||||||
|
int im_resize_linear( IMAGE *, IMAGE *, int, int );
|
||||||
|
|
||||||
int im_line( IMAGE *, int, int, int, int, int );
|
int im_line( IMAGE *, int, int, int, int, int );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -226,6 +226,25 @@ void imb_Lab2LabQ( float *, PEL *, int );
|
|||||||
void imb_LabS2Lab( signed short *, float *, int );
|
void imb_LabS2Lab( signed short *, float *, int );
|
||||||
void imb_Lab2LabS( float *, signed short *, int n );
|
void imb_Lab2LabS( float *, signed short *, int n );
|
||||||
|
|
||||||
|
void im_copy_dmask_matrix( DOUBLEMASK *mask, double **matrix );
|
||||||
|
void im_copy_matrix_dmask( double **matrix, DOUBLEMASK *mask );
|
||||||
|
|
||||||
|
int *im_ivector();
|
||||||
|
float *im_fvector();
|
||||||
|
double *im_dvector();
|
||||||
|
void im_free_ivector();
|
||||||
|
void im_free_fvector();
|
||||||
|
void im_free_dvector();
|
||||||
|
|
||||||
|
int **im_imat_alloc();
|
||||||
|
float **im_fmat_alloc();
|
||||||
|
double **im_dmat_alloc();
|
||||||
|
void im_free_imat();
|
||||||
|
void im_free_fmat();
|
||||||
|
void im_free_dmat();
|
||||||
|
|
||||||
|
int im_invmat( double **, int );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /*__cplusplus*/
|
#endif /*__cplusplus*/
|
||||||
|
@ -55,26 +55,11 @@ typedef struct im__DOUBLEMASK {
|
|||||||
char *filename;
|
char *filename;
|
||||||
} DOUBLEMASK;
|
} DOUBLEMASK;
|
||||||
|
|
||||||
void im_copy_dmask_matrix( DOUBLEMASK *mask, double **matrix );
|
|
||||||
void im_copy_matrix_dmask( double **matrix, DOUBLEMASK *mask );
|
|
||||||
|
|
||||||
INTMASK *im_create_imask( const char *name, int width, int height );
|
INTMASK *im_create_imask( const char *name, int width, int height );
|
||||||
INTMASK *im_create_imaskv( const char *name, int width, int height, ... );
|
INTMASK *im_create_imaskv( const char *name, int width, int height, ... );
|
||||||
DOUBLEMASK *im_create_dmask( const char *name, int width, int height );
|
DOUBLEMASK *im_create_dmask( const char *name, int width, int height );
|
||||||
DOUBLEMASK *im_create_dmaskv( const char *name, int width, int height, ... );
|
DOUBLEMASK *im_create_dmaskv( const char *name, int width, int height, ... );
|
||||||
|
|
||||||
INTMASK *im_log_imask( const char *name, double, double );
|
|
||||||
DOUBLEMASK *im_log_dmask( const char *name, double, double );
|
|
||||||
INTMASK *im_gauss_imask( const char *name, double, double );
|
|
||||||
INTMASK *im_gauss_imask_sep( const char *name, double, double );
|
|
||||||
DOUBLEMASK *im_gauss_dmask( const char *name, double, double );
|
|
||||||
|
|
||||||
INTMASK *im_dup_imask( INTMASK *m, const char *name );
|
|
||||||
DOUBLEMASK *im_dup_dmask( DOUBLEMASK *m, const char *name );
|
|
||||||
|
|
||||||
int im_free_imask( INTMASK *m );
|
|
||||||
int im_free_dmask( DOUBLEMASK *m );
|
|
||||||
|
|
||||||
INTMASK *im_read_imask( const char *filename );
|
INTMASK *im_read_imask( const char *filename );
|
||||||
DOUBLEMASK *im_read_dmask( const char *filename );
|
DOUBLEMASK *im_read_dmask( const char *filename );
|
||||||
|
|
||||||
@ -86,40 +71,38 @@ int im_write_dmask( DOUBLEMASK *m );
|
|||||||
int im_write_imask_name( INTMASK *m, const char *filename );
|
int im_write_imask_name( INTMASK *m, const char *filename );
|
||||||
int im_write_dmask_name( DOUBLEMASK *m, const char *filename );
|
int im_write_dmask_name( DOUBLEMASK *m, const char *filename );
|
||||||
|
|
||||||
INTMASK *im_scale_dmask( DOUBLEMASK *m, const char *name );
|
int im_free_imask( INTMASK *m );
|
||||||
void im_norm_dmask( DOUBLEMASK *mask );
|
int im_free_dmask( DOUBLEMASK *m );
|
||||||
int *im_offsets45( int );
|
|
||||||
int *im_offsets90( int );
|
|
||||||
INTMASK *im_rotate_imask90( INTMASK *m, const char *name );
|
|
||||||
INTMASK *im_rotate_imask45( INTMASK *m, const char *name );
|
|
||||||
DOUBLEMASK *im_rotate_dmask90( DOUBLEMASK *m, const char *name );
|
|
||||||
DOUBLEMASK *im_rotate_dmask45( DOUBLEMASK *m, const char *name );
|
|
||||||
|
|
||||||
DOUBLEMASK *im_mattrn( DOUBLEMASK *, const char * );
|
INTMASK *im_log_imask( const char *filename, double sigma, double min_ampl );
|
||||||
DOUBLEMASK *im_matcat( DOUBLEMASK *, DOUBLEMASK *, const char * );
|
DOUBLEMASK *im_log_dmask( const char *filename, double sigma, double min_ampl );
|
||||||
DOUBLEMASK *im_matmul( DOUBLEMASK *, DOUBLEMASK *, const char * );
|
INTMASK *im_gauss_imask( const char *filename, double sigma, double min_ampl );
|
||||||
|
INTMASK *im_gauss_imask_sep( const char *filename,
|
||||||
|
double sigma, double min_ampl );
|
||||||
|
DOUBLEMASK *im_gauss_dmask( const char *filename,
|
||||||
|
double sigma, double min_ampl );
|
||||||
|
|
||||||
|
INTMASK *im_dup_imask( INTMASK *m, const char *name );
|
||||||
|
DOUBLEMASK *im_dup_dmask( DOUBLEMASK *m, const char *name );
|
||||||
|
|
||||||
|
INTMASK *im_scale_dmask( DOUBLEMASK *m, const char *filename );
|
||||||
|
void im_norm_dmask( DOUBLEMASK *mask );
|
||||||
|
int *im_offsets45( int size );
|
||||||
|
int *im_offsets90( int size );
|
||||||
|
INTMASK *im_rotate_imask90( INTMASK *m, const char *filename );
|
||||||
|
INTMASK *im_rotate_imask45( INTMASK *m, const char *filename );
|
||||||
|
DOUBLEMASK *im_rotate_dmask90( DOUBLEMASK *m, const char *filename );
|
||||||
|
DOUBLEMASK *im_rotate_dmask45( DOUBLEMASK *m, const char *filename );
|
||||||
|
|
||||||
|
DOUBLEMASK *im_mattrn( DOUBLEMASK *in, const char *name );
|
||||||
|
DOUBLEMASK *im_matcat( DOUBLEMASK *in1, DOUBLEMASK *in2, const char *name );
|
||||||
|
DOUBLEMASK *im_matmul( DOUBLEMASK *in1, DOUBLEMASK *in2, const char *name );
|
||||||
|
|
||||||
DOUBLEMASK *im_lu_decomp( const DOUBLEMASK *mat, const char *name );
|
DOUBLEMASK *im_lu_decomp( const DOUBLEMASK *mat, const char *name );
|
||||||
int im_lu_solve( const DOUBLEMASK *lu, double *vec );
|
int im_lu_solve( const DOUBLEMASK *lu, double *vec );
|
||||||
DOUBLEMASK *im_matinv( const DOUBLEMASK *mat, const char *name );
|
DOUBLEMASK *im_matinv( const DOUBLEMASK *mat, const char *name );
|
||||||
int im_matinv_inplace( DOUBLEMASK *mat );
|
int im_matinv_inplace( DOUBLEMASK *mat );
|
||||||
|
|
||||||
int *im_ivector();
|
|
||||||
float *im_fvector();
|
|
||||||
double *im_dvector();
|
|
||||||
void im_free_ivector();
|
|
||||||
void im_free_fvector();
|
|
||||||
void im_free_dvector();
|
|
||||||
|
|
||||||
int **im_imat_alloc();
|
|
||||||
float **im_fmat_alloc();
|
|
||||||
double **im_dmat_alloc();
|
|
||||||
void im_free_imat();
|
|
||||||
void im_free_fmat();
|
|
||||||
void im_free_dmat();
|
|
||||||
|
|
||||||
int im_invmat( double **, int );
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /*__cplusplus*/
|
#endif /*__cplusplus*/
|
||||||
|
@ -42,14 +42,13 @@ int im_dilate_raw( IMAGE *in, IMAGE *out, INTMASK *m );
|
|||||||
int im_erode( IMAGE *in, IMAGE *out, INTMASK *m );
|
int im_erode( IMAGE *in, IMAGE *out, INTMASK *m );
|
||||||
int im_erode_raw( IMAGE *in, IMAGE *out, INTMASK *m );
|
int im_erode_raw( IMAGE *in, IMAGE *out, INTMASK *m );
|
||||||
|
|
||||||
int im_rank( IMAGE *in, IMAGE *out, int width, int height, int rank );
|
int im_rank( IMAGE *in, IMAGE *out, int xsize, int ysize, int order );
|
||||||
int im_rank_raw( IMAGE *in, IMAGE *out, int xsize, int ysize, int n );
|
int im_rank_raw( IMAGE *in, IMAGE *out, int xsize, int ysize, int order );
|
||||||
int im_rank_image( IMAGE **in, IMAGE *out, int n, int index );
|
int im_rank_image( IMAGE **in, IMAGE *out, int n, int index );
|
||||||
int im_maxvalue( IMAGE **in, IMAGE *out, int n );
|
int im_maxvalue( IMAGE **in, IMAGE *out, int n );
|
||||||
|
|
||||||
int im_cntlines( IMAGE *im, double *nolines, int flag );
|
int im_cntlines( IMAGE *im, double *nolines, int flag );
|
||||||
int im_zerox( IMAGE *, IMAGE *, int );
|
int im_zerox( IMAGE *in, IMAGE *out, int flag );
|
||||||
|
|
||||||
int im_profile( IMAGE *in, IMAGE *out, int dir );
|
int im_profile( IMAGE *in, IMAGE *out, int dir );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@ -37,6 +37,18 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif /*__cplusplus*/
|
#endif /*__cplusplus*/
|
||||||
|
|
||||||
|
int im_affinei( IMAGE *in, IMAGE *out,
|
||||||
|
VipsInterpolate *interpolate,
|
||||||
|
double a, double b, double c, double d, double dx, double dy,
|
||||||
|
int ox, int oy, int ow, int oh );
|
||||||
|
int im_affinei_all( IMAGE *in, IMAGE *out, VipsInterpolate *interpolate,
|
||||||
|
double a, double b, double c, double d, double dx, double dy ) ;
|
||||||
|
|
||||||
|
int im_stretch3( IMAGE *in, IMAGE *out, double dx, double dy );
|
||||||
|
|
||||||
|
int im_shrink( IMAGE *in, IMAGE *out, double xshrink, double yshrink );
|
||||||
|
int im_rightshift_size( IMAGE *in, IMAGE *out, int xshift, int yshift, int band_fmt );
|
||||||
|
|
||||||
int im_match_linear( IMAGE *ref, IMAGE *sec, IMAGE *out,
|
int im_match_linear( IMAGE *ref, IMAGE *sec, IMAGE *out,
|
||||||
int xr1, int yr1, int xs1, int ys1,
|
int xr1, int yr1, int xs1, int ys1,
|
||||||
int xr2, int yr2, int xs2, int ys2 );
|
int xr2, int yr2, int xs2, int ys2 );
|
||||||
@ -45,19 +57,6 @@ int im_match_linear_search( IMAGE *ref, IMAGE *sec, IMAGE *out,
|
|||||||
int xr2, int yr2, int xs2, int ys2,
|
int xr2, int yr2, int xs2, int ys2,
|
||||||
int hwindowsize, int hsearchsize );
|
int hwindowsize, int hsearchsize );
|
||||||
|
|
||||||
int im_affinei( IMAGE *in, IMAGE *out,
|
|
||||||
VipsInterpolate *interpolate,
|
|
||||||
double a, double b, double c, double d, double dx, double dy,
|
|
||||||
int ox, int oy, int ow, int oh );
|
|
||||||
int im_affinei_all( IMAGE *in, IMAGE *out, VipsInterpolate *interpolate,
|
|
||||||
double a, double b, double c, double d, double dx, double dy ) ;
|
|
||||||
|
|
||||||
int im_resize_linear( IMAGE *, IMAGE *, int, int );
|
|
||||||
int im_stretch3( IMAGE *in, IMAGE *out, double dx, double dy );
|
|
||||||
int im_shrink( IMAGE *, IMAGE *, double, double );
|
|
||||||
|
|
||||||
int im_rightshift_size( IMAGE *in, IMAGE *out, int xshift, int yshift, int band_fmt );
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /*__cplusplus*/
|
#endif /*__cplusplus*/
|
||||||
|
@ -42,6 +42,19 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: mask
|
||||||
|
* @short_description: load, save and process mask (matrix) objects
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* These operations load, save and process mask objects. Masks are used as
|
||||||
|
* paramaters to convolution and morphology operators, and to represent
|
||||||
|
* matrices.
|
||||||
|
*
|
||||||
|
* This API is horrible and clunky. Surely it will be replaced soon.
|
||||||
|
*/
|
||||||
|
|
||||||
/* One matrix in, one out.
|
/* One matrix in, one out.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc one_in_one_out[] = {
|
static im_arg_desc one_in_one_out[] = {
|
||||||
|
@ -42,6 +42,17 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: morphology
|
||||||
|
* @short_description: morphological operators, rank filters and related image
|
||||||
|
* analysis
|
||||||
|
* @see_also: <link linkend="libvips-boolean">boolean</link>
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* Erode, dilate, rank, count lines, number regions, etc.
|
||||||
|
*/
|
||||||
|
|
||||||
/* Args to im_profile.
|
/* Args to im_profile.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc profile_args[] = {
|
static im_arg_desc profile_args[] = {
|
||||||
|
@ -56,6 +56,7 @@
|
|||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
#include <vips/vips.h>
|
#include <vips/vips.h>
|
||||||
|
#include <vips/internal.h>
|
||||||
|
|
||||||
#include "mosaic.h"
|
#include "mosaic.h"
|
||||||
|
|
||||||
|
@ -46,6 +46,16 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: mosaicing
|
||||||
|
* @short_description: build image mosaics
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* A set of operations for assembling large image mosaics.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
/* Merge args.
|
/* Merge args.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc merge_args[] = {
|
static im_arg_desc merge_args[] = {
|
||||||
|
@ -42,6 +42,16 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: other
|
||||||
|
* @short_description: miscellaneous operators
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* Various small things.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
/* Args for im_eye.
|
/* Args for im_eye.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc eye_args[] = {
|
static im_arg_desc eye_args[] = {
|
||||||
|
@ -5,7 +5,6 @@ libresample_la_SOURCES = \
|
|||||||
bicubic.cpp \
|
bicubic.cpp \
|
||||||
interpolate.c \
|
interpolate.c \
|
||||||
yafrsmooth.cpp \
|
yafrsmooth.cpp \
|
||||||
im_resize_linear.c \
|
|
||||||
im_shrink.c \
|
im_shrink.c \
|
||||||
im_stretch3.c \
|
im_stretch3.c \
|
||||||
im_rightshift_size.c \
|
im_rightshift_size.c \
|
||||||
|
@ -48,6 +48,15 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: interpolate
|
||||||
|
* @short_description: shrink, expand, rotate with a choice of interpolators
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* A number of image interpolators.
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* FAST_PSEUDO_FLOOR is a floor and floorf replacement which has been
|
* FAST_PSEUDO_FLOOR is a floor and floorf replacement which has been
|
||||||
* found to be faster on several linux boxes than the library
|
* found to be faster on several linux boxes than the library
|
||||||
|
@ -44,6 +44,16 @@
|
|||||||
#include <dmalloc.h>
|
#include <dmalloc.h>
|
||||||
#endif /*WITH_DMALLOC*/
|
#endif /*WITH_DMALLOC*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SECTION: resample
|
||||||
|
* @short_description: shrink, expand, rotate with a choice of interpolators
|
||||||
|
* @stability: Stable
|
||||||
|
* @include: vips/vips.h
|
||||||
|
*
|
||||||
|
* Resample an image in various ways, using a #VipsInterpolator to generate
|
||||||
|
* intermediate values.
|
||||||
|
*/
|
||||||
|
|
||||||
/* Args to im_rightshift_size.
|
/* Args to im_rightshift_size.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc rightshift_size_args[] = {
|
static im_arg_desc rightshift_size_args[] = {
|
||||||
@ -202,37 +212,6 @@ static im_function shrink_desc = {
|
|||||||
shrink_args /* Arg list */
|
shrink_args /* Arg list */
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Args for im_resize_linear.
|
|
||||||
*/
|
|
||||||
static im_arg_desc resize_linear_args[] = {
|
|
||||||
IM_INPUT_IMAGE( "in" ),
|
|
||||||
IM_OUTPUT_IMAGE( "out" ),
|
|
||||||
IM_INPUT_INT( "X" ),
|
|
||||||
IM_INPUT_INT( "Y" )
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Call im_resize_linear via arg vector.
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
resize_linear_vec( im_object *argv )
|
|
||||||
{
|
|
||||||
int X = *((int *) argv[2]);
|
|
||||||
int Y = *((int *) argv[3]);
|
|
||||||
|
|
||||||
return( im_resize_linear( argv[0], argv[1], X, Y ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Description of im_resize_linear.
|
|
||||||
*/
|
|
||||||
static im_function resize_linear_desc = {
|
|
||||||
"im_resize_linear", /* Name */
|
|
||||||
"resize to X by Y pixels with linear interpolation",
|
|
||||||
0, /* Flags */
|
|
||||||
resize_linear_vec, /* Dispatch function */
|
|
||||||
IM_NUMBER( resize_linear_args ), /* Size of arg list */
|
|
||||||
resize_linear_args /* Arg list */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Args to im_stretch3.
|
/* Args to im_stretch3.
|
||||||
*/
|
*/
|
||||||
static im_arg_desc stretch3_args[] = {
|
static im_arg_desc stretch3_args[] = {
|
||||||
@ -267,7 +246,6 @@ static im_function stretch3_desc = {
|
|||||||
/* Package up all these functions.
|
/* Package up all these functions.
|
||||||
*/
|
*/
|
||||||
static im_function *resample_list[] = {
|
static im_function *resample_list[] = {
|
||||||
&resize_linear_desc,
|
|
||||||
&rightshift_size_desc,
|
&rightshift_size_desc,
|
||||||
&shrink_desc,
|
&shrink_desc,
|
||||||
&stretch3_desc,
|
&stretch3_desc,
|
||||||
|
Loading…
Reference in New Issue
Block a user