Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Un saúdo a todos os lectores da sección "DIY or Faino vostede mesmo" de Habr! O artigo de hoxe tratará sobre o interruptor táctil do chip TTP223 | folla de datos. O interruptor funciona no microcontrolador nRF52832 | folla de datos, utilizouse un módulo YJ-17103 cunha antena impresa e un conector para unha antena MHF4 externa. O interruptor táctil funciona con pilas CR2430 ou CR2450. O consumo en modo de transmisión non é superior a 8 mA, no modo de suspensión non superior a 6 µA.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Como todos os proxectos anteriores, este tamén é un proxecto Arduino, o programa está escrito no IDE de Arduino. A implementación de software do dispositivo baséase no protocolo Mysensors | Bibliotecas GitHub, placa nRF5 compatible con GitHub en Mysensors. foro comunitario en inglés - http://forum.mysensors.org, foro da comunidade en lingua rusa - http://mysensors.ru/forum/
(Para os que queiran estudar - Documentación, Protocolo en serie, API, Protocolo, Analizador | para aqueles que desexen axudar (contribucións) no desenvolvemento do proxecto - Documentación)

A tarxeta de interruptor táctil foi desenvolvida no programa Deeptrace, tendo en conta a fabricación posterior mediante o método Laser Ironing Technology (LUT). O taboleiro foi desenvolvido en dimensións de 60x60mm (un panel de vidro estándar ten dimensións de 80x80mm). O circuíto foi impreso nas páxinas da revista Antenna e transferido cun ferro Bosch coa configuración "Len" (potencia máxima) nunha placa de fibra de vidro de dobre cara de 1.5 mm, 35 µm (en ausencia doutra).
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

O gravado realizouse cunha solución de cloruro férrico, previamente preparada en proporcións de 1.5 culleres de té por 250 ml de auga morna. O proceso levou 15 minutos.
A perforación das vías intercapas e para fixar o soporte da batería realizouse cunha minibroca DREMEL 3000 montada nun soporte de perforación DREMEL 220. Perforáronse os orificios para as vías intercapas cunha broca de 0,4 mm, os orificios para o soporte da batería cunha broca de 1,1 mm. . O recorte ao longo dos bordos do taboleiro realizouse co mesmo minibroca cun accesorio DREMEL 540 (círculo de corte d=32.0 mm). A poda fíxose nun respirador.
O estañado do taboleiro gravado realizouse con aliaxe Rose nunha solución acuosa (1 cucharadita de ácido cítrico cristalizado por 300 ml de auga).

O proceso de soldadura levou aproximadamente unha hora, a maior parte do tempo pasou a soldar o fío (estañado, de 0.4 mm de diámetro) nos orificios das vías intermedias.

O taboleiro foi lavado con limpador de aerosol FLUX OFF.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

O deseño do corpo do dispositivo realizouse nun editor tridimensional de deseño asistido por ordenador. Dimensións da caixa 78,5 mm X 78,5 mm X 12 mm.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

O modelo completo da funda e a tapa do compartimento da batería gardouse en formato STL, entón foi necesario preparar estes modelos para imprimir nunha impresora SLA (engadindo soportes, orientación). Nesta fase, xurdiu un pequeno problema, xa que a área de impresión das impresoras SLA domésticas é pequena. O modelo da caixa do dispositivo na posición máis óptima en relación ao tempo de impresión non se axustaba ás dimensións da área de impresión. Ao colocar o modelo a 45 graos, tamén deu un resultado decepcionante; o peso do soporte era igual ao peso do modelo do corpo. Decidiuse imprimir o modelo verticalmente, facendo un soporte nunha das caras frontales, tendo acordado previamente o feito de posprocesar. A impresión do corpo levou 5 horas cunha configuración de capa de 50 micras. A continuación, o procesamento levouse a cabo con papel de lixa moi fino (non vou escribir o número porque non o sei :)). A tapa da batería tardou 40 minutos en imprimirse.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Os paneis de vidro de Aliexpress véndense cun marco de plástico xa pegado; non houbo problemas para quitar o marco. Quitei o panel de vidro despois de prequentalo cun secador de pelo normal.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

O difusor para a retroiluminación LED estaba feito de cinta de dobre cara con adhesivo acrílico 3M 9088-200. Para a iluminación fluorescente había varios materiais para escoller, cinta adhesiva chinesa e papel adhesivo cortado en cintas da empresa doméstica Luminofor. A elección foi feita a favor dun fabricante nacional; segundo os meus sentimentos, brillou máis e máis tempo. Enriba pegouse un cadrado de papel con pigmento fluorescente con cinta de dobre cara 3M 9088-200.

O vidro pegouse ao corpo do interruptor usando cinta de dobre cara con adhesivo acrílico 3M VHB 4910.
Interruptor táctil sen fíos con retroiluminación fluorescente adicional

A cuberta fixouse cun parafuso M 1,4 X 5 mm.

O custo do dispositivo foi de 890 rublos.

A continuación veu a parte do programa. Houbo algúns problemas. Resulta que os chips do sensor TTP223 funcionan moi ben cunha fonte de alimentación estabilizada de 3.3 V e non moi ben cando se alimentan directamente cunha batería ben descargada. Ao iniciar o dispositivo cunha fonte de alimentación ao redor de 2.5 v, ademais de despois dunha "retracción" adicional ao elaborar a presentación de Mysensors, o microcircuíto TTP223 (inmediatamente despois da calibración) provocou unha interrupción do MK xa que estaba cun gatillo activo.

Cambiouse o circuíto de fonte de alimentación do microcircuíto (xestión de enerxía TTP223 con gpio MK), proporcionouse terra adicional e substituíronse as resistencias con maior resistencia nas liñas de led rgb (que funcionan no outro lado da placa do sensor capacitivo). Tamén se engadiu ao software: activación de enerxía para o microcircuíto capacitivo despois de iniciar o marco Mysensors e elaborar a presentación. Duplicouse o atraso para a calibración automática do chip TTP223 cando se aplica a enerxía. Todos estes cambios eliminaron completamente este problema.

Antes de ver o código do programa, recoméndoche que te familiarices coa estrutura básica dos bosquexos en 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()
{

}

Código de proba do programa do interruptor táctil: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

O interruptor ten un botón táctil e un botón táctil na parte traseira do dispositivo. Este botón táctil utilizarase para os modos de servizo, o modo de vinculación ao aire e o restablecemento do dispositivo. O botón ten unha función anti-rebote de ferro. A liña do sensor capacitivo e a liña do botón táctil están conectadas a través de díodos Schottky e conectadas ao pin analóxico p0.05, e tamén desde o sensor capacitivo e o botón táctil hai liñas aos pines MK p0.25 e p0.27. .0.05 para ler estados despois de activar a interrupción no pin p0.05. No pin pXNUMX, actívase unha interrupción a través do comparador (NRF_LPCOMP) a través de EVENTS_UP. Recibín inspiración para resolver o problema aquí и aquí.

O interruptor engadiuse á rede Mysensors, xestionada polo controlador de casa intelixente Majordomo (sitio web do proxecto)

Código PHP para engadir un interruptor ao método 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');
} 
}

Mira o resultado no vídeo

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Máis tarde, realizouse unha opción cun conversor de refuerzo, pero isto non está relacionado co funcionamento do microcircuíto capacitivo TTP223; hai máis desexo dunha iluminación boa e uniforme ao premer as teclas durante toda a vida útil da batería.

VerInterruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Proxecto Github - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

falante ruso sitio comunitario Os meus sensores

Chat de Telegram Mysensors — solución rápida a problemas con Mysensors, consellos, trucos, instalación de placas, traballo con microcontroladores atmega 328, stm32, nRF5 no IDE de Arduino — @mysensors_rus

Algunhas fotosInterruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Interruptor táctil sen fíos con retroiluminación fluorescente adicional

Fonte: www.habr.com

Engadir un comentario