Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Tervitused kõigile Habri rubriigi "DIY või tee ise" lugejatele! Tänane artikkel räägib TTP223 kiibi puutelülitist | andmeleht. Lüliti töötab mikrokontrolleril nRF52832 | andmeleht, kasutati YJ-17103 moodulit trükitud antenni ja välise MHF4 antenni pistikuga. Puutelüliti töötab CR2430 või CR2450 patareidega. Tarbimine edastusrežiimis ei ületa 8 mA, puhkerežiimis mitte rohkem kui 6 µA.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Nagu kõik varasemad projektid, on ka see Arduino projekt, programm on kirjutatud Arduino IDE-s. Seadme tarkvaraline teostus põhineb Mysensors protokollil | GitHubi teegid, nRF5 plaadi tugi GitHub rakenduses Mysensors. Ingliskeelne kogukonna foorum - http://forum.mysensors.org, venekeelne kogukonnafoorum - http://mysensors.ru/forum/
(Neile, kes soovivad õppida - Документация, Sarjaprotokoll, API, Protokoll, parser | neile, kes soovivad aidata (sissemaksed) projekti väljatöötamisel - Документация)

Puutetundlik lülitusplaat töötati välja programmis Deeptrace, võttes arvesse hilisemat tootmist lasertriikimistehnoloogia (LUT) meetodil. Tahvel töötati välja mõõtmetega 60x60mm (tavalise klaaspaneeli mõõtmed on 80x80mm). Ahel trükiti ajakirja Antenna lehtedele ja kanti Boschi triikrauaga, mille seadistus oli "Len" (maksimaalne võimsus) kahepoolsele fooliumklaaskiudplaadile 1.5 mm, 35 µm (teise puudumisel).
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Söövitamine viidi läbi raudkloriidi lahusega, mis oli eelnevalt valmistatud vahekorras 1.5 teelusikatäit 250 ml sooja vee kohta. Protsess kestis 15 minutit.
Avad puuriti kihtidevaheliste läbiviikude jaoks ja akuhoidiku kinnitamiseks minitrelliga DREMEL 3000, mis oli paigaldatud puurialusele DREMEL 220. Kihtide vaheavade jaoks puuriti augud 0,4 mm puuriga, akuhoidiku jaoks 1,1 mm puuriga. . Kärpimine piki plaadi piire tehti sama minitrelliga, millel oli DREMEL 540 kinnitus (lõikering d=32.0mm). Lõikamine toimus respiraatoris.
Söövitatud plaadi tinatamiseks kasutati Rose sulamit vesilahuses (1 tl kristalliseerunud sidrunhapet 300 ml vee kohta).

Jootmisprotsess kestis umbes tund aega, suurem osa ajast kulus traadi (tinatatud, läbimõõduga 0.4 mm) jootmisele kihtide vaheavade avadesse.

Plaati pesti aerosoolpuhastusvahendiga FLUX OFF.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Seadme korpuse projekteerimine viidi läbi kolmemõõtmelises arvutipõhises disainiredaktoris. Korpuse mõõtmed 78,5 mm X 78,5 mm X 12 mm.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Valminud korpuse ja akupesa kaane mudel salvestati STL formaadis, seejärel oli vaja need mudelid SLA printeril printimiseks ette valmistada (tugede lisamine, orientatsioon). Selles etapis tekkis väike probleem, kuna kodumajapidamises kasutatavate SLA-printerite prindipind on väike. Printimisaja suhtes kõige optimaalsemas asendis seadme korpuse mudel ei mahtunud trükiala mõõtmetesse. Mudelit 45 kraadise nurga alla asetades andis see samuti pettumust valmistava tulemuse, toe kaal oli võrdne keremudeli kaaluga. Mudel otsustati trükkida vertikaalselt, tehes ühele esiküljele toe, olles eelnevalt kokku leppinud järeltöötluse faktiga. Korpuse printimiseks kulus 5 tundi kihi seadistusega 50 mikronit. Järgmisena viidi töötlemine läbi väga peeneteralise liivapaberiga (ma ei kirjuta numbrit, sest ma ei tea :)). Akukaane printimine võttis aega 40 minutit.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Aliexpressi klaaspaneele müüakse juba liimitud plastraamiga, raami eemaldamisega probleeme polnud. Klaaspaneeli eemaldasin pärast eelkuumutamist tavalise fööniga.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

LED-taustvalgustuse hajuti valmistati kahepoolsest teibist akrüülliimiga 3M 9088-200. Luminofoorvalgustite jaoks oli valida mitme materjali vahel, Hiina kleeplint ja lintideks lõigatud kleeppaber kodumaiselt ettevõttelt Luminofor. Valik sai tehtud kodumaise tootja kasuks, enesetunde järgi säras eredamalt ja kauem. Fluorestseeruva pigmendiga paberiruut liimiti peale 3M 9088-200 kahepoolse teibiga.

Klaas liimiti lüliti korpuse külge kahepoolse teibiga 3M VHB 4910 akrüülliimiga.
Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Kate kinnitati kruviga M 1,4 X 5 mm.

Seadme maksumus oli 890 rubla.

Edasi tuli programmi osa. Tekkisid mõned probleemid. Selgub, et TTP223 andurikiibid töötavad suurepäraselt stabiliseeritud 3.3 V toiteallikaga ja mitte eriti hästi, kui toidetakse otse hästi tühjenenud akust. Seadme käivitamisel umbes 2.5 V toiteallikaga, pluss pärast täiendavat "tõmmet" Mysensorsi esitluse väljatöötamisel, põhjustas TTP223 kiip (kohe pärast kalibreerimist) MK katkestuse, kuna see oli aktiivse päästikuga.

Vahetati mikroskeemi toiteahelat (toitehaldus TTP223 koos gpio MK-ga), lisati maandus ning rgb led liinidel (mis jooksevad teisel pool mahtuvusliku anduri plaati) vahetati välja suurema takistusega takistid. See lisati ka tarkvarasse: mahtuvusliku mikroskeemi võimsuse aktiveerimine pärast Mysensorsi raamistiku käivitamist ja esitluse väljatöötamist. TTP223 kiibi automaatse kalibreerimise viivitus toite sisselülitamisel on kahekordistunud. Kõik need muudatused kõrvaldasid selle probleemi täielikult.

Enne programmikoodi vaatamist soovitan tutvuda Mysensorsi visandite põhistruktuuriga.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()
{

}

Puutelüliti programmi testikood: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ülitil on puutetundlik nupp ja puutetundlik nupp seadme tagaküljel. Seda taktinuppu kasutatakse teenindusrežiimide, õhu kaudu sidumisrežiimi ja seadme lähtestamise jaoks. Nupul on rauast põrkevastane funktsioon. Mahtuvusanduri liin ja kellanupu liin on ühendatud läbi Schottky dioodide ja ühendatud analoogviiguga p0.05 ning ka mahtuvusandurilt ja kellanupult on liinid MK tihvtidele p0.25 ja p0.27 .0.05 olekute lugemiseks pärast kontakti p0.05 katkestuse aktiveerimist. XNUMX. Pin pXNUMX korral aktiveeritakse katkestus komparaatori (NRF_LPCOMP) kaudu EVENTS_UP kaudu. Sain inspiratsiooni probleemi lahendamiseks siin и siin.

Lüliti lisati Mysensorsi võrku, mida haldab targa kodu kontroller Majordomo (projekti veebisait)

PHP-kood olekuvärskendusmeetodile lüliti lisamiseks

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

Vaata tulemust videost

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Hiljem tehti võimalus ka võimendusmuunduriga, kuid see ei ole seotud TTP223 mahtuvusliku mikroskeemi tööga, rohkem on soovi hea ja ühtlase valgustuse järele, kui klahve vajutada kogu aku eluea jooksul.

VaadeTraadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Projekt Github - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

venekeelne kogukonna sait Müsensorid

Telegrami vestlus Mysensors — kiire lahendus Mysensorite probleemidele, näpunäited, nipid, plaatide paigaldamine, töö Atmega 328, stm32, nRF5 mikrokontrolleritega Arduino IDE-s — @mysensors_rus

Mõned fotodTraadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Traadita puutelüliti täiendava fluorestsents-taustvalgustusega

Allikas: www.habr.com

Lisa kommentaar