1
0
mirror of https://github.com/lvgl/lvgl.git synced 2025-01-21 06:53:01 +08:00
lvgl/lv_misc/lv_color.c

144 lines
2.8 KiB
C
Raw Normal View History

2017-11-23 20:42:14 +01:00
/**
2017-11-23 21:28:36 +01:00
* @file lv_color.c
2017-11-23 20:42:14 +01:00
*
*/
/*********************
* INCLUDES
*********************/
#include "lv_color.h"
/*********************
* DEFINES
*********************/
/**********************
* TYPEDEFS
**********************/
/**********************
* STATIC PROTOTYPES
**********************/
/**********************
* STATIC VARIABLES
**********************/
/**********************
* MACROS
**********************/
/**********************
* GLOBAL FUNCTIONS
**********************/
/**********************
* STATIC FUNCTIONS
**********************/
/**
* Convert a HSV color to RGB
* @param h hue [0..359]
* @param s saturation [0..100]
* @param v value [0..100]
2017-11-23 21:28:36 +01:00
* @return the given RGB color in RGB (with LV_COLOR_DEPTH depth)
2017-11-23 20:42:14 +01:00
*/
2017-11-23 21:28:36 +01:00
lv_color_t lv_color_hsv_to_rgb(uint16_t h, uint8_t s, uint8_t v)
2017-11-23 20:42:14 +01:00
{
h = (uint32_t)((uint32_t)h * 255) / 360;
s = (uint16_t)((uint16_t)s * 255) / 100;
v = (uint16_t)((uint16_t)v * 255) / 100;
uint8_t r, g, b;
uint8_t region, remainder, p, q, t;
2018-06-19 09:49:58 +02:00
if(s == 0) {
2017-11-23 20:42:14 +01:00
r = v;
g = v;
b = v;
2019-03-17 07:44:48 +01:00
return lv_color_make(v, v, v);
2017-11-23 20:42:14 +01:00
}
region = h / 43;
remainder = (h - (region * 43)) * 6;
p = (v * (255 - s)) >> 8;
q = (v * (255 - ((s * remainder) >> 8))) >> 8;
t = (v * (255 - ((s * (255 - remainder)) >> 8))) >> 8;
2018-06-19 09:49:58 +02:00
switch(region) {
2017-11-23 20:42:14 +01:00
case 0:
2018-06-19 09:49:58 +02:00
r = v;
g = t;
b = p;
2017-11-23 20:42:14 +01:00
break;
case 1:
2018-06-19 09:49:58 +02:00
r = q;
g = v;
b = p;
2017-11-23 20:42:14 +01:00
break;
case 2:
2018-06-19 09:49:58 +02:00
r = p;
g = v;
b = t;
2017-11-23 20:42:14 +01:00
break;
case 3:
2018-06-19 09:49:58 +02:00
r = p;
g = q;
b = v;
2017-11-23 20:42:14 +01:00
break;
case 4:
2018-06-19 09:49:58 +02:00
r = t;
g = p;
b = v;
2017-11-23 20:42:14 +01:00
break;
default:
2018-06-19 09:49:58 +02:00
r = v;
g = p;
b = q;
2017-11-23 20:42:14 +01:00
break;
}
2019-03-17 07:44:48 +01:00
lv_color_t result = lv_color_make(r, g, b);
2017-11-23 20:42:14 +01:00
return result;
}
/**
* Convert an RGB color to HSV
* @param r red
* @param g green
* @param b blue
* @return the given RGB color n HSV
*/
2017-11-23 21:28:36 +01:00
lv_color_hsv_t lv_color_rgb_to_hsv(uint8_t r, uint8_t g, uint8_t b)
2017-11-23 20:42:14 +01:00
{
2017-11-23 21:28:36 +01:00
lv_color_hsv_t hsv;
2017-11-23 20:42:14 +01:00
uint8_t rgbMin, rgbMax;
rgbMin = r < g ? (r < b ? r : b) : (g < b ? g : b);
rgbMax = r > g ? (r > b ? r : b) : (g > b ? g : b);
hsv.v = rgbMax;
2018-06-19 09:49:58 +02:00
if(hsv.v == 0) {
2017-11-23 20:42:14 +01:00
hsv.h = 0;
hsv.s = 0;
return hsv;
}
hsv.s = 255 * (long)(rgbMax - rgbMin) / hsv.v;
2018-06-19 09:49:58 +02:00
if(hsv.s == 0) {
2017-11-23 20:42:14 +01:00
hsv.h = 0;
return hsv;
}
2018-06-19 09:49:58 +02:00
if(rgbMax == r)
2017-11-23 20:42:14 +01:00
hsv.h = 0 + 43 * (g - b) / (rgbMax - rgbMin);
2018-06-19 09:49:58 +02:00
else if(rgbMax == g)
2017-11-23 20:42:14 +01:00
hsv.h = 85 + 43 * (b - r) / (rgbMax - rgbMin);
else
hsv.h = 171 + 43 * (r - g) / (rgbMax - rgbMin);
return hsv;
}