GFXprim
2D bitmap graphics library with emphasis on speed and correctness
Loading...
Searching...
No Matches
gp_pixel.h
Go to the documentation of this file.
1// SPDX-License-Identifier: LGPL-2.1-or-later
2/*
3 * Copyright (C) 2009-2010 Jiri "BlueBear" Dluhos
4 * <jiri.bluebear.dluhos@gmail.com>
5 *
6 * Copyright (C) 2009-2024 Cyril Hrubis <metan@ucw.cz>
7 *
8 * Copyright (C) 2011 Tomas Gavenciak <gavento@ucw.cz>
9 */
10
16#ifndef CORE_GP_PIXEL_H
17#define CORE_GP_PIXEL_H
18
19#include <stdint.h>
20
21#include <core/gp_types.h>
22#include <core/gp_common.h>
23
24#define GP_PIXEL_BITS (sizeof(gp_pixel) * 8)
25
26#include <core/gp_pixel.gen.h>
28#include <core/gp_pixel_alias.h>
31
45typedef struct gp_pixel_channel {
47 char name[8];
49 uint8_t offset;
51 uint8_t size;
57 uint8_t lin_size;
59
75
84 const char name[16];
86 uint8_t size;
88 uint8_t pack;
90 uint8_t numchannels;
94 const char bitmap[GP_PIXEL_BITS + 1];
97};
98
103
104#define GP_VALID_PIXELTYPE(type) (((type) > 0) && ((type) < GP_PIXEL_MAX))
105
106#define GP_CHECK_VALID_PIXELTYPE(type) \
107 GP_CHECK(GP_VALID_PIXELTYPE(type), "Invalid PixelType %d", (type))
108
109/*
110 * Convert pixel type to name.
111 */
112static inline const char *gp_pixel_type_name(gp_pixel_type type)
113{
114 GP_CHECK_VALID_PIXELTYPE(type);
115 return gp_pixel_types[type].name;
116}
117
118/*
119 * Returns number of bits per pixel.
120 */
121static inline uint32_t gp_pixel_size(gp_pixel_type type)
122{
123 GP_CHECK_VALID_PIXELTYPE(type);
124 return gp_pixel_types[type].size;
125}
126
134{
135 GP_CHECK_VALID_PIXELTYPE(type);
136 return &gp_pixel_types[type];
137}
138
145static inline unsigned int gp_pixel_channel_count(gp_pixel_type type)
146{
147 GP_CHECK_VALID_PIXELTYPE(type);
148 return gp_pixel_types[type].numchannels;
149}
150
158static inline uint8_t gp_pixel_channel_bits(gp_pixel_type type, uint8_t channel)
159{
160 GP_CHECK_VALID_PIXELTYPE(type);
161 return gp_pixel_types[type].channels[channel].size;
162}
163
171static inline uint8_t gp_pixel_channel_lin_bits(gp_pixel_type type, uint8_t channel)
172{
173 GP_CHECK_VALID_PIXELTYPE(type);
174 return gp_pixel_types[type].channels[channel].lin_size;
175}
176
184static inline const char *gp_pixel_channel_name(gp_pixel_type type,
185 uint8_t channel)
186{
187 GP_CHECK_VALID_PIXELTYPE(type);
188 return gp_pixel_types[type].channels[channel].name;
189}
190
199 uint8_t channel)
200{
201 GP_CHECK_VALID_PIXELTYPE(type);
202 return gp_pixel_types[type].channels[channel].name[0] == 'A';
203}
204
205/*
206 * Print a human-readable representation of a pixel value to a string.
207 * Arguments as for snprintf().
208 */
209void gp_pixel_snprint(char *buf, size_t len, gp_pixel pixel, gp_pixel_type type);
210
211/*
212 * Prints human-readable representation of pixel value into the stdout.
213 */
214void gp_pixel_print(gp_pixel pixel, gp_pixel_type type);
215
216/*
217 * Returns pixel type for passed human-readable name (e.g. RGB888).
218 */
219gp_pixel_type gp_pixel_type_by_name(const char *name);
220
237 gp_pixel bmask, gp_pixel amask,
238 uint8_t bits_per_pixel);
239
260gp_pixel_type gp_pixel_rgb_lookup(uint32_t rsize, uint32_t roff,
261 uint32_t gsize, uint32_t goff,
262 uint32_t bsize, uint32_t boff,
263 uint32_t asize, uint32_t aoff,
264 uint8_t bits_per_pixel);
265
280
289gp_pixel gp_pixel_chan_mask(gp_pixel_type pixel_type, const char *chan_name);
290
303
304#endif /* CORE_GP_PIXEL_H */
Common macros.
A common types.
uint32_t gp_pixel
Pixel integer value.
Definition gp_types.h:33
Helper macros to get and set bits given offset and length.
A pattern fill constants.
A pixel defintions generated from gen/include/gfxprim_config.py.
#define GP_PIXEL_CHANS_MAX
Maximal number of channels per all defined pixel types.
gp_pixel_type
List of all pixel types.
@ GP_PIXEL_MAX
Last valid pixel type has value GP_PIXEL_MAX-1.
int gp_pixel_has_flags(gp_pixel_type pixel_type, gp_pixel_flags flags)
Function to determine pixel attributes.
static int gp_pixel_channel_is_alpha(gp_pixel_type type, uint8_t channel)
Returns true if pixel channel is alpha channel.
Definition gp_pixel.h:198
gp_pixel gp_pixel_chan_mask(gp_pixel_type pixel_type, const char *chan_name)
Returns channel mask for a given pixel type and channel name.
const gp_pixel_type_desc gp_pixel_types[GP_PIXEL_MAX]
Array with description for all pixel types.
gp_pixel gp_pixel_chans_add(gp_pixel_type pixel_type, gp_pixel pixel, int add)
Does per-channel saturated addition.
static uint8_t gp_pixel_channel_bits(gp_pixel_type type, uint8_t channel)
Returns number of bits for a pixel channel.
Definition gp_pixel.h:158
gp_pixel_type gp_pixel_rgb_match(gp_pixel rmask, gp_pixel gmask, gp_pixel bmask, gp_pixel amask, uint8_t bits_per_pixel)
Matches a RGB pixel type againts known pixel types.
static uint8_t gp_pixel_channel_lin_bits(gp_pixel_type type, uint8_t channel)
Returns number of bits for a linearized pixel channel.
Definition gp_pixel.h:171
static const gp_pixel_type_desc * gp_pixel_desc(gp_pixel_type type)
Returns a pixel type description for a pixel type enum.
Definition gp_pixel.h:133
static unsigned int gp_pixel_channel_count(gp_pixel_type type)
Returns a numbers of pixel channels.
Definition gp_pixel.h:145
gp_pixel_type gp_pixel_rgb_lookup(uint32_t rsize, uint32_t roff, uint32_t gsize, uint32_t goff, uint32_t bsize, uint32_t boff, uint32_t asize, uint32_t aoff, uint8_t bits_per_pixel)
Looks up a RGB pixel type against know pixel types.
gp_pixel_flags
Pixel type flags for various pixel properties.
Definition gp_pixel.h:63
@ GP_PIXEL_IS_PALETTE
Pixel is palette.
Definition gp_pixel.h:69
@ GP_PIXEL_HAS_ALPHA
Pixel has an alpha channel.
Definition gp_pixel.h:65
@ GP_PIXEL_IS_CMYK
Pixel has CMYK channels.
Definition gp_pixel.h:71
@ GP_PIXEL_IS_GRAYSCALE
Pixel is grayscale.
Definition gp_pixel.h:73
@ GP_PIXEL_IS_RGB
Pixel has RGB channels.
Definition gp_pixel.h:67
struct gp_pixel_channel gp_pixel_channel
Description of one pixel channel.
static const char * gp_pixel_channel_name(gp_pixel_type type, uint8_t channel)
Returns number of bits for a pixel channel.
Definition gp_pixel.h:184
Pixel type aliases.
A pixel channel manipulations generated from gen/include/gfxprim_config.py.
Description of one pixel channel.
Definition gp_pixel.h:45
uint8_t offset
Definition gp_pixel.h:49
uint8_t lin_size
Definition gp_pixel.h:57
A description of a gp_pixel_type Assumes name with at most 15 chars.
Definition gp_pixel.h:80
const gp_pixel_channel channels[4]
An individual channel descriptions.
Definition gp_pixel.h:96
uint8_t pack
A pixel packing.
Definition gp_pixel.h:88
const char bitmap[(sizeof(gp_pixel) *8)+1]
String describing the bit-representaton (as in "RRRRRGGGGGGBBBBB")
Definition gp_pixel.h:94
gp_pixel_flags flags
Bitwise or of gp_pixel_flags.
Definition gp_pixel.h:92
uint8_t size
A pixel size in bits.
Definition gp_pixel.h:86
const char name[16]
A name e.g. xRGB8888.
Definition gp_pixel.h:84
gp_pixel_type type
An id of the pixel type.
Definition gp_pixel.h:82
uint8_t numchannels
A number of channels.
Definition gp_pixel.h:90