forked from dresden-elektronik/deconz-rest-plugin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlight_node.h
115 lines (106 loc) · 3.25 KB
/
light_node.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
/*
* Copyright (c) 2016-2017 dresden elektronik ingenieurtechnik gmbh.
* All rights reserved.
*
* The software in this package is published under the terms of the BSD
* style license a copy of which has been included with this distribution in
* the LICENSE.txt file.
*
*/
#ifndef LIGHT_NODE_H
#define LIGHT_NODE_H
#include <QString>
#include <deconz.h>
#include "resource.h"
#include "rest_node_base.h"
#include "group_info.h"
/*! \class LightNode
Represents a HA or ZLL based light.
*/
class LightNode : public Resource,
public RestNodeBase
{
public:
enum State
{
StateNormal,
StateDeleted
};
LightNode();
State state() const;
void setState(State state);
bool isAvailable() const;
uint16_t manufacturerCode() const;
void setManufacturerCode(uint16_t code);
const QString &manufacturer() const;
void setManufacturerName(const QString &name);
const QString &modelId() const;
void setModelId(const QString &modelId);
const QString &swBuildId() const;
void setSwBuildId(const QString & swBuildId);
const QString &name() const;
void setName(const QString &name);
const QString &type() const;
std::vector<GroupInfo> &groups();
const std::vector<GroupInfo> &groups() const;
uint16_t otauClusterId() const;
void setOtauClusterId(uint16_t clusterId);
bool hasColor() const;
uint16_t level() const;
void setLevel(uint16_t level);
uint8_t hue() const;
void setHue(uint8_t hue);
uint16_t enhancedHue() const;
void setEnhancedHue(uint16_t ehue);
uint8_t saturation() const;
void setSaturation(uint8_t sat);
void setColorXY(uint16_t x, uint16_t y);
uint16_t colorX() const;
uint16_t colorY() const;
uint16_t colorTemperature() const;
void setColorTemperature(uint16_t colorTemperature);
const QString &colorMode() const;
void setColorMode(const QString &colorMode);
void setColorLoopActive(bool colorLoopActive);
bool isColorLoopActive() const;
void setColorLoopSpeed(uint8_t speed);
uint8_t colorLoopSpeed() const;
const deCONZ::SimpleDescriptor &haEndpoint() const;
void setHaEndpoint(const deCONZ::SimpleDescriptor &endpoint);
uint8_t groupCapacity() const;
void setGroupCapacity(uint8_t capacity);
uint8_t resetRetryCount() const;
void setResetRetryCount(uint8_t resetRetryCount);
uint8_t zdpResetSeq() const;
void setZdpResetSeq(uint8_t zdpResetSeq);
uint8_t groupCount() const;
void setGroupCount(uint8_t groupCount);
uint8_t sceneCapacity() const;
void setSceneCapacity(uint8_t sceneCapacity);
QString etag;
private:
State m_state;
uint8_t m_resetRetryCount;
uint8_t m_zdpResetSeq;
uint8_t m_groupCapacity;
QString m_manufacturer;
uint16_t m_manufacturerCode;
QString m_swBuildId;
uint16_t m_otauClusterId;
std::vector<GroupInfo> m_groups;
bool m_isOn;
uint16_t m_level;
uint8_t m_hue;
uint16_t m_ehue;
double m_normHue;
uint8_t m_sat;
uint16_t m_colorX;
uint16_t m_colorY;
uint16_t m_colorTemperature;
bool m_colorLoopActive;
uint8_t m_colorLoopSpeed;
deCONZ::SimpleDescriptor m_haEndpoint;
uint8_t m_groupCount;
uint8_t m_sceneCapacity;
};
#endif // LIGHT_NODE_H