Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Un saluto a tutti i lettori della sezione “Fai da te o fai da te” su Habr! L'articolo di oggi riguarderà l'interruttore touch sul chip TTP223 | scheda dati. L'interruttore funziona sul microcontrollore nRF52832 | scheda dati, è stato utilizzato un modulo YJ-17103 con un'antenna stampata e un connettore per un'antenna MHF4 esterna. L'interruttore a sfioramento funziona con batterie CR2430 o CR2450. Il consumo in modalità di trasmissione non è superiore a 8 mA, in modalità di sospensione non è superiore a 6 µA.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Come tutti i progetti precedenti, anche questo è un progetto Arduino, il programma è scritto nell'IDE di Arduino. L'implementazione software del dispositivo si basa sul protocollo Mysensors | Librerie GitHub, Supporto della scheda nRF5 GitHub in Mysensors. Forum della comunità in lingua inglese - http://forum.mysensors.org, forum della comunità in lingua russa - http://mysensors.ru/forum/
(Per chi vuole studiare - Documentazione, Protocollo seriale, API, protocollo, analizzatore | per chi volesse assistere (contributi) nello sviluppo del progetto - Documentazione)

La scheda dell'interruttore tattile è stata sviluppata nel programma Deeptrace, tenendo conto della successiva produzione utilizzando il metodo Laser Ironing Technology (LUT). Il pannello è stato sviluppato nelle dimensioni di 60x60mm (un pannello di vetro standard ha dimensioni di 80x80mm). Il circuito è stato stampato sulle pagine della rivista Antenna e trasferito con un ferro Bosch con impostazione “Len” (massima potenza) su un cartoncino in fibra di vetro biadesivo da 1.5mm, 35μm (in assenza di altro).
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

L'attacco è stato effettuato con una soluzione di cloruro ferrico, precedentemente preparata nelle proporzioni di 1.5 cucchiaini da tè per 250 ml di acqua tiepida. Il processo è durato 15 minuti.
La perforazione dei fori per le vie interstrato e per il fissaggio del supporto batteria è stata eseguita con un mini-trapano DREMEL 3000 montato su un supporto per trapano DREMEL 220. I fori per le vie interstrato sono stati eseguiti con un trapano da 0,4 mm, i fori per il supporto della batteria con un trapano da 1,1 mm . La rifilatura lungo i bordi del pannello è stata eseguita con lo stesso mini-trapano dotato di attacco DREMEL 540 (cerchio di taglio d=32.0 mm). La potatura è stata eseguita in un respiratore.
La stagnatura della tavola incisa è stata effettuata utilizzando la lega di rosa in una soluzione acquosa (1 cucchiaino di acido citrico cristallizzato per 300 ml di acqua).

Il processo di saldatura è durato circa un'ora, la maggior parte del tempo è stata spesa per saldare il filo (stagnato, di 0.4 mm di diametro) nei fori per i passaggi interstrato.

La tavola è stata lavata con il detergente aerosol FLUX OFF.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

La progettazione del corpo del dispositivo è stata eseguita in un editor di progettazione tridimensionale assistita da computer. Dimensioni della cassa 78,5 mm X 78,5 mm X 12 mm.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Il modello completo della custodia e del coperchio del vano batteria è stato salvato in formato STL, quindi è stato necessario preparare questi modelli per la stampa su una stampante SLA (aggiunta di supporti, orientamento). A questo punto è sorto un piccolo problema, poiché l'area di stampa delle stampanti SLA domestiche è piccola. Il modello della custodia del dispositivo nella posizione ottimale rispetto al tempo di stampa non rientrava nelle dimensioni dell'area di stampa. Anche il posizionamento del modello a 45 gradi ha dato un risultato deludente; il peso del supporto era uguale al peso del modello del corpo. Si è deciso di stampare il modello in verticale, realizzando un supporto su uno dei lati anteriori, previo accordo con la post-elaborazione. La stampa del corpo ha richiesto 5 ore con un'impostazione dello strato di 50 micron. Successivamente la lavorazione è stata effettuata utilizzando carta vetrata a grana molto fine (non scrivo il numero perché non lo so :)). La stampa del coperchio della batteria ha richiesto 40 minuti.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

I pannelli in vetro di Aliexpress vengono venduti con un telaio in plastica già incollato, non ci sono stati problemi con la rimozione del telaio. Ho rimosso il pannello di vetro dopo averlo preriscaldato con un normale asciugacapelli.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Il diffusore per la retroilluminazione a LED è stato realizzato in nastro biadesivo con adesivo acrilico 3M 9088-200. Per l'illuminazione fluorescente si poteva scegliere tra diversi materiali, nastro adesivo cinese e carta adesiva tagliata a nastro dell'azienda nazionale Luminofor. La scelta è stata fatta a favore di un produttore nazionale, secondo i miei sentimenti ha brillato più luminoso e più a lungo. Sopra è stato incollato un quadrato di carta con pigmento fluorescente con nastro biadesivo 3M 9088-200.

Il vetro è stato incollato al corpo dell'interruttore tramite nastro biadesivo con adesivo acrilico 3M VHB 4910.
Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Il coperchio è stato fissato con una vite M 1,4 X 5 mm.

Il costo del dispositivo era di 890 rubli.

Poi è arrivata la parte del programma. Ci sono stati alcuni problemi. Si scopre che i chip del sensore TTP223 funzionano benissimo con un'alimentazione stabilizzata da 3.3 V e non molto bene se alimentati direttamente da una batteria ben scarica. Avviando il dispositivo con un'alimentazione di circa 2.5 V, oltre a un ulteriore "prelievo" durante l'elaborazione della presentazione Mysensors, il microcircuito TTP223 (immediatamente dopo la calibrazione) ha causato un'interruzione del MK poiché era con un trigger attivo.

Il circuito di alimentazione del microcircuito è stato modificato (gestione dell'alimentazione TTP223 con gpio MK), è stata fornita ulteriore massa e sulle linee led RGB (che corrono sull'altro lato della scheda del sensore capacitivo) sono state sostituite resistenze con resistenza maggiore. Al software è stato aggiunto anche: l'attivazione dell'alimentazione per il microcircuito capacitivo dopo l'avvio del framework Mysensors e l'elaborazione della presentazione. Il ritardo per la calibrazione automatica del chip TTP223 quando viene applicata l'alimentazione è stato raddoppiato. Tutti questi cambiamenti hanno completamente eliminato questo problema.

Prima di visualizzare il codice del programma, ti consiglio di familiarizzare con la struttura di base degli schizzi 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 test del programma touch switch: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

L'interruttore ha un pulsante a sfioramento e un pulsante tattile sul retro del dispositivo. Questo pulsante tattile verrà utilizzato per le modalità di servizio, la modalità di associazione via etere e il ripristino del dispositivo. Il pulsante ha una funzione antirimbalzo del ferro. La linea del sensore capacitivo e la linea del pulsante tattile sono collegate tramite diodi Schottky e collegate al pin analogico p0.05, e anche dal sensore capacitivo e dal pulsante tattile ci sono linee ai pin MK p0.25 e p0.27 .0.05 per la lettura degli stati dopo aver attivato l'interrupt sul pin p0.05. Sul pin pXNUMX viene attivato un interrupt tramite il comparatore (NRF_LPCOMP) tramite EVENTS_UP. Ho ricevuto l'ispirazione per risolvere il problema qui и qui.

Lo switch è stato aggiunto alla rete Mysensors, gestita dal controller smart home Majordomo (sito del progetto)

Codice PHP per aggiungere un'opzione al metodo 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');
} 
}

Guarda il risultato nel video

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Successivamente è stata realizzata un'opzione con un convertitore boost, ma ciò non è correlato al funzionamento del microcircuito capacitivo TTP223, c'è più desiderio di un'illuminazione buona e uniforme quando si premono i tasti per tutta la durata della batteria.

VedereInterruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Progetto Github - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

di lingua russa sito della comunità I miei sensori

Chatta su Telegram Mysensors — soluzione rapida ai problemi con Mysensors, suggerimenti, trucchi, installazione di schede, utilizzo dei microcontrollori atmega 328, stm32, nRF5 nell'IDE Arduino — @mysensors_rus

Poche immaginiInterruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Interruttore tattile wireless con retroilluminazione fluorescente aggiuntiva

Fonte: habr.com

Aggiungi un commento