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
|
#include <inttypes.h>
struct PCD_IMAGE {
int size;
unsigned char *mmap;
int thumbnails; /* # of thumbnails, 0 for normal image */
int res, nr, gray, verbose;
int left, top, width, height, rot;
unsigned char **luma;
unsigned char **red;
unsigned char **blue;
unsigned char *data;
uint32_t *lut_red;
uint32_t *lut_green;
uint32_t *lut_blue;
unsigned char *seq1; /* huffman tables */
unsigned char *len1;
unsigned char *seq2;
unsigned char *len2;
unsigned char *seq3;
unsigned char *len3;
};
/* --- file.c --- */
#define PCD_WIDTH(res,rot) (rot&1?pcd_def_height[res]:pcd_def_width[res])
#define PCD_HEIGHT(res,rot) (rot&1?pcd_def_width[res]:pcd_def_height[res])
extern char pcd_rotor[];
extern int pcd_img_start[];
extern int pcd_def_width[];
extern int pcd_def_height[];
extern char pcd_errmsg[];
int pcd_open(struct PCD_IMAGE *img, char *filename);
int pcd_get_rot(struct PCD_IMAGE *img, int nr);
int pcd_get_maxres(struct PCD_IMAGE *img);
int pcd_select(struct PCD_IMAGE *img, int res, int nr, int gray, int verbose,
int rot, int *left, int *top, int *width, int *height);
int pcd_free(struct PCD_IMAGE *img);
int pcd_close(struct PCD_IMAGE *img);
/* --- yuv2rgb.c --- */
#define RANGE 320
extern int32_t LUT_range[256 + 2 * RANGE];
extern uint32_t LUT_15_red[256];
extern uint32_t LUT_15_green[256];
extern uint32_t LUT_15_blue[256];
extern uint32_t LUT_16_red[256];
extern uint32_t LUT_16_green[256];
extern uint32_t LUT_16_blue[256];
extern uint32_t LUT_24_red[256];
extern uint32_t LUT_24_green[256];
extern uint32_t LUT_24_blue[256];
#define PCD_TYPE_GRAY 1 /* gray - 1 byte/pixel */
#define PCD_TYPE_RGB 2 /* red,green,blue - 3 byte/pixel */
#define PCD_TYPE_BGR 3 /* blue,green,red - 3 byte/pixel */
#define PCD_TYPE_LUT_SHORT 4 /* lookup table - 2 byte/pixel */
#define PCD_TYPE_LUT_LONG 5 /* lookup table - 4 byte/pixel */
void pcd_get_LUT_init(void);
void pcd_set_lookup(struct PCD_IMAGE *img, uint32_t *red,
uint32_t *green, uint32_t *blue);
int pcd_get_image_line(struct PCD_IMAGE *img, int line,
unsigned char *dest, int type, int scale);
int pcd_get_image(struct PCD_IMAGE *img,
unsigned char *dest, int type, int scale);
/* --- huff.c --- */
int pcd_read_htable(unsigned char *src,
unsigned char **pseq, unsigned char **pbits);
int pcd_decode(struct PCD_IMAGE *img);
/* --- inter.c --- */
int pcd_inter_m2(struct PCD_IMAGE *img);
int pcd_inter_pixels(unsigned char **data, int width, int height);
int pcd_inter_lines(unsigned char **data, int width, int height);
/* ----------------------------------------------------------------- */
#define TELL(x) { if(img->verbose) fputc(x,stderr); }
#define ROTOR(x) { if(img->verbose) fprintf(stderr,"%c\010",pcd_rotor[x&3]); }
|