1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
|
/* pnm.h - header file for libpnm portable anymap library
*/
#ifndef _PNM_H_
#define _PNM_H_
#include "ppm.h"
#ifdef __cplusplus
extern "C" {
#endif
#if 0
} /* to fake out automatic code indenters */
#endif
typedef pixel xel;
typedef pixval xelval;
#define PNM_OVERALLMAXVAL PPM_OVERALLMAXVAL
#define PNM_MAXMAXVAL PPM_MAXMAXVAL
#define PNM_GET1(x) PPM_GETB(x)
#define PNM_ASSIGN1(x,v) PPM_ASSIGN(x,0,0,v)
#define PNM_ASSIGN(x,r,g,b) PPM_ASSIGN(x,r,g,b)
#define PNM_EQUAL(x,y) PPM_EQUAL(x,y)
#define PNM_FORMAT_TYPE(f) PPM_FORMAT_TYPE(f)
#define PNM_DEPTH(newp,p,oldmaxval,newmaxval) \
PPM_DEPTH(newp,p,oldmaxval,newmaxval)
/* Declarations of routines. */
void pnm_init ARGS(( int* argcP, char* argv[] ));
void
pnm_nextimage(FILE *file, int * const eofP);
xel *
pnm_allocrow(unsigned int const cols);
#define pnm_freerow(xelrow) free(xelrow)
#define pnm_allocarray( cols, rows ) \
((xel**) pm_allocarray( cols, rows, sizeof(xel) ))
#define pnm_freearray( xels, rows ) pm_freearray( (char**) xels, rows )
void
pnm_readpnminit(FILE * const fileP,
int * const colsP,
int * const rowsP,
xelval * const maxvalP,
int * const formatP);
void
pnm_readpnmrow(FILE * const fileP,
xel * const xelrow,
int const cols,
xelval const maxval,
int const format);
xel **
pnm_readpnm(FILE * const fileP,
int * const colsP,
int * const rowsP,
xelval * const maxvalP,
int * const formatP);
void
pnm_check(FILE * const fileP,
enum pm_check_type const check_type,
int const format,
int const cols,
int const rows,
int const maxval,
enum pm_check_code * const retvalP);
void
pnm_writepnminit(FILE * const fileP,
int const cols,
int const rows,
xelval const maxval,
int const format,
int const forceplain);
void
pnm_writepnmrow(FILE * const fileP,
xel * const xelrow,
int const cols,
xelval const maxval,
int const format,
int const forceplain);
void
pnm_writepnm(FILE * const fileP,
xel ** const xels,
int const cols,
int const rows,
xelval const maxval,
int const format,
int const forceplain);
xel
pnm_backgroundxel (xel** xels, int cols, int rows, xelval maxval, int format);
xel
pnm_backgroundxelrow (xel* xelrow, int cols, xelval maxval, int format);
xel
pnm_whitexel (xelval maxval, int format);
xel
pnm_blackxel(xelval maxval, int format);
void
pnm_invertxel(xel * const x,
xelval const maxval,
int const format);
void
pnm_promoteformat(xel** xels, int cols, int rows, xelval maxval, int format,
xelval newmaxval, int newformat);
void
pnm_promoteformatrow(xel* xelrow, int cols, xelval maxval, int format,
xelval newmaxval, int newformat);
pixel
xeltopixel(xel const inputxel);
#ifdef __cplusplus
}
#endif
#endif /*_PNM_H_*/
|