lume/color.go

174 lines
3.3 KiB
Go
Raw Normal View History

2020-02-29 22:00:21 +00:00
package lifx
import (
2020-03-07 02:55:31 +00:00
"encoding/json"
2020-03-08 18:47:01 +00:00
"errors"
2020-02-29 22:00:21 +00:00
"fmt"
2020-03-07 02:55:31 +00:00
"net/http"
2020-02-29 22:00:21 +00:00
"strings"
)
type (
Color interface {
ColorString() string
}
)
type (
RGBColor struct {
R, G, B uint8
}
HSBKColor struct {
2020-03-08 18:47:01 +00:00
H *float32 `json:"hue"`
S *float32 `json:"saturation"`
B *float32 `json:"brightness"`
K *int16 `json:"kelvin"`
2020-02-29 22:00:21 +00:00
}
2020-02-29 22:09:05 +00:00
NamedColor string
2020-02-29 22:00:21 +00:00
)
2020-03-22 16:31:10 +00:00
const (
WhiteCandlelight = 1500
WhiteSunset = 2000
WhiteUltraWarm = 2500
WhiteIncandescent = 2700
WhiteWarm = 3000
WhiteCool = 4000
WhiteCoolDaylight = 4500
WhiteSoftDaylight = 5000
WhiteDaylight = 5600
WhiteNoonDaylight = 6000
WhiteBrightDaylight = 6500
WhiteCloudDaylight = 7000
WhiteBlueDaylight = 7500
WhiteBlueOvercast = 8000
WhiteBlueIce = 9000
)
var (
2020-03-22 16:31:10 +00:00
DefaultWhites = map[string]int{
"candlelight": WhiteCandlelight,
"sunset": WhiteSunset,
"ultrawarm": WhiteUltraWarm,
"incandesent": WhiteIncandescent,
"warm": WhiteWarm,
"cool": WhiteCool,
"cooldaylight": WhiteCoolDaylight,
"softdaylight": WhiteSoftDaylight,
"daylight": WhiteDaylight,
"noondaylight": WhiteNoonDaylight,
"brightdaylight": WhiteBrightDaylight,
"clouddaylight": WhiteCloudDaylight,
"bluedaylight": WhiteBlueDaylight,
"blueovercast": WhiteBlueOvercast,
"blueice": WhiteBlueIce,
}
)
2020-02-29 22:00:21 +00:00
func NewRGBColor(r, g, b uint8) (*RGBColor, error) {
return &RGBColor{R: r, G: g, B: b}, nil
}
2020-03-08 18:47:01 +00:00
func NewHSBColor(h, s, b float32) (HSBKColor, error) {
2020-02-29 22:00:21 +00:00
var c HSBKColor
2020-03-08 18:47:01 +00:00
if h < 0 || h > 360 {
return c, errors.New("hue must be between 0.0-360.0")
}
if s < 0 || s > 1 {
return c, errors.New("saturation must be between 0.0-1.0")
}
if b < 0 || b > 1 {
return c, errors.New("brightness must be between 0.0-1.0")
}
c = HSBKColor{
H: Float32Ptr(h),
S: Float32Ptr(s),
B: Float32Ptr(b),
}
return c, nil
}
func NewWhite(k int16) (HSBKColor, error) {
var c HSBKColor
if k < 1500 || k > 8000 {
return c, errors.New("kelvin must be between 1500-9000")
}
c = HSBKColor{
H: Float32Ptr(0.0),
S: Float32Ptr(0.0),
K: Int16Ptr(k),
}
return c, nil
2020-02-29 22:00:21 +00:00
}
2020-03-22 16:31:10 +00:00
func NewWhiteString(s string) (HSBKColor, error) {
k, ok := DefaultWhites[s]
if !ok {
return HSBKColor{}, fmt.Errorf("'%s' is not a valid default white", s)
}
return NewWhite(int16(k))
}
2020-02-29 22:00:21 +00:00
func (c RGBColor) ColorString() string {
return fmt.Sprintf("rgb:%d,%d,%d", c.R, c.G, c.B)
}
func (c RGBColor) Hex() string {
return fmt.Sprintf("#%x%x%x", c.R, c.G, c.B)
}
func (c HSBKColor) ColorString() string {
var s []string
2020-03-08 18:47:01 +00:00
if c.H != nil {
s = append(s, fmt.Sprintf("hue:%g", *c.H))
2020-02-29 22:00:21 +00:00
}
2020-03-08 18:47:01 +00:00
if c.S != nil {
s = append(s, fmt.Sprintf("saturation:%g", *c.S))
2020-02-29 22:00:21 +00:00
}
2020-03-08 18:47:01 +00:00
if c.B != nil {
s = append(s, fmt.Sprintf("brightness:%g", *c.B))
2020-02-29 22:00:21 +00:00
}
2020-03-08 18:47:01 +00:00
if c.K != nil {
s = append(s, fmt.Sprintf("kelvin:%d", *c.K))
2020-02-29 22:00:21 +00:00
}
return strings.Join(s, " ")
}
func (c HSBKColor) MarshalText() ([]byte, error) {
return []byte(c.ColorString()), nil
}
2020-02-29 22:09:05 +00:00
func (c NamedColor) ColorString() string {
return string(c)
}
2020-03-01 05:15:39 +00:00
func (c *Client) ValidateColor(color Color) (Color, error) {
2020-03-07 02:55:31 +00:00
var (
err error
s *HSBKColor
resp *http.Response
)
if resp, err = c.validateColor(color); err != nil {
2020-03-01 05:15:39 +00:00
return nil, err
}
2020-03-07 02:55:31 +00:00
fmt.Println(resp)
defer resp.Body.Close()
2020-03-01 05:15:39 +00:00
2020-03-07 02:55:31 +00:00
if err = json.NewDecoder(resp.Body).Decode(&s); err != nil {
2020-03-01 05:15:39 +00:00
return nil, err
}
return s, nil
}