126 lines
4.3 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/Kelvin2RGB/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
2021-11-06 15:56:44 +01:00
[![Arduino-lint](https://github.com/RobTillaart/Kelvin2RGB/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/Kelvin2RGB/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/Kelvin2RGB/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/Kelvin2RGB/actions/workflows/jsoncheck.yml)
2021-01-29 12:31:58 +01:00
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/Kelvin2RGB/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/Kelvin2RGB.svg?maxAge=3600)](https://github.com/RobTillaart/Kelvin2RGB/releases)
# Kelvin2RGB
2021-12-20 17:09:35 +01:00
Arduino library for converting temperature and brightness to RGB values.
2021-06-02 13:46:05 +02:00
2021-01-29 12:31:58 +01:00
## Credentials
2023-01-30 15:57:29 +01:00
This library is based upon an article of Tanner Helland and a related story by Neil Bartlett
- http://www.tannerhelland.com/4435/convert-temperature-rgb-algorithm-code/
- http://www.zombieprototypes.com/?p=210
- https://en.wikipedia.org/wiki/Color_temperature#Categorizing_different_lighting
2021-01-29 12:31:58 +01:00
2022-11-14 20:29:43 +01:00
There are more approximation formulas, some claim to be better,
2021-06-02 13:46:05 +02:00
however these are not investigated. On request these can be added.
2021-01-29 12:31:58 +01:00
## Description
2022-11-14 20:29:43 +01:00
The library converts a temperature in Kelvin and a brightness (0..100%)
2023-01-30 15:57:29 +01:00
to three numbers **red**, **green** and **blue**.
2021-12-20 17:09:35 +01:00
These numbers are weights can be used to correct a colour image for virtual white temperature.
2021-01-29 12:31:58 +01:00
2023-01-30 15:57:29 +01:00
There are two convert functions where the **convert_NB()** is claimed to be
2021-06-02 13:46:05 +02:00
the more accurate one.
2023-01-30 15:57:29 +01:00
With the numbers **red**, **green** and **blue** calculated one can convert images
so they will look more like taken with candle light, sunrise or sunset etc.
2021-01-29 12:31:58 +01:00
**pseudo code**
```cpp
Kelvin2RGB KRGB;
KRGB.convert(1850, 100); // sunrise light factors
for each pixel in image
{
red *= KRGB.red();
green *= KRGB.green();
blue *= KRGB.blue();
drawPixel();
}
```
2023-01-30 15:57:29 +01:00
The numbers can also be used to reduce the blue channel so it has less effect
2021-01-29 12:31:58 +01:00
on "getting sleepy".
The library uses floats for the R,G and B weights to keep values as accurate as possible.
Especially with images with more than 8 bits per channel this is preferred.
2023-01-30 15:57:29 +01:00
That said it is also possible to use this on a 565 image or to adjust colour lookup tables.
2021-01-29 12:31:58 +01:00
## Interface
2023-01-30 15:57:29 +01:00
```cpp
#include "Kelvin2RGB.h"
```
2021-11-06 15:56:44 +01:00
The interface is straightforward:
2021-01-29 12:31:58 +01:00
- **Kelvin2RGB()** constructor
2021-11-06 15:56:44 +01:00
- **void begin()** empty function for now.
2022-11-14 20:29:43 +01:00
- **void reset()** resets all internal values to 0.
All colours, brightness and temperature.
- **void convert_TH(float temperature, float brightness = 100)**
temperature = 0..65500 temperature below 1000 is not well defined.
brightness = 0..100%,
- **void convert_NB(float temperature, float brightness = 100)**
temperature = 0..65500 temperature below 1000 is not well defined.
brightness = 0..100%,
2021-01-29 12:31:58 +01:00
Is a bit more accurate and slightly slower (few %). Read link above for more information.
- **float temperature()** returns temperature, to check the value used.
- **float brightness()** returns brightness, to check the value used.
2022-11-14 20:29:43 +01:00
- **float red()** returns red channel weight 0.0 .. 1.0
2021-01-29 12:31:58 +01:00
note this is different from Helland / Bartlett who both use an integer value 0 .. 255
- **float green()** returns green channel weight 0.0 .. 1.0
- **float blue()** returns blue channel weight 0.0 .. 1.0
2022-11-14 20:29:43 +01:00
- **uint32_t setRGB(float red, float green, float blue, float brightness = 100)** sets RGB values
2021-11-06 15:56:44 +01:00
red, green, blue should be in 0 .. 1.0 range. brightness should be in 0..100%, Default = 100%.
2022-11-14 20:29:43 +01:00
returns a 24 bit RGB value,
2021-11-06 15:56:44 +01:00
- **uint32_t RGB()** returns a 24 bit RGB value, 0 .. 16777215
2022-11-14 20:29:43 +01:00
more efficient than 3 floats for communication.
2023-01-30 15:57:29 +01:00
- **uint16_t RGB565()** returns a 16 bit RGB value, 5 bits for red, 6 for green and 5 for blue.
2021-11-06 15:56:44 +01:00
- **uint32_t BGR()** returns a 24 bit BGR value, 0 .. 16777215
2022-11-14 20:29:43 +01:00
- **uint32_t CMYK()** returns a 32 bit = 4 byte CMYK value,
## Operations
See examples
2021-06-02 13:46:05 +02:00
2021-01-29 12:31:58 +01:00
2021-06-02 13:46:05 +02:00
## Future
2021-01-29 12:31:58 +01:00
2023-01-30 15:57:29 +01:00
#### Must
#### Should
2022-11-14 20:29:43 +01:00
2021-01-29 12:31:58 +01:00
- define constants like candleLight as parameter.
2021-06-02 13:46:05 +02:00
- investigate other formulas.
2021-11-06 15:56:44 +01:00
- investigate usability for RGB led strip.
2021-01-29 12:31:58 +01:00
2023-01-30 15:57:29 +01:00
#### Could
2022-11-14 20:29:43 +01:00
- separate brightness per colour channel to mimic "artificial illumination" (0.2.0 ?)
- remove begin() ?
2023-01-30 15:57:29 +01:00
- add examples
- ledstrip
- CMYK()
- BGR()
#### Wont
2021-01-29 12:31:58 +01:00
2023-01-30 15:57:29 +01:00
- investigate **RGB_10_12_10()**
- nowhere used (not found)
2021-01-29 12:31:58 +01:00