File: bandary.h

package info (click to toggle)
vips 8.16.1-2
  • links: PTS
  • area: main
  • in suites: sid
  • size: 51,940 kB
  • sloc: ansic: 169,179; cpp: 11,890; python: 4,620; xml: 4,353; sh: 732; perl: 40; makefile: 19
file content (120 lines) | stat: -rw-r--r-- 2,829 bytes parent folder | download | duplicates (2)
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
/* base class for various operations on bands
 */

/*

	This file is part of VIPS.

	VIPS is free software; you can redistribute it and/or modify
	it under the terms of the GNU Lesser General Public License as published by
	the Free Software Foundation; either version 2 of the License, or
	(at your option) any later version.

	This program is distributed in the hope that it will be useful,
	but WITHOUT ANY WARRANTY; without even the implied warranty of
	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
	GNU Lesser General Public License for more details.

	You should have received a copy of the GNU Lesser General Public License
	along with this program; if not, write to the Free Software
	Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
	02110-1301  USA

 */

/*

	These files are distributed with VIPS - http://www.vips.ecs.soton.ac.uk

 */

#ifndef VIPS__BANDARY_H
#define VIPS__BANDARY_H

#ifdef __cplusplus
extern "C" {
#endif /*__cplusplus*/

#include "pconversion.h"

#define VIPS_TYPE_BANDARY (vips_bandary_get_type())
#define VIPS_BANDARY(obj) \
	(G_TYPE_CHECK_INSTANCE_CAST((obj), \
		VIPS_TYPE_BANDARY, VipsBandary))
#define VIPS_BANDARY_CLASS(klass) \
	(G_TYPE_CHECK_CLASS_CAST((klass), \
		VIPS_TYPE_BANDARY, VipsBandaryClass))
#define VIPS_IS_BANDARY(obj) \
	(G_TYPE_CHECK_INSTANCE_TYPE((obj), VIPS_TYPE_BANDARY))
#define VIPS_IS_BANDARY_CLASS(klass) \
	(G_TYPE_CHECK_CLASS_TYPE((klass), VIPS_TYPE_BANDARY))
#define VIPS_BANDARY_GET_CLASS(obj) \
	(G_TYPE_INSTANCE_GET_CLASS((obj), \
		VIPS_TYPE_BANDARY, VipsBandaryClass))

struct _VipsBandary;

/* Our sequence value.
 */
typedef struct {
	struct _VipsBandary *bandary;

	/* Set of input regions.
	 */
	VipsRegion **ir;

	/* For each input, an input pointer.
	 */
	VipsPel **p;

	/* A memory area large enough to hold one pixel from each input image.
	 */
	VipsPel *pixels;

} VipsBandarySequence;

typedef void (*VipsBandaryProcessFn)(VipsBandarySequence *seq,
	VipsPel *out, VipsPel **in, int width);

typedef struct _VipsBandary {
	VipsConversion parent_instance;

	/* Array of input arguments, set these from a subclass.
	 */
	VipsImage **in;
	int n;

	/* The number of output bands. For example, VipsBandjoin sets the sum
	 * of the bands in the input images.
	 */
	int out_bands;

	/* The input images, ready for the operation.
	 */
	VipsImage **ready;

} VipsBandary;

typedef struct _VipsBandaryClass {
	VipsConversionClass parent_class;

	/* The buffer processor.
	 */
	VipsBandaryProcessFn process_line;

	/* For each input format, what output format. Leave NULL for output
	 * format == input format.
	 */
	const VipsBandFormat *format_table;

} VipsBandaryClass;

GType vips_bandary_get_type(void);

int vips_bandary_copy(VipsBandary *bandary);

#ifdef __cplusplus
}
#endif /*__cplusplus*/

#endif /*VIPS__BANDARY_H*/