2019-07-04 03:51:42 +11:00
|
|
|
/*
|
|
|
|
* conversion vers le format PNM
|
|
|
|
*
|
|
|
|
*/
|
2019-03-04 02:22:55 +11:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "../floatimg.h"
|
|
|
|
|
|
|
|
int verbosity;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------- */
|
2019-09-11 00:38:24 +11:00
|
|
|
int convertir_fimg_en_pnm(char *srcname, char *dstname, int to_gray)
|
2019-03-04 02:22:55 +11:00
|
|
|
{
|
|
|
|
int foo, infos[3];
|
2019-09-11 00:38:24 +11:00
|
|
|
FloatImg fimg, gris, *outptr;
|
2019-03-04 02:22:55 +11:00
|
|
|
|
|
|
|
#if DEBUG_LEVEL
|
2019-09-11 00:38:24 +11:00
|
|
|
fprintf(stderr, ">>> %25s ( '%s' '%s' %d )\n", __func__,
|
|
|
|
srcname, dstname, to_gray);
|
2019-03-04 02:22:55 +11:00
|
|
|
#endif
|
|
|
|
|
|
|
|
foo = fimg_fileinfos(srcname, infos);
|
|
|
|
if (foo) { fprintf(stderr, "'%s' get dims -> %d\n", srcname, foo); }
|
|
|
|
|
|
|
|
if (verbosity) {
|
2019-09-10 21:18:02 +11:00
|
|
|
fprintf(stderr, "image '%s' is %d x %d %s\n",
|
|
|
|
srcname, infos[0], infos[1],
|
|
|
|
fimg_str_type(infos[2]));
|
2019-03-04 02:22:55 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
foo = fimg_create_from_dump(srcname, &fimg);
|
|
|
|
if (foo) {
|
|
|
|
fprintf(stderr, "create fimg from '%s' -> %d\n", srcname, foo);
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2019-09-11 00:38:24 +11:00
|
|
|
outptr = &fimg; /* safe default value */
|
|
|
|
|
|
|
|
if (to_gray) {
|
|
|
|
puts("converting to gray...");
|
|
|
|
foo = fimg_create(&gris, fimg.width, fimg.height, FIMG_TYPE_GRAY);
|
|
|
|
if (foo) {
|
|
|
|
fprintf(stderr, "err create gray %d\n", foo);
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
foo = fimg_mk_gray_from(&fimg, &gris, 0);
|
|
|
|
if (foo) {
|
|
|
|
fprintf(stderr, "err mk gray %d\n", foo);
|
|
|
|
return -4;
|
|
|
|
}
|
|
|
|
outptr = &gris;
|
|
|
|
}
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
#if DEBUG_LEVEL > 1
|
2019-09-11 00:38:24 +11:00
|
|
|
print_floatimg(outptr, "created fimg");
|
2019-03-04 02:22:55 +11:00
|
|
|
#endif
|
|
|
|
|
2019-09-11 00:38:24 +11:00
|
|
|
foo = fimg_save_as_pnm(outptr, dstname, 0);
|
2019-03-04 02:22:55 +11:00
|
|
|
if(foo) { fprintf(stderr, "%p to '%s' -> %d\n", &fimg, dstname, foo); }
|
|
|
|
|
2019-09-11 00:38:24 +11:00
|
|
|
if (to_gray) {
|
|
|
|
fimg_destroy(&gris);
|
|
|
|
outptr = NULL;
|
|
|
|
/* please run valgrind every hour */
|
|
|
|
}
|
|
|
|
|
2019-03-04 02:22:55 +11:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
/* --------------------------------------------------------------------- */
|
2019-09-10 21:18:02 +11:00
|
|
|
static void help(int flag)
|
|
|
|
{
|
|
|
|
if (flag) {
|
|
|
|
fprintf(stderr, "conversion FIMG -> PNM 16 bits\n");
|
|
|
|
fimg_print_version(1);
|
|
|
|
}
|
|
|
|
puts("usage :");
|
|
|
|
puts("\tfimg2pnm [flags] infile.fimg outfile.pnm");
|
|
|
|
}
|
|
|
|
/* --------------------------------------------------------------------- */
|
2019-03-04 02:22:55 +11:00
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
2019-09-10 21:18:02 +11:00
|
|
|
int foo, opt;
|
2019-09-11 00:38:24 +11:00
|
|
|
int to_gray = 0;
|
2019-03-04 02:22:55 +11:00
|
|
|
|
2019-09-10 21:18:02 +11:00
|
|
|
if (argc == 1) {
|
|
|
|
help(0);
|
|
|
|
exit(0);
|
|
|
|
}
|
|
|
|
|
2019-09-11 00:38:24 +11:00
|
|
|
while ((opt = getopt(argc, argv, "ghv")) != -1) {
|
2019-09-10 21:18:02 +11:00
|
|
|
switch(opt) {
|
2019-09-11 00:38:24 +11:00
|
|
|
case 'g': to_gray = 1;
|
2019-09-10 21:18:02 +11:00
|
|
|
case 'v': verbosity++; break;
|
|
|
|
case 'h': help(1); exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#if DEBUG_LEVEL
|
|
|
|
/* mmmm, is it the good way ? */
|
|
|
|
printf("argc %d -> %d\n", argc, argc-optind);
|
|
|
|
for (foo=optind; foo<argc; foo++) {
|
|
|
|
printf(" %d %s\n", foo, argv[foo]);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (2 != argc-optind) {
|
|
|
|
fprintf(stderr, "error: %s need two filenames\n", argv[0]);
|
2019-03-04 02:22:55 +11:00
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
2019-09-10 21:18:02 +11:00
|
|
|
if ( 0 != access(argv[optind], R_OK) ) { /* fimg is NOT readable */
|
|
|
|
fprintf(stderr, "%s: %s don't exist.\n", argv[0], argv[optind]);
|
2019-03-04 02:22:55 +11:00
|
|
|
exit(2);
|
|
|
|
}
|
|
|
|
|
2019-09-11 00:38:24 +11:00
|
|
|
foo = convertir_fimg_en_pnm(argv[optind], argv[optind+1], to_gray);
|
2019-03-04 02:22:55 +11:00
|
|
|
if (foo) fprintf(stderr, "conversion -> %d\n", foo);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2019-07-04 03:51:42 +11:00
|
|
|
/* --------------------------------------------------------------------- */
|