163 lines
5.5 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)
2023-11-06 14:18:53 +01:00
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/Kelvin2RGB.svg)](https://github.com/RobTillaart/Kelvin2RGB/issues)
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)
2023-11-06 14:18:53 +01:00
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/Kelvin2RGB.svg)](https://registry.platformio.org/libraries/robtillaart/Kelvin2RGB)
2021-01-29 12:31:58 +01:00
# 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
2023-11-06 14:18:53 +01:00
#### Celsius and Fahrenheit
To use Celsius or Fahrenheit with the **Kelvin2RGB** library,
one need to convert that temperature to Kelvin.
```cpp
Kelvin = Celsius + 273.15;
Kelvin = (Fahrenheit - 32) * 5 / 9 - 273.15;
// or shorter
Kelvin = (Fahrenheit - 523.67) * 0.5555555555;
```
#### Related
- https://github.com/RobTillaart/Kelvin2RGB
- https://github.com/RobTillaart/map2colour map float onto a colour(gradient).
- https://github.com/RobTillaart/Temperature temperature scale convertors
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
2023-11-06 14:18:53 +01:00
- **Kelvin2RGB()** constructor.
- **void begin()** resets all internal values to 0.
All colours, brightness and temperature.
2022-11-14 20:29:43 +01:00
- **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
2023-11-06 14:18:53 +01:00
note this is different from Helland / Bartlett who both use an integer value 0 .. 255
2021-01-29 12:31:58 +01:00
- **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
2023-11-06 14:18:53 +01:00
red, green, blue should be in 0 .. 1.0 range. brightness should be in 0..100%, Default = 100%.
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
2023-11-06 14:18:53 +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,
2023-11-06 14:18:53 +01:00
#### Obsolete
- **void reset()** => replaced by **begin()**
2022-11-14 20:29:43 +01:00
## 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
2023-11-06 14:18:53 +01:00
- improve documentations.
2023-01-30 15:57:29 +01:00
#### 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 ?)
2023-11-06 14:18:53 +01:00
- remove begin() or reset() ?
2023-01-30 15:57:29 +01:00
- add examples
- ledstrip
2023-11-06 14:18:53 +01:00
- use a "dirty flag" to minimize math operations.
2023-01-30 15:57:29 +01:00
#### 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
2023-11-06 14:18:53 +01:00
## Support
If you appreciate my libraries, you can support the development and maintenance.
Improve the quality of the libraries by providing issues and Pull Requests, or
donate through PayPal or GitHub sponsors.
Thank you,