mirror of https://github.com/arendst/Tasmota.git
parent
567770ef4c
commit
fae30ee5e6
|
@ -62,24 +62,17 @@
|
||||||
#define APDS9930_CHIPID_2 0x39 // there are case reports about "accidentially bought" 9930's
|
#define APDS9930_CHIPID_2 0x39 // there are case reports about "accidentially bought" 9930's
|
||||||
|
|
||||||
/* Gesture parameters */
|
/* Gesture parameters */
|
||||||
#define GESTURE_THRESHOLD_OUT 10
|
#define GESTURE_THRESHOLD_OUT 10
|
||||||
#define GESTURE_SENSITIVITY_1 50
|
#define GESTURE_SENSITIVITY_1 50
|
||||||
#define GESTURE_SENSITIVITY_2 20
|
#define GESTURE_SENSITIVITY_2 20
|
||||||
|
|
||||||
uint8_t APDS9960addr;
|
|
||||||
uint8_t APDS9960type = 0;
|
|
||||||
char APDS9960stype[] = "APDS9960";
|
|
||||||
char currentGesture[6];
|
|
||||||
uint8_t gesture_mode = 1;
|
|
||||||
|
|
||||||
|
|
||||||
volatile uint8_t recovery_loop_counter = 0; // count number of stateloops to switch the sensor off, if needed
|
|
||||||
#define APDS9960_LONG_RECOVERY 50 // long pause after sensor overload in loops
|
#define APDS9960_LONG_RECOVERY 50 // long pause after sensor overload in loops
|
||||||
#define APDS9960_MAX_GESTURE_CYCLES 50 // how many FIFO-reads are allowed to prevent crash
|
#define APDS9960_MAX_GESTURE_CYCLES 50 // how many FIFO-reads are allowed to prevent crash
|
||||||
bool APDS9960_overload = false;
|
|
||||||
|
const char APDS9960_TAG[] = "APDS9960";
|
||||||
|
|
||||||
#ifdef USE_WEBSERVER
|
#ifdef USE_WEBSERVER
|
||||||
const char HTTP_APDS_9960_SNS[] PROGMEM =
|
const char HTTP_APDS9960_SNS[] PROGMEM =
|
||||||
"{s}" "Red" "{m}%s{e}"
|
"{s}" "Red" "{m}%s{e}"
|
||||||
"{s}" "Green" "{m}%s{e}"
|
"{s}" "Green" "{m}%s{e}"
|
||||||
"{s}" "Blue" "{m}%s{e}"
|
"{s}" "Blue" "{m}%s{e}"
|
||||||
|
@ -153,7 +146,7 @@ const char HTTP_APDS_9960_SNS[] PROGMEM =
|
||||||
#define APDS9960_AEN 0b00000010
|
#define APDS9960_AEN 0b00000010
|
||||||
#define APDS9960_PEN 0b00000100
|
#define APDS9960_PEN 0b00000100
|
||||||
#define APDS9960_WEN 0b00001000
|
#define APDS9960_WEN 0b00001000
|
||||||
#define APSD9960_AIEN 0b00010000
|
#define APDS9960_AIEN 0b00010000
|
||||||
#define APDS9960_PIEN 0b00100000
|
#define APDS9960_PIEN 0b00100000
|
||||||
#define APDS9960_GEN 0b01000000
|
#define APDS9960_GEN 0b01000000
|
||||||
#define APDS9960_GVALID 0b00000001
|
#define APDS9960_GVALID 0b00000001
|
||||||
|
@ -269,16 +262,17 @@ typedef struct gesture_data_type {
|
||||||
uint8_t total_gestures;
|
uint8_t total_gestures;
|
||||||
uint8_t in_threshold;
|
uint8_t in_threshold;
|
||||||
uint8_t out_threshold;
|
uint8_t out_threshold;
|
||||||
} gesture_data_type;
|
} gesture_data_t;
|
||||||
|
|
||||||
/*Members*/
|
typedef struct gesture_type
|
||||||
gesture_data_type gesture_data_;
|
{
|
||||||
int16_t gesture_ud_delta_ = 0;
|
int16_t ud_delta_ = 0;
|
||||||
int16_t gesture_lr_delta_ = 0;
|
int16_t lr_delta_ = 0;
|
||||||
int16_t gesture_ud_count_ = 0;
|
int16_t ud_count_ = 0;
|
||||||
int16_t gesture_lr_count_ = 0;
|
int16_t lr_count_ = 0;
|
||||||
int16_t gesture_state_ = 0;
|
int16_t state_ = 0;
|
||||||
int16_t gesture_motion_ = DIR_NONE;
|
int16_t motion_ = DIR_NONE;
|
||||||
|
} gesture_t;
|
||||||
|
|
||||||
typedef struct color_data_type {
|
typedef struct color_data_type {
|
||||||
uint16_t a; // measured ambient
|
uint16_t a; // measured ambient
|
||||||
|
@ -288,11 +282,19 @@ typedef struct color_data_type {
|
||||||
uint8_t p; // proximity
|
uint8_t p; // proximity
|
||||||
uint16_t cct; // calculated color temperature
|
uint16_t cct; // calculated color temperature
|
||||||
uint16_t lux; // calculated illuminance - atm only from rgb
|
uint16_t lux; // calculated illuminance - atm only from rgb
|
||||||
} color_data_type;
|
} color_data_t;
|
||||||
|
|
||||||
color_data_type color_data;
|
/*Members*/
|
||||||
|
gesture_data_t gesture_data;
|
||||||
|
gesture_t gesture;
|
||||||
|
color_data_t color_data;
|
||||||
|
|
||||||
|
volatile uint8_t recovery_loop_counter = 0; // count number of stateloops to switch the sensor off, if needed
|
||||||
|
bool APDS9960_overload = false;
|
||||||
|
char currentGesture[6];
|
||||||
uint8_t APDS9960_aTime = DEFAULT_ATIME;
|
uint8_t APDS9960_aTime = DEFAULT_ATIME;
|
||||||
|
uint8_t APDS9960type = 0;
|
||||||
|
uint8_t gesture_mode = 1;
|
||||||
|
|
||||||
/******************************************************************************\
|
/******************************************************************************\
|
||||||
* Helper functions
|
* Helper functions
|
||||||
|
@ -1270,7 +1272,7 @@ void setMode(uint8_t mode, uint8_t enable) {
|
||||||
|
|
||||||
/* Change bit(s) in ENABLE register */
|
/* Change bit(s) in ENABLE register */
|
||||||
enable = enable & 0x01;
|
enable = enable & 0x01;
|
||||||
if (mode >= 0 && mode <= 6) {
|
if (mode <= 6) {
|
||||||
if (enable) {
|
if (enable) {
|
||||||
reg_val |= (1 << mode);
|
reg_val |= (1 << mode);
|
||||||
} else {
|
} else {
|
||||||
|
@ -1394,12 +1396,12 @@ bool isGestureAvailable(void) {
|
||||||
*/
|
*/
|
||||||
int16_t readGesture(void) {
|
int16_t readGesture(void) {
|
||||||
uint8_t fifo_level = 0;
|
uint8_t fifo_level = 0;
|
||||||
uint8_t bytes_read = 0;
|
|
||||||
uint8_t fifo_data[128];
|
uint8_t fifo_data[128];
|
||||||
uint8_t gstatus;
|
uint8_t gstatus;
|
||||||
uint16_t motion;
|
int16_t motion;
|
||||||
uint16_t i;
|
uint16_t i;
|
||||||
uint8_t gesture_loop_counter = 0; // don't loop forever later
|
uint8_t gesture_loop_counter = 0; // don't loop forever later
|
||||||
|
int8_t bytes_read = 0;
|
||||||
|
|
||||||
/* Make sure that power and gesture is on and data is valid */
|
/* Make sure that power and gesture is on and data is valid */
|
||||||
if (!isGestureAvailable() || !(getMode() & 0b01000001)) {
|
if (!isGestureAvailable() || !(getMode() & 0b01000001)) {
|
||||||
|
@ -1435,16 +1437,12 @@ int16_t readGesture(void) {
|
||||||
/* If at least 1 set of data, sort the data into U/D/L/R */
|
/* If at least 1 set of data, sort the data into U/D/L/R */
|
||||||
if (bytes_read >= 4) {
|
if (bytes_read >= 4) {
|
||||||
for (i = 0; i < bytes_read; i += 4) {
|
for (i = 0; i < bytes_read; i += 4) {
|
||||||
gesture_data_.u_data[gesture_data_.index] = \
|
gesture_data.u_data[gesture_data.index] = fifo_data[i + 0];
|
||||||
fifo_data[i + 0];
|
gesture_data.d_data[gesture_data.index] = fifo_data[i + 1];
|
||||||
gesture_data_.d_data[gesture_data_.index] = \
|
gesture_data.l_data[gesture_data.index] = fifo_data[i + 2];
|
||||||
fifo_data[i + 1];
|
gesture_data.r_data[gesture_data.index] = fifo_data[i + 3];
|
||||||
gesture_data_.l_data[gesture_data_.index] = \
|
gesture_data.index++;
|
||||||
fifo_data[i + 2];
|
gesture_data.total_gestures++;
|
||||||
gesture_data_.r_data[gesture_data_.index] = \
|
|
||||||
fifo_data[i + 3];
|
|
||||||
gesture_data_.index++;
|
|
||||||
gesture_data_.total_gestures++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Filter and process gesture data. Decode near/far state */
|
/* Filter and process gesture data. Decode near/far state */
|
||||||
|
@ -1454,15 +1452,15 @@ int16_t readGesture(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Reset data */
|
/* Reset data */
|
||||||
gesture_data_.index = 0;
|
gesture_data.index = 0;
|
||||||
gesture_data_.total_gestures = 0;
|
gesture_data.total_gestures = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* Determine best guessed gesture and clean up */
|
/* Determine best guessed gesture and clean up */
|
||||||
delay(FIFO_PAUSE_TIME);
|
delay(FIFO_PAUSE_TIME);
|
||||||
decodeGesture();
|
decodeGesture();
|
||||||
motion = gesture_motion_;
|
motion = gesture.motion_;
|
||||||
resetGestureParameters();
|
resetGestureParameters();
|
||||||
return motion;
|
return motion;
|
||||||
}
|
}
|
||||||
|
@ -1509,17 +1507,17 @@ void readAllColorAndProximityData(void) {
|
||||||
* @brief Resets all the parameters in the gesture data member
|
* @brief Resets all the parameters in the gesture data member
|
||||||
*/
|
*/
|
||||||
void resetGestureParameters(void) {
|
void resetGestureParameters(void) {
|
||||||
gesture_data_.index = 0;
|
gesture_data.index = 0;
|
||||||
gesture_data_.total_gestures = 0;
|
gesture_data.total_gestures = 0;
|
||||||
|
|
||||||
gesture_ud_delta_ = 0;
|
gesture.ud_delta_ = 0;
|
||||||
gesture_lr_delta_ = 0;
|
gesture.lr_delta_ = 0;
|
||||||
|
|
||||||
gesture_ud_count_ = 0;
|
gesture.ud_count_ = 0;
|
||||||
gesture_lr_count_ = 0;
|
gesture.lr_count_ = 0;
|
||||||
|
|
||||||
gesture_state_ = 0;
|
gesture.state_ = 0;
|
||||||
gesture_motion_ = DIR_NONE;
|
gesture.motion_ = DIR_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1545,23 +1543,23 @@ bool processGestureData(void) {
|
||||||
uint16_t i;
|
uint16_t i;
|
||||||
|
|
||||||
/* If we have less than 4 total gestures, that's not enough */
|
/* If we have less than 4 total gestures, that's not enough */
|
||||||
if (gesture_data_.total_gestures <= 4) {
|
if (gesture_data.total_gestures <= 4) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check to make sure our data isn't out of bounds */
|
/* Check to make sure our data isn't out of bounds */
|
||||||
if ((gesture_data_.total_gestures <= 32) && \
|
if ((gesture_data.total_gestures <= 32) && \
|
||||||
(gesture_data_.total_gestures > 0)) {
|
(gesture_data.total_gestures > 0)) {
|
||||||
/* Find the first value in U/D/L/R above the threshold */
|
/* Find the first value in U/D/L/R above the threshold */
|
||||||
for (i = 0; i < gesture_data_.total_gestures; i++) {
|
for (i = 0; i < gesture_data.total_gestures; i++) {
|
||||||
if ((gesture_data_.u_data[i] > GESTURE_THRESHOLD_OUT) &&
|
if ((gesture_data.u_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.d_data[i] > GESTURE_THRESHOLD_OUT) &&
|
(gesture_data.d_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.l_data[i] > GESTURE_THRESHOLD_OUT) &&
|
(gesture_data.l_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.r_data[i] > GESTURE_THRESHOLD_OUT) ) {
|
(gesture_data.r_data[i] > GESTURE_THRESHOLD_OUT) ) {
|
||||||
u_first = gesture_data_.u_data[i];
|
u_first = gesture_data.u_data[i];
|
||||||
d_first = gesture_data_.d_data[i];
|
d_first = gesture_data.d_data[i];
|
||||||
l_first = gesture_data_.l_data[i];
|
l_first = gesture_data.l_data[i];
|
||||||
r_first = gesture_data_.r_data[i];
|
r_first = gesture_data.r_data[i];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1572,15 +1570,15 @@ bool processGestureData(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Find the last value in U/D/L/R above the threshold */
|
/* Find the last value in U/D/L/R above the threshold */
|
||||||
for (i = gesture_data_.total_gestures - 1; i >= 0; i--) {
|
for (i = gesture_data.total_gestures - 1; i >= 0; i--) {
|
||||||
if ((gesture_data_.u_data[i] > GESTURE_THRESHOLD_OUT) &&
|
if ((gesture_data.u_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.d_data[i] > GESTURE_THRESHOLD_OUT) &&
|
(gesture_data.d_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.l_data[i] > GESTURE_THRESHOLD_OUT) &&
|
(gesture_data.l_data[i] > GESTURE_THRESHOLD_OUT) &&
|
||||||
(gesture_data_.r_data[i] > GESTURE_THRESHOLD_OUT)) {
|
(gesture_data.r_data[i] > GESTURE_THRESHOLD_OUT)) {
|
||||||
u_last = gesture_data_.u_data[i];
|
u_last = gesture_data.u_data[i];
|
||||||
d_last = gesture_data_.d_data[i];
|
d_last = gesture_data.d_data[i];
|
||||||
l_last = gesture_data_.l_data[i];
|
l_last = gesture_data.l_data[i];
|
||||||
r_last = gesture_data_.r_data[i];
|
r_last = gesture_data.r_data[i];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1597,25 +1595,25 @@ bool processGestureData(void) {
|
||||||
lr_delta = lr_ratio_last - lr_ratio_first;
|
lr_delta = lr_ratio_last - lr_ratio_first;
|
||||||
|
|
||||||
/* Accumulate the UD and LR delta values */
|
/* Accumulate the UD and LR delta values */
|
||||||
gesture_ud_delta_ += ud_delta;
|
gesture.ud_delta_ += ud_delta;
|
||||||
gesture_lr_delta_ += lr_delta;
|
gesture.lr_delta_ += lr_delta;
|
||||||
|
|
||||||
/* Determine U/D gesture */
|
/* Determine U/D gesture */
|
||||||
if (gesture_ud_delta_ >= GESTURE_SENSITIVITY_1) {
|
if (gesture.ud_delta_ >= GESTURE_SENSITIVITY_1) {
|
||||||
gesture_ud_count_ = 1;
|
gesture.ud_count_ = 1;
|
||||||
} else if (gesture_ud_delta_ <= -GESTURE_SENSITIVITY_1) {
|
} else if (gesture.ud_delta_ <= -GESTURE_SENSITIVITY_1) {
|
||||||
gesture_ud_count_ = -1;
|
gesture.ud_count_ = -1;
|
||||||
} else {
|
} else {
|
||||||
gesture_ud_count_ = 0;
|
gesture.ud_count_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Determine L/R gesture */
|
/* Determine L/R gesture */
|
||||||
if (gesture_lr_delta_ >= GESTURE_SENSITIVITY_1) {
|
if (gesture.lr_delta_ >= GESTURE_SENSITIVITY_1) {
|
||||||
gesture_lr_count_ = 1;
|
gesture.lr_count_ = 1;
|
||||||
} else if (gesture_lr_delta_ <= -GESTURE_SENSITIVITY_1) {
|
} else if (gesture.lr_delta_ <= -GESTURE_SENSITIVITY_1) {
|
||||||
gesture_lr_count_ = -1;
|
gesture.lr_count_ = -1;
|
||||||
} else {
|
} else {
|
||||||
gesture_lr_count_ = 0;
|
gesture.lr_count_ = 0;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1627,37 +1625,37 @@ bool processGestureData(void) {
|
||||||
*/
|
*/
|
||||||
bool decodeGesture(void) {
|
bool decodeGesture(void) {
|
||||||
/* Determine swipe direction */
|
/* Determine swipe direction */
|
||||||
if ((gesture_ud_count_ == -1) && (gesture_lr_count_ == 0)) {
|
if ((gesture.ud_count_ == -1) && (gesture.lr_count_ == 0)) {
|
||||||
gesture_motion_ = DIR_UP;
|
gesture.motion_ = DIR_UP;
|
||||||
} else if ((gesture_ud_count_ == 1) && (gesture_lr_count_ == 0)) {
|
} else if ((gesture.ud_count_ == 1) && (gesture.lr_count_ == 0)) {
|
||||||
gesture_motion_ = DIR_DOWN;
|
gesture.motion_ = DIR_DOWN;
|
||||||
} else if ((gesture_ud_count_ == 0) && (gesture_lr_count_ == 1)) {
|
} else if ((gesture.ud_count_ == 0) && (gesture.lr_count_ == 1)) {
|
||||||
gesture_motion_ = DIR_RIGHT;
|
gesture.motion_ = DIR_RIGHT;
|
||||||
} else if ((gesture_ud_count_ == 0) && (gesture_lr_count_ == -1)) {
|
} else if ((gesture.ud_count_ == 0) && (gesture.lr_count_ == -1)) {
|
||||||
gesture_motion_ = DIR_LEFT;
|
gesture.motion_ = DIR_LEFT;
|
||||||
} else if ((gesture_ud_count_ == -1) && (gesture_lr_count_ == 1)) {
|
} else if ((gesture.ud_count_ == -1) && (gesture.lr_count_ == 1)) {
|
||||||
if (abs(gesture_ud_delta_) > abs(gesture_lr_delta_)) {
|
if (abs(gesture.ud_delta_) > abs(gesture.lr_delta_)) {
|
||||||
gesture_motion_ = DIR_UP;
|
gesture.motion_ = DIR_UP;
|
||||||
} else {
|
} else {
|
||||||
gesture_motion_ = DIR_RIGHT;
|
gesture.motion_ = DIR_RIGHT;
|
||||||
}
|
}
|
||||||
} else if ((gesture_ud_count_ == 1) && (gesture_lr_count_ == -1)) {
|
} else if ((gesture.ud_count_ == 1) && (gesture.lr_count_ == -1)) {
|
||||||
if (abs(gesture_ud_delta_) > abs(gesture_lr_delta_)) {
|
if (abs(gesture.ud_delta_) > abs(gesture.lr_delta_)) {
|
||||||
gesture_motion_ = DIR_DOWN;
|
gesture.motion_ = DIR_DOWN;
|
||||||
} else {
|
} else {
|
||||||
gesture_motion_ = DIR_LEFT;
|
gesture.motion_ = DIR_LEFT;
|
||||||
}
|
}
|
||||||
} else if ((gesture_ud_count_ == -1) && (gesture_lr_count_ == -1)) {
|
} else if ((gesture.ud_count_ == -1) && (gesture.lr_count_ == -1)) {
|
||||||
if (abs(gesture_ud_delta_) > abs(gesture_lr_delta_)) {
|
if (abs(gesture.ud_delta_) > abs(gesture.lr_delta_)) {
|
||||||
gesture_motion_ = DIR_UP;
|
gesture.motion_ = DIR_UP;
|
||||||
} else {
|
} else {
|
||||||
gesture_motion_ = DIR_LEFT;
|
gesture.motion_ = DIR_LEFT;
|
||||||
}
|
}
|
||||||
} else if ((gesture_ud_count_ == 1) && (gesture_lr_count_ == 1)) {
|
} else if ((gesture.ud_count_ == 1) && (gesture.lr_count_ == 1)) {
|
||||||
if (abs(gesture_ud_delta_) > abs(gesture_lr_delta_)) {
|
if (abs(gesture.ud_delta_) > abs(gesture.lr_delta_)) {
|
||||||
gesture_motion_ = DIR_DOWN;
|
gesture.motion_ = DIR_DOWN;
|
||||||
} else {
|
} else {
|
||||||
gesture_motion_ = DIR_RIGHT;
|
gesture.motion_ = DIR_RIGHT;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
@ -1763,9 +1761,15 @@ void APDS9960_detect(void) {
|
||||||
if (APDS9960type || I2cActive(APDS9960_I2C_ADDR)) { return; }
|
if (APDS9960type || I2cActive(APDS9960_I2C_ADDR)) { return; }
|
||||||
|
|
||||||
APDS9960type = I2cRead8(APDS9960_I2C_ADDR, APDS9960_ID);
|
APDS9960type = I2cRead8(APDS9960_I2C_ADDR, APDS9960_ID);
|
||||||
|
|
||||||
|
#ifdef USE_DEBUG_DRIVER
|
||||||
|
// Debug new chip
|
||||||
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("DRV: %s Chip %X"), APDS9960_TAG, APDS9960type);
|
||||||
|
#endif // USE_DEBUG_DRIVER
|
||||||
|
|
||||||
if (APDS9960type == APDS9960_CHIPID_1 || APDS9960type == APDS9960_CHIPID_2 || APDS9960type == APDS9960_CHIPID_3) {
|
if (APDS9960type == APDS9960_CHIPID_1 || APDS9960type == APDS9960_CHIPID_2 || APDS9960type == APDS9960_CHIPID_3) {
|
||||||
if (APDS9960_init()) {
|
if (APDS9960_init()) {
|
||||||
I2cSetActiveFound(APDS9960_I2C_ADDR, APDS9960stype);
|
I2cSetActiveFound(APDS9960_I2C_ADDR, APDS9960_TAG);
|
||||||
|
|
||||||
enableProximitySensor();
|
enableProximitySensor();
|
||||||
enableGestureSensor();
|
enableGestureSensor();
|
||||||
|
@ -1811,15 +1815,15 @@ void APDS9960_show(bool json) {
|
||||||
|
|
||||||
if (json) {
|
if (json) {
|
||||||
ResponseAppend_P(PSTR(",\"%s\":{\"Red\":%s,\"Green\":%s,\"Blue\":%s,\"Ambient\":%s,\"CCT\":%s,\"Proximity\":%s}"),
|
ResponseAppend_P(PSTR(",\"%s\":{\"Red\":%s,\"Green\":%s,\"Blue\":%s,\"Ambient\":%s,\"CCT\":%s,\"Proximity\":%s}"),
|
||||||
APDS9960stype, red_chr, green_chr, blue_chr, ambient_chr, cct_chr, prox_chr);
|
APDS9960_TAG, red_chr, green_chr, blue_chr, ambient_chr, cct_chr, prox_chr);
|
||||||
#ifdef USE_WEBSERVER
|
#ifdef USE_WEBSERVER
|
||||||
} else {
|
} else {
|
||||||
WSContentSend_PD(HTTP_APDS_9960_SNS, red_chr, green_chr, blue_chr, ambient_chr, cct_chr, prox_chr);
|
WSContentSend_PD(HTTP_APDS9960_SNS, red_chr, green_chr, blue_chr, ambient_chr, cct_chr, prox_chr);
|
||||||
#endif // USE_WEBSERVER
|
#endif // USE_WEBSERVER
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (json && (currentGesture[0] != '\0' )) {
|
if (json && (currentGesture[0] != '\0' )) {
|
||||||
ResponseAppend_P(PSTR(",\"%s\":{\"%s\":1}"), APDS9960stype, currentGesture);
|
ResponseAppend_P(PSTR(",\"%s\":{\"%s\":1}"), APDS9960_TAG, currentGesture);
|
||||||
currentGesture[0] = '\0';
|
currentGesture[0] = '\0';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue