2014-06-11 18:13:55 +02:00
|
|
|
/*
|
2016-02-13 23:00:05 +01:00
|
|
|
* Copyright (C) 2014 - 2016 Freie Universität Berlin
|
2014-06-11 18:13:55 +02:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License v2.1. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-10-21 16:46:03 +02:00
|
|
|
* @defgroup sys_color Color
|
2014-06-11 18:13:55 +02:00
|
|
|
* @ingroup sys
|
|
|
|
* @brief The color sys module supports handling RGB and HSV color
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Headers for the color handling module
|
|
|
|
*
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
2016-02-13 23:00:05 +01:00
|
|
|
* @author Cenk Gündoğan <mail@cgundogan.de>
|
2016-03-15 18:01:12 +01:00
|
|
|
* @author Simon Brummer <brummer.simon@googlemail.com>
|
2014-06-11 18:13:55 +02:00
|
|
|
*/
|
|
|
|
|
2016-10-26 21:53:58 +02:00
|
|
|
#ifndef COLOR_H
|
|
|
|
#define COLOR_H
|
2014-06-11 18:13:55 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-06-11 18:13:55 +02:00
|
|
|
/**
|
2014-10-21 16:46:03 +02:00
|
|
|
* @brief Data-structure describing a RGB color
|
2014-06-11 18:13:55 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
uint8_t r; /**< red value [0 - 255] */
|
|
|
|
uint8_t g; /**< green value [0 - 255] */
|
|
|
|
uint8_t b; /**< blue value [0 - 255] */
|
|
|
|
} color_rgb_t;
|
|
|
|
|
2017-03-16 13:28:37 +01:00
|
|
|
/**
|
|
|
|
* @brief RGBA color value
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
color_rgb_t color; /**< RGB value */
|
|
|
|
uint8_t alpha; /**< alpha value [0 - 255] */
|
|
|
|
} color_rgba_t;
|
|
|
|
|
2014-06-11 18:13:55 +02:00
|
|
|
/**
|
2014-10-21 16:46:03 +02:00
|
|
|
* @brief Data-structure for holding HSV colors
|
2014-06-11 18:13:55 +02:00
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
float h; /**< hue value [0.0 - 360.0] */
|
|
|
|
float s; /**< saturation value [0.0 - 1.0] */
|
|
|
|
float v; /**< value [0.0 - 1.0] */
|
|
|
|
} color_hsv_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert RGB color to HSV color
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input color encoded in RGB space
|
|
|
|
* @param[out] hsv Output color encoded in HSV space
|
|
|
|
*/
|
|
|
|
void color_rgb2hsv(color_rgb_t *rgb, color_hsv_t *hsv);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert HSV color to RGB color
|
|
|
|
*
|
|
|
|
* @param[in] hsv Input color encoded in HSV space
|
|
|
|
* @param[out] rgb Output color encoded in RGB space
|
|
|
|
*/
|
|
|
|
void color_hsv2rgb(color_hsv_t *hsv, color_rgb_t *rgb);
|
|
|
|
|
2016-02-13 23:00:05 +01:00
|
|
|
/**
|
|
|
|
* @brief Convert a @p hex value of the form 0x00RRGGBB to an RGB color struct
|
|
|
|
*
|
|
|
|
* @note the two most significant bytes of @p hex will be ignored
|
|
|
|
*
|
|
|
|
* @param[in] hex Input color encoded in hex
|
|
|
|
* @param[out] rgb Output color encoded in RGB space
|
|
|
|
*/
|
|
|
|
void color_hex2rgb(const uint32_t hex, color_rgb_t *rgb);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert a @p rgb struct to a @p hex value of the form 0x00RRGGBB
|
|
|
|
*
|
|
|
|
* @note the two most significant bytes of @p hex will be 0
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input color encoded in RGB space
|
|
|
|
* @param[out] hex Output color encoded in hex
|
|
|
|
*/
|
|
|
|
void color_rgb2hex(const color_rgb_t *rgb, uint32_t *hex);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert a hex color string of the form 'RRGGBB' to a color_rgb_t struct
|
|
|
|
*
|
|
|
|
* @note @p str MUST contain only hexadecimal digits.
|
|
|
|
* Expect unexpected behaviour, otherwise.
|
|
|
|
*
|
|
|
|
* @param[in] str Input color encoded as string of the form 'RRGGBB'
|
2017-03-02 18:15:05 +01:00
|
|
|
* @param[out] color Output color encoded in RGB space
|
2016-02-13 23:00:05 +01:00
|
|
|
*/
|
|
|
|
void color_str2rgb(const char *str, color_rgb_t *color);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Convert a color_rgb_t struct to a hex color string of the form 'RRGGBB'
|
|
|
|
*
|
|
|
|
* @note @p str MUST be big enough to hold 6 characters
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input color encoded in RGB space
|
|
|
|
* @param[out] str Output color encoded as string of the form 'RRGGBB'
|
|
|
|
*/
|
|
|
|
void color_rgb2str(const color_rgb_t *rgb, char *str);
|
|
|
|
|
2016-03-15 18:01:12 +01:00
|
|
|
/**
|
|
|
|
* @brief Invert a given rgb color
|
|
|
|
*
|
|
|
|
* @pre ((rgb != NULL) && (inv_rgb != NULL))
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input rgb color, that should be converted. Must be NOT NULL
|
|
|
|
* @param[out] inv_rgb Output rgb color, result of the conversion. Must be NOT NULL
|
|
|
|
*/
|
|
|
|
static inline void color_rgb_invert(const color_rgb_t *rgb, color_rgb_t *inv_rgb)
|
|
|
|
{
|
|
|
|
inv_rgb->r = rgb->r ^ 0xFF;
|
|
|
|
inv_rgb->g = rgb->g ^ 0xFF;
|
|
|
|
inv_rgb->b = rgb->b ^ 0xFF;
|
|
|
|
}
|
|
|
|
|
2019-11-16 16:12:18 +01:00
|
|
|
/**
|
|
|
|
* @brief Shifts a given rgb color to change it's brightness
|
|
|
|
*
|
|
|
|
* @pre ((rgb != NULL) && (out != NULL))
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input rgb color, that should be shifted. Must be NOT NULL
|
|
|
|
* @param[out] out Output rgb color, result of the shift. Must be NOT NULL
|
|
|
|
* @param[in] shift Amount by which the color components should be shifted.
|
|
|
|
* May be positive (shift to left) or negative (shift to right).
|
|
|
|
*/
|
|
|
|
static inline void color_rgb_shift(const color_rgb_t *rgb, color_rgb_t *out, int8_t shift)
|
|
|
|
{
|
|
|
|
if (shift > 0) {
|
|
|
|
out->r = rgb->r << shift;
|
|
|
|
out->g = rgb->g << shift;
|
|
|
|
out->b = rgb->b << shift;
|
|
|
|
} else {
|
|
|
|
out->r = rgb->r >> -shift;
|
|
|
|
out->g = rgb->g >> -shift;
|
|
|
|
out->b = rgb->b >> -shift;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-16 16:12:41 +01:00
|
|
|
/**
|
|
|
|
* @brief Change the brightness of a RGB color by multiplying it with a set factor.
|
|
|
|
*
|
|
|
|
* @pre ((rgb != NULL) && (out != NULL))
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input rgb color, that should be multiplied. Must be NOT NULL
|
|
|
|
* @param[out] out Output rgb color. Must be NOT NULL
|
|
|
|
* @param[in] level New brightness level. 255 = Full Brightness, 0 = Off.
|
|
|
|
*/
|
|
|
|
static inline void color_rgb_set_brightness(const color_rgb_t *rgb, color_rgb_t *out, uint8_t level)
|
|
|
|
{
|
|
|
|
out->r = ((unsigned)rgb->r * level + 128) >> 8;
|
|
|
|
out->g = ((unsigned)rgb->g * level + 128) >> 8;
|
|
|
|
out->b = ((unsigned)rgb->b * level + 128) >> 8;
|
|
|
|
}
|
|
|
|
|
2016-03-15 18:01:12 +01:00
|
|
|
/**
|
|
|
|
* @brief Calculate the complementary color of a given rgb color.
|
|
|
|
*
|
|
|
|
* @note Complementary color calculation according to adobe illustator calculations.
|
|
|
|
* See https://helpx.adobe.com/illustrator/using/adjusting-colors.html
|
|
|
|
*
|
|
|
|
* @pre ((rgb != NULL) && (comp_rgb != NULL))
|
|
|
|
*
|
|
|
|
* @param[in] rgb Input rgb color. Must be NOT NULL
|
|
|
|
* @param[out] comp_rgb Output rgb color, result of the complementary color calculation. Must be NOT NULL
|
|
|
|
*/
|
|
|
|
void color_rgb_complementary(const color_rgb_t *rgb, color_rgb_t *comp_rgb);
|
|
|
|
|
2014-10-10 11:51:11 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2016-10-26 21:53:58 +02:00
|
|
|
#endif /* COLOR_H */
|
2014-06-11 18:13:55 +02:00
|
|
|
/** @} */
|