-
Notifications
You must be signed in to change notification settings - Fork 2.2k
/
Copy path_P015_TSL2561.ino
198 lines (167 loc) · 5.8 KB
/
_P015_TSL2561.ino
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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
#include "_Plugin_Helper.h"
#ifdef USES_P015
// #######################################################################################################
// ######################## Plugin 015 TSL2561 I2C Lux Sensor ############################################
// #######################################################################################################
// complete rewrite, to support lower lux values better, add ability to change gain and sleep mode
// by: https://github.com/krikk
// this plugin is based on the sparkfun library
// written based on version 1.1.0 from https://github.com/sparkfun/SparkFun_TSL2561_Arduino_Library
/** Changelog:
* 2025-01-12 tonhuisman: Add support for MQTT AutoDiscovery (partially)
*/
# include "src/PluginStructs/P015_data_struct.h"
# define PLUGIN_015
# define PLUGIN_ID_015 15
# define PLUGIN_NAME_015 "Light/Lux - TSL2561"
# define PLUGIN_VALUENAME1_015 "Lux"
# define PLUGIN_VALUENAME2_015 "Infrared"
# define PLUGIN_VALUENAME3_015 "Broadband"
# define PLUGIN_VALUENAME4_015 "Ratio"
# define P015_I2C_ADDR PCONFIG(0)
# define P015_INTEGRATION PCONFIG(1)
# define P015_SLEEP PCONFIG(2)
# define P015_GAIN PCONFIG(3)
boolean Plugin_015(uint8_t function, struct EventStruct *event, String& string)
{
bool success = false;
switch (function)
{
case PLUGIN_DEVICE_ADD:
{
auto& dev = Device[++deviceCount];
dev.Number = PLUGIN_ID_015;
dev.Type = DEVICE_TYPE_I2C;
dev.VType = Sensor_VType::SENSOR_TYPE_TRIPLE;
dev.FormulaOption = true;
dev.ValueCount = 3;
dev.SendDataOption = true;
dev.TimerOption = true;
dev.PluginStats = true;
break;
}
case PLUGIN_GET_DEVICENAME:
{
string = F(PLUGIN_NAME_015);
break;
}
case PLUGIN_GET_DEVICEVALUENAMES:
{
strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[0], PSTR(PLUGIN_VALUENAME1_015));
strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[1], PSTR(PLUGIN_VALUENAME2_015));
strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[2], PSTR(PLUGIN_VALUENAME3_015));
strcpy_P(ExtraTaskSettings.TaskDeviceValueNames[3], PSTR(PLUGIN_VALUENAME4_015));
break;
}
# if FEATURE_MQTT_DISCOVER
case PLUGIN_GET_DISCOVERY_VTYPES:
{
event->Par1 = static_cast<int>(Sensor_VType::SENSOR_TYPE_LUX_ONLY);
event->Par2 = static_cast<int>(Sensor_VType::SENSOR_TYPE_IR_ONLY);
event->Par3 = static_cast<int>(Sensor_VType::SENSOR_TYPE_LUX_ONLY);
success = true;
break;
}
# endif // if FEATURE_MQTT_DISCOVER
case PLUGIN_I2C_HAS_ADDRESS:
case PLUGIN_WEBFORM_SHOW_I2C_PARAMS:
{
const uint8_t i2cAddressValues[] = { TSL2561_ADDR_0, TSL2561_ADDR, TSL2561_ADDR_1 };
if (function == PLUGIN_WEBFORM_SHOW_I2C_PARAMS) {
addFormSelectorI2C(F("i2c_addr"), 3, i2cAddressValues, P015_I2C_ADDR, TSL2561_ADDR);
} else {
success = intArrayContains(3, i2cAddressValues, event->Par1);
}
break;
}
# if FEATURE_I2C_GET_ADDRESS
case PLUGIN_I2C_GET_ADDRESS:
{
event->Par1 = P015_I2C_ADDR;
success = true;
break;
}
# endif // if FEATURE_I2C_GET_ADDRESS
case PLUGIN_SET_DEFAULTS:
{
P015_I2C_ADDR = TSL2561_ADDR; // Default address
success = true;
break;
}
case PLUGIN_WEBFORM_LOAD:
{
{
const __FlashStringHelper *options[] = {
F("13.7"),
F("101"),
F("402"),
};
constexpr size_t optionCount = NR_ELEMENTS(options);
const FormSelectorOptions selector(optionCount, options);
selector.addFormSelector(F("Integration time"), F("pintegration"), P015_INTEGRATION);
addUnit(F("ms"));
}
addFormCheckBox(F("Send sensor to sleep:"), F("psleep"),
P015_SLEEP);
{
const __FlashStringHelper *options[] = {
F("No Gain"),
F("16x Gain"),
F("Auto Gain"),
F("Extended Auto Gain"),
};
/*
const int optionValues[] = {
P015_NO_GAIN,
P015_16X_GAIN,
P015_AUTO_GAIN,
P015_EXT_AUTO_GAIN,
};
*/
constexpr size_t optionCount = NR_ELEMENTS(options);
const FormSelectorOptions selector(optionCount, options/*, optionValues*/);
selector.addFormSelector(F("Gain"), F("pgain"), P015_GAIN);
}
success = true;
break;
}
case PLUGIN_WEBFORM_SAVE:
{
P015_I2C_ADDR = getFormItemInt(F("i2c_addr"));
P015_INTEGRATION = getFormItemInt(F("pintegration"));
P015_SLEEP = isFormItemChecked(F("psleep"));
P015_GAIN = getFormItemInt(F("pgain"));
success = true;
break;
}
case PLUGIN_INIT:
{
success = initPluginTaskData(event->TaskIndex, new (std::nothrow) P015_data_struct(P015_I2C_ADDR, P015_GAIN, P015_INTEGRATION));
break;
}
case PLUGIN_READ:
{
P015_data_struct *P015_data =
static_cast<P015_data_struct *>(getPluginTaskData(event->TaskIndex));
if (nullptr != P015_data) {
P015_data->begin();
float luxVal, infraredVal, broadbandVal, ir_broadband_ratio{};
success = P015_data->performRead(
luxVal, infraredVal, broadbandVal, ir_broadband_ratio);
UserVar.setFloat(event->TaskIndex, 0, luxVal);
UserVar.setFloat(event->TaskIndex, 1, infraredVal);
UserVar.setFloat(event->TaskIndex, 2, broadbandVal);
UserVar.setFloat(event->TaskIndex, 3, ir_broadband_ratio);
if (P015_SLEEP) {
# ifndef BUILD_NO_DEBUG
addLog(LOG_LEVEL_DEBUG, F("TSL2561: sleeping..."));
# endif // ifndef BUILD_NO_DEBUG
P015_data->setPowerDown();
}
}
break;
}
}
return success;
}
#endif // USES_P015