2019-03-04 02:22:55 +11:00
|
|
|
/*
|
|
|
|
* floatimg.h
|
|
|
|
*/
|
|
|
|
|
2019-09-13 23:34:56 +11:00
|
|
|
#define FIMG_VERSION 73
|
2019-03-04 02:22:55 +11:00
|
|
|
|
|
|
|
/*
|
|
|
|
* in memory descriptor
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
int width;
|
|
|
|
int height;
|
|
|
|
int type;
|
|
|
|
float fval;
|
|
|
|
int count;
|
|
|
|
|
|
|
|
float *R, *G, *B, *A;
|
|
|
|
|
|
|
|
int reserved;
|
|
|
|
} FloatImg;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* fimg file header
|
|
|
|
*/
|
|
|
|
typedef struct {
|
2019-07-08 15:28:04 +11:00
|
|
|
char magic[8];
|
2019-03-04 02:22:55 +11:00
|
|
|
int w, h, t;
|
2019-07-08 15:28:04 +11:00
|
|
|
} FimgFileHead;
|
2019-03-04 02:22:55 +11:00
|
|
|
|
2019-08-07 20:55:29 +11:00
|
|
|
|
|
|
|
#define FIMG_TYPE_GRAY 1
|
|
|
|
#define FIMG_TYPE_RGB 3
|
|
|
|
#define FIMG_TYPE_RGBA 4
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
/*
|
|
|
|
* core module
|
|
|
|
*/
|
|
|
|
int fimg_create(FloatImg *fimg, int w, int h, int t);
|
|
|
|
int fimg_destroy(FloatImg *fimg);
|
|
|
|
|
|
|
|
int fimg_print_version(int k);
|
|
|
|
void fimg_printhead(FloatImg *h);
|
|
|
|
int fimg_describe(FloatImg *head, char *txt);
|
2019-09-10 21:18:02 +11:00
|
|
|
char *fimg_str_type(int type);
|
2019-03-04 02:22:55 +11:00
|
|
|
int fimg_fileinfo(char *fname, int *datas);
|
|
|
|
int fimg_plot_rgb (FloatImg *head, int x, int y, float r, float g, float b);
|
|
|
|
int fimg_clear(FloatImg *fimg);
|
|
|
|
int fimg_add_rgb(FloatImg *head, int x, int y, float r, float g, float b);
|
|
|
|
|
2019-09-10 01:02:44 +11:00
|
|
|
|
2019-09-10 10:31:48 +11:00
|
|
|
int fimg_images_compatible(FloatImg *a, FloatImg *b);
|
|
|
|
|
2019-09-10 01:02:44 +11:00
|
|
|
int fimg_interpolate(FloatImg *s1, FloatImg *s2, FloatImg *d, float coef);
|
|
|
|
|
2019-08-09 02:16:20 +11:00
|
|
|
/* 'operats' module */
|
|
|
|
int fimg_add(FloatImg *a, FloatImg *b, FloatImg *d);
|
|
|
|
int fimg_sub(FloatImg *a, FloatImg *b, FloatImg *d);
|
|
|
|
int fimg_mul(FloatImg *a, FloatImg *b, FloatImg *d);
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
/* PNM files module */
|
|
|
|
int fimg_save_as_pnm(FloatImg *head, char *fname, int notused);
|
2019-06-30 04:33:23 +11:00
|
|
|
int fimg_load_from_pnm(char *fname, FloatImg *head, int notused);
|
2019-03-04 02:22:55 +11:00
|
|
|
|
|
|
|
double fimg_timer_set(int whot);
|
|
|
|
double fimg_timer_get(int whot);
|
|
|
|
|
|
|
|
|
2019-08-24 22:06:51 +11:00
|
|
|
int fimg_mk_gray_from(FloatImg *src, FloatImg*dst, int k);
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
/* FIMG files module */
|
|
|
|
int fimg_fileinfos(char *fname, int *datas);
|
|
|
|
int fimg_dump_to_file(FloatImg *head, char *fname, int notused);
|
|
|
|
int fimg_create_from_dump(char *fname, FloatImg *head);
|
|
|
|
|
2019-09-10 10:31:48 +11:00
|
|
|
/* mathematics operations */
|
2019-03-04 02:22:55 +11:00
|
|
|
float fimg_get_maxvalue(FloatImg *head);
|
|
|
|
int fimg_meanvalues(FloatImg *head, float means[4]);
|
|
|
|
int fimg_to_gray(FloatImg *head);
|
|
|
|
void fimg_add_cste(FloatImg *fi, float value);
|
2019-09-10 10:31:48 +11:00
|
|
|
void fimg_mul_cste(FloatImg *fi, float value);
|
2019-03-04 02:22:55 +11:00
|
|
|
void fimg_drand48(FloatImg *fi, float kmul);
|
|
|
|
|
2019-05-20 17:47:13 +11:00
|
|
|
/* various funcs modules */
|
2019-03-04 02:22:55 +11:00
|
|
|
int fimg_load_from_png(char *filename, FloatImg *fimg);
|
|
|
|
int fimg_create_from_png(char *filename, FloatImg *fimg);
|
|
|
|
int fimg_save_as_png(FloatImg *src, char *outname, int flags);
|
|
|
|
|
|
|
|
int fimg_draw_something(FloatImg *fimg);
|
|
|
|
|
2019-08-29 06:08:59 +11:00
|
|
|
int parse_WxH(char *str, int *pw, int *ph);
|
2019-09-16 21:28:47 +11:00
|
|
|
int parse_double(char *str, double *dptr);
|
|
|
|
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
|
|
|
|
|