Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Saluti à tutti i lettori di a sezione "DIY or Do It Yourself" in Habr ! articulu d'oghje sarà circa u toccu switch nant'à u chip TTP223 | datasheet. U switch opera nant'à u microcontroller nRF52832 | datasheet, un modulu YJ-17103 cù una antenna stampata è un connector per una antenna MHF4 esterna hè stata utilizata. L'interruttore touch opera cù batterie CR2430 o CR2450. U cunsumu in u modu di trasmissione ùn hè micca più di 8 mA, in u modu di sonnu micca più di 6 µA.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Cum'è tutti i prughjetti previ, questu hè ancu un prughjettu Arduino, u prugramma hè scrittu in l'IDE Arduino. L'implementazione di u software di u dispusitivu hè basatu annantu à u protocolu Mysensors | librerie GitHub, nRF5 supporta GitHub in Mysensors. Forum di a cumunità in lingua inglese - http://forum.mysensors.org, forum di a cumunità in lingua russa - http://mysensors.ru/forum/
(Per quelli chì volenu studià - Documentazione, Protocollu Seriale, API, Prutucollu, Parser | per quelli chì vulianu aiutà (Cuntenuti) in u sviluppu di u prugettu - Documentazione)

U tavulinu di u toccu hè statu sviluppatu in u prugramma Deeptrace, tenendu in contu a fabricazione successiva cù u metudu Laser Ironing Technology (LUT). A tavola hè stata sviluppata in dimensioni di 60x60mm (un pannellu di vetru standard hà dimensioni di 80x80mm). U circuitu hè statu stampatu nantu à e pagine di a rivista Antenna è trasferitu cù un ferru Bosch cù u paràmetru "Len" (potenza massima) nantu à una tavola di fibra di vetro foglia à doppia faccia 1.5mm, 35µm (in assenza di un altru).
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

L'incisione hè stata realizata cù una suluzione di ferric chloride, preparata prima in proporzioni di 1.5 teaspoons per 250 ml d'acqua calda. U prucessu hà pigliatu 15 minuti.
Perforazione per via interlayer è per fissazione di u supportu di a batteria hè stata fatta cù un mini-drill DREMEL 3000 muntatu nantu à un supportu di perforazione DREMEL 220 I fori per via interlayer sò stati perforati cù un drill 0,4mm, fori per u supportu di batteria cù un drill 1,1mm. . Trimming along the borders of the board hè stata fatta cù u listessu mini-drill cun un attache DREMEL 540 (Cutting circle d=32.0mm). A poda hè stata fatta in un respiratore.
Tinning of the etched board hè stata fatta cù Rose alloy in una suluzione acquosa (1 cucchiara di l'acidu citricu cristalizatu per 300 ml d'acqua).

U prucessu di saldatura hà pigliatu circa una ora, a maiò parte di u tempu hè stata passata filu di saldatura (stagnatu, 0.4 mm di diametru) in i buchi per via interlayer.

A tavola hè stata lavata cù un detergente aerosol FLUX OFF.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

U disignu di u corpu di u dispusitivu hè statu realizatu in un editore di disignu tridimensionale assistitu da computer. Dimensioni di u casu 78,5 mm X 78,5 mm X 12 mm.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

U mudellu cumpletu di u casu è a tappa di u compartimentu di a bateria hè stata salvata in u formatu STL, allora era necessariu di preparà questi mudelli per stampà nantu à una stampante SLA (aghjunghje supporti, orientazione). In questu stadiu, hè ghjuntu un picculu prublema, postu chì l'area di stampa di l'imprese SLA domestiche hè chjuca. U mudellu di u casu di u dispusitivu in a pusizioni più ottimali relative à u tempu di stampa ùn hè micca adattatu in e dimensioni di a zona di stampa. Quandu si mette u mudellu à 45 gradi, hà ancu datu un risultatu disappuntu, u pesu di u sustegnu era uguali à u pesu di u mudellu di corpu. Hè statu decisu di stampà u mudellu verticalmente, facendu un supportu nantu à unu di i lati di fronte, avè accunsentutu in anticipu cù u fattu di post-processamentu. A stampa di u corpu hà pigliatu 5 ore cù una paràmetra di strata di 50 microns. In seguitu, a trasfurmazioni hè stata realizata cù una carta sabbia finissima (ùn scriveraghju micca u numeru perchè ùn cunnosci micca :)). A tappa di a bateria hà pigliatu 40 minuti per stampà.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

I pannelli di vetru da Aliexpress sò venduti cù un quadru di plastica digià incollatu, ùn ci era micca prublemi per sguassà u quadru. Aghju sguassatu u pannellu di vetru dopu avè preheating cù un secadoru regulare.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

U diffusore per a retroilluminazione LED hè stata fatta di cinta bifacciale cù adesivo acrilico 3M 9088-200. Per l'illuminazione fluorescente, ci sò parechji materiali per sceglie, a cinta adhesiva cinese è a carta adesiva tagliata in cinta da a cumpagnia domestica Luminofor. L'scelta hè stata fatta in favore di un fabricatore domesticu secondu i mo sentimenti, brillava più è più longu. Un quadru di carta cù pigmentu fluoriscente hè stata pegata nantu à a cima cù cinta 3M 9088-200 doppia faccia.

U vetru hè stata incollata à u corpu di l'interruttore cù una cinta bifacciale cù adesivo acrilico 3M VHB 4910.
Interruttore touch wireless cù retroilluminazione fluorescente addiziale

A tappa hè stata fissata cù una viti M 1,4 X 5 mm.

U costu di u dispusitivu era 890 rubles.

Dopu hè vinutu a parte di u prugramma. Ci era qualchi prublemi. Risulta chì i chips di sensori TTP223 funzionanu bè cù una alimentazione stabilizzata di 3.3V è micca assai bè quandu alimentate direttamente da una bateria ben scaricata. Quandu si principia u dispusitivu cù una fonte di energia intornu à 2.5v, più dopu un "drawdown" supplementu quandu travaglia a presentazione Mysensors, u microcircuit TTP223 (subitu dopu a calibrazione) hà causatu una interruzzione di u MK postu chì era cun un trigger attivu.

U circuitu di supply supply à u microcircuit hè statu cambiatu (gestione di l'energia TTP223 cù gpio MK), un terrenu supplementu hè statu furnitu, è i resistori cù una resistenza più altu sò stati rimpiazzati nantu à e linee led rgb (chì correnu da l'altra parte di u sensore capacitivu). Hè statu ancu aghjuntu à u software: attivazione di u putere per u microcircuit capacitivu dopu avè principiatu u framework Mysensors è travaglià a presentazione. U ritardu per l'autocalibrazione di u chip TTP223 quandu u putere hè applicatu hè duppiatu. Tutti issi cambiamenti eliminati cumplettamente stu prublema.

Prima di vede u codice di u prugramma, vi ricumandemu di familiarizàvi cù a struttura basica di sketch in Mysensors.void before()
{
// Дополнительная функция, если сравнивать со стандартной структурой Ардуино скетчей, то before() это подобие setup(), отработка происходит до инициализации транспортного уровня Mysensors, рекомендуется например для инициализации устройств SPI
}

void setup()
{

}

void presentation()
{
//Тут происходит презентация ноды и ее сенсоров на контролере через маршрутизатор
sendSketchInfo("Name of my sensor node", "1.0"); // презентация названия ноды, версии ПО
present(CHILD_ID, S_WHATEVER, "Description"); // презентация сенсоров ноды, описания сенсоров
}

void loop()
{

}

Codice di prova di u prugramma di l'interruttore Touch:test_sens.ino
/**
ТЕСТОВЫЙ СКЕТЧ СЕНСОРНОГО ВЫКЛЮЧАТЕЛЯ С ПРЕРЫВАНИЯМИ НА NRF_LPCOMP
*/
bool button_flag;
bool sens_flag;
bool send_flag;
bool detection;
bool nosleep;
byte timer;
unsigned long SLEEP_TIME = 21600000; //6 hours
unsigned long oldmillis;
unsigned long newmillis;
unsigned long interrupt_time;
unsigned long SLEEP_TIME_W;
uint16_t currentBatteryPercent;
uint16_t batteryVoltage = 0;
uint16_t battery_vcc_min = 2400;
uint16_t battery_vcc_max = 3000;

#define MY_RADIO_NRF5_ESB
//#define MY_PASSIVE_NODE
#define MY_NODE_ID 30
#define MY_PARENT_NODE_ID 0
#define MY_PARENT_NODE_IS_STATIC
#define MY_TRANSPORT_UPLINK_CHECK_DISABLED
#define IRT_PIN 3 //(PORT0, gpio 5)
#include <MySensors.h>
// see https://www.mysensors.org/download/serial_api_20
#define SENS_CHILD_ID 0
#define CHILD_ID_VOLT 254
MyMessage sensMsg(SENS_CHILD_ID, V_VAR1);
//MyMessage voltMsg(CHILD_ID_VOLT, V_VOLTAGE);

void preHwInit() {
sleep(2000);
pinMode(RED_LED, OUTPUT);
digitalWrite(RED_LED, HIGH);
pinMode(GREEN_LED, OUTPUT);
digitalWrite(GREEN_LED, HIGH);
pinMode(BLUE_LED, OUTPUT);
digitalWrite(BLUE_LED, HIGH);
pinMode(MODE_PIN, INPUT);
pinMode(SENS_PIN, INPUT);
}

void before()
{
NRF_POWER->DCDCEN = 1;
NRF_UART0->ENABLE = 0;
sleep(1000);
digitalWrite(BLUE_LED, LOW);
sleep(150);
digitalWrite(BLUE_LED, HIGH);
}

void presentation() {
sendSketchInfo("EFEKTA Sens 1CH Sensor", "1.1");
present(SENS_CHILD_ID, S_CUSTOM, "SWITCH STATUS");
//present(CHILD_ID_VOLT, S_MULTIMETER, "Battery");
}

void setup() {
digitalWrite(BLUE_LED, LOW);
sleep(100);
digitalWrite(BLUE_LED, HIGH);
sleep(200);
digitalWrite(BLUE_LED, LOW);
sleep(100);
digitalWrite(BLUE_LED, HIGH);
lpComp();
detection = false;
SLEEP_TIME_W = SLEEP_TIME;
pinMode(31, OUTPUT);
digitalWrite(31, HIGH);
/*
while (timer < 10) {
timer++;
digitalWrite(GREEN_LED, LOW);
wait(5);
digitalWrite(GREEN_LED, HIGH);
wait(500);
}
timer = 0;
*/
sleep(7000);
while (timer < 3) {
timer++;
digitalWrite(GREEN_LED, LOW);
sleep(15);
digitalWrite(GREEN_LED, HIGH);
sleep(85);
}
timer = 0;
sleep(1000);
}

void loop() {

if (detection) {
if (digitalRead(MODE_PIN) == 1 && button_flag == 0 && digitalRead(SENS_PIN) == 0) {
//back side button detection
button_flag = 1;
nosleep = 1;
}
if (digitalRead(MODE_PIN) == 1 && button_flag == 1 && digitalRead(SENS_PIN) == 0) {
digitalWrite(RED_LED, LOW);
wait(10);
digitalWrite(RED_LED, HIGH);
wait(50);
}
if (digitalRead(MODE_PIN) == 0 && button_flag == 1 && digitalRead(SENS_PIN) == 0) {
nosleep = 0;
button_flag = 0;
digitalWrite(RED_LED, HIGH);
lpComp_reset();
}

if (digitalRead(SENS_PIN) == 1 && sens_flag == 0 && digitalRead(MODE_PIN) == 0) {
//sens detection
sens_flag = 1;
nosleep = 1;
newmillis = millis();
interrupt_time = newmillis - oldmillis;
SLEEP_TIME_W = SLEEP_TIME_W - interrupt_time;
if (send(sensMsg.set(detection))) {
send_flag = 1;
}
}
if (digitalRead(SENS_PIN) == 1 && sens_flag == 1 && digitalRead(MODE_PIN) == 0) {
if (send_flag == 1) {
while (timer < 10) {
timer++;
digitalWrite(GREEN_LED, LOW);
wait(20);
digitalWrite(GREEN_LED, HIGH);
wait(30);
}
timer = 0;
} else {
while (timer < 10) {
timer++;
digitalWrite(RED_LED, LOW);
wait(20);
digitalWrite(RED_LED, HIGH);
wait(30);
}
timer = 0;
}
}
if (digitalRead(SENS_PIN) == 0 && sens_flag == 1 && digitalRead(MODE_PIN) == 0) {
sens_flag = 0;
nosleep = 0;
send_flag = 0;
digitalWrite(GREEN_LED, HIGH);
sleep(500);
lpComp_reset();
}
if (SLEEP_TIME_W < 60000) {
SLEEP_TIME_W = SLEEP_TIME;
sendBatteryStatus();
}
}
else {
//if (detection == -1) {
SLEEP_TIME_W = SLEEP_TIME;
sendBatteryStatus();
}
if (nosleep == 0) {
oldmillis = millis();
sleep(SLEEP_TIME_W);
}
}

void sendBatteryStatus() {
wait(20);
batteryVoltage = hwCPUVoltage();
wait(2);

if (batteryVoltage > battery_vcc_max) {
currentBatteryPercent = 100;
}
else if (batteryVoltage < battery_vcc_min) {
currentBatteryPercent = 0;
} else {
currentBatteryPercent = (100 * (batteryVoltage - battery_vcc_min)) / (battery_vcc_max - battery_vcc_min);
}

sendBatteryLevel(currentBatteryPercent, 1);
wait(2000, C_INTERNAL, I_BATTERY_LEVEL);
//send(powerMsg.set(batteryVoltage), 1);
//wait(2000, 1, V_VAR1);
}

void lpComp() {
NRF_LPCOMP->PSEL = IRT_PIN;
NRF_LPCOMP->ANADETECT = 1;
NRF_LPCOMP->INTENSET = B0100;
NRF_LPCOMP->ENABLE = 1;
NRF_LPCOMP->TASKS_START = 1;
NVIC_SetPriority(LPCOMP_IRQn, 15);
NVIC_ClearPendingIRQ(LPCOMP_IRQn);
NVIC_EnableIRQ(LPCOMP_IRQn);
}

void s_lpComp() {
if ((NRF_LPCOMP->ENABLE) && (NRF_LPCOMP->EVENTS_READY)) {
NRF_LPCOMP->INTENCLR = B0100;
}
}

void r_lpComp() {
NRF_LPCOMP->INTENSET = B0100;
}

#if __CORTEX_M == 0x04
#define NRF5_RESET_EVENT(event)
event = 0;
(void)event
#else
#define NRF5_RESET_EVENT(event) event = 0
#endif

extern "C" {
void LPCOMP_IRQHandler(void) {
detection = true;
NRF5_RESET_EVENT(NRF_LPCOMP->EVENTS_UP);
NRF_LPCOMP->EVENTS_UP = 0;
MY_HW_RTC->CC[0] = (MY_HW_RTC->COUNTER + 2);
}
}

void lpComp_reset () {
s_lpComp();
detection = false;
NRF_LPCOMP->EVENTS_UP = 0;
r_lpComp();
}

MyBoardNRF5.cpp
#ifdef MYBOARDNRF5
#include <variant.h>

/*
* Pins descriptions. Attributes are ignored by arduino-nrf5 variant.
* Definition taken from Arduino Primo Core with ordered ports
*/
const PinDescription g_APinDescription[]=
{
{ NOT_A_PORT, 0, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // LFCLK
{ NOT_A_PORT, 1, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // LFCLK
{ PORT0, 2, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A0, PWM4, NOT_ON_TIMER},
{ PORT0, 3, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A1, PWM5, NOT_ON_TIMER},
{ PORT0, 4, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A2, PWM6, NOT_ON_TIMER},
{ PORT0, 5, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A3, PWM7, NOT_ON_TIMER},
{ PORT0, 6, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT3
{ PORT0, 7, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT4
{ PORT0, 8, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM10, NOT_ON_TIMER}, //USER_LED
{ PORT0, 9, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // NFC1
{ PORT0, 10, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // NFC2
{ PORT0, 11, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // TX
{ PORT0, 12, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // RX
{ PORT0, 13, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // SDA
{ PORT0, 14, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // SCL
{ PORT0, 15, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // SDA1
{ PORT0, 16, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // SCL1
{ PORT0, 17, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // TP4
{ PORT0, 18, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // TP5
{ PORT0, 19, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT2
{ PORT0, 20, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT1
{ PORT0, 21, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT1
{ PORT0, 22, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM9, NOT_ON_TIMER},
{ PORT0, 23, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM8, NOT_ON_TIMER},
{ PORT0, 24, PIO_DIGITAL, PIN_ATTR_DIGITAL, No_ADC_Channel, NOT_ON_PWM, NOT_ON_TIMER}, // INT
{ PORT0, 25, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM11, NOT_ON_TIMER}, //RED_LED
{ PORT0, 26, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM11, NOT_ON_TIMER}, //GREEN_LED
{ PORT0, 27, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), No_ADC_Channel, PWM11, NOT_ON_TIMER}, //BLUE_LED
{ PORT0, 28, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A4, PWM3, NOT_ON_TIMER},
{ PORT0, 29, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A5, PWM2, NOT_ON_TIMER},
{ PORT0, 30, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A6, PWM1, NOT_ON_TIMER},
{ PORT0, 31, PIO_DIGITAL, (PIN_ATTR_DIGITAL|PIN_ATTR_PWM), ADC_A7, PWM0, NOT_ON_TIMER}
};

// Don't remove this line
#include <compat_pin_mapping.h>

#endif

MyBoardNRF5.h
#ifndef _MYBOARDNRF5_H_
#define _MYBOARDNRF5_H_

#ifdef __cplusplus
extern "C"
{
#endif // __cplusplus

// Number of pins defined in PinDescription array
#define PINS_COUNT (32u)
#define NUM_DIGITAL_PINS (32u)
#define NUM_ANALOG_INPUTS (8u)
#define NUM_ANALOG_OUTPUTS (8u)

/*
* LEDs
*
* This is optional
*
* With My Sensors, you can use
* hwPinMode() instead of pinMode()
* hwPinMode() allows to use advanced modes like OUTPUT_H0H1 to drive LEDs.
* https://github.com/mysensors/MySensors/blob/development/drivers/NRF5/nrf5_wiring_constants.h
*
*/
#define PIN_LED1 (16)
#define PIN_LED2 (15)
#define PIN_LED3 (17)
#define RED_LED (PIN_LED1)
#define GREEN_LED (PIN_LED2)
#define BLUE_LED (PIN_LED3)
#define INTERRUPT_PIN (5)
#define MODE_PIN (25)
#define SENS_PIN (27)

/*
* Analog ports
*
* If you change g_APinDescription, replace PIN_AIN0 with
* port numbers mapped by the g_APinDescription Array.
* You can add PIN_AIN0 to the g_APinDescription Array if
* you want provide analog ports MCU independed, you can add
* PIN_AIN0..PIN_AIN7 to your custom g_APinDescription Array
* defined in MyBoardNRF5.cpp
*/
static const uint8_t A0 = ADC_A0;
static const uint8_t A1 = ADC_A1;
static const uint8_t A2 = ADC_A2;
static const uint8_t A3 = ADC_A3;
static const uint8_t A4 = ADC_A4;
static const uint8_t A5 = ADC_A5;
static const uint8_t A6 = ADC_A6;
static const uint8_t A7 = ADC_A7;

/*
* Serial interfaces
*
* RX and TX are required.
* If you have no serial port, use unused pins
* CTS and RTS are optional.
*/
#define PIN_SERIAL_RX (11)
#define PIN_SERIAL_TX (12)

#ifdef __cplusplus
}
#endif

#endif

U cambiamentu hà un buttone di toccu è un buttone di tact in u spinu di u dispusitivu. Stu buttone di tact serà utilizatu per i modi di serviziu, u modu di ubligatoriu over-the-air, è u reset di u dispositivu. U buttone hà una funzione anti-bonce di ferru. A linea di u sensoru capacitivu è a linea di u buttone di clock sò cunnessi à traversu diodi Schottky è cunnessi à u pin analogicu p0.05, è ancu da u sensor capacitivu è u buttone di clock ci sò linii à i pins MK p0.25 è p0.27. .0.05 per leghje stati dopu l'attivazione di l'interruzzione nantu à u pin p0.05. In u pin pXNUMX, una interruzzione via u comparatore (NRF_LPCOMP) via EVENTS_UP hè attivata. Ricevutu ispirazione per risolve u prublema ccà и ccà.

U cambiamentu hè statu aghjuntu à a reta Mysensors, gestita da u controller di casa intelligente Majordomo (situ web di u prugettu)

Codice PHP per aghjunghje un cambiamentu à u metudu statusUpdate

if (getGlobal("MysensorsButton01.status")==1) {
if (getGlobal('MysensorsRelay04.status') == 0) {
setGlobal('MysensorsRelay04.status', '1');
} else if (getGlobal('MysensorsRelay04.status') == 1) {
setGlobal('MysensorsRelay04.status', '0');
} 
}

Vede u risultatu in u video

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

In seguitu, una opzione hè stata fatta cù un cunvertitore boost, ma questu ùn hè micca ligatu à l'operazione di u microcircuit capacitivu TTP223, ci hè più desideriu di illuminazione bona è uniforme quandu pressu i chjavi in ​​tutta a vita di a bateria.

VedeInterruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Prughjettu Github - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

di lingua russa situ di a cumunità I miei sensori

Chat di Telegram Mysensors - suluzione rapida à i prublemi cù Mysensors, cunsiglii, trucchi, installà schede, travagliendu cù microcontrollers atmega 328, stm32, nRF5 in l'IDE Arduino - @mysensors_rus

Certi ritrattiInterruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Interruttore touch wireless cù retroilluminazione fluorescente addiziale

Source: www.habr.com

Add a comment