Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Üdvözlök minden olvasót a „Barkács vagy csináld magad” rovatban a Habron! A mai cikk a TTP223 chip érintőkapcsolójáról fog szólni | adatlap. A kapcsoló az nRF52832 mikrokontrolleren működik | adatlap, egy YJ-17103 modult használtak nyomtatott antennával és egy külső MHF4 antenna csatlakozóval. Az érintőkapcsoló CR2430 vagy CR2450 elemekkel működik. A fogyasztás átviteli módban nem több, mint 8 mA, alvó üzemmódban legfeljebb 6 µA.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Mint minden korábbi projekt, ez is egy Arduino projekt, a program Arduino IDE-ben íródott. Az eszköz szoftveres megvalósítása a Mysensors protokollon alapul | GitHub könyvtárak, nRF5 kártya támogatása GitHub a Mysensorsban. angol nyelvű közösségi fórum - http://forum.mysensors.org, orosz nyelvű közösségi fórum - http://mysensors.ru/forum/
(Tanulni vágyóknak - dokumentáció, Soros protokoll, API, Jegyzőkönyv, elemző | azoknak, akik segíteni szeretnének (hozzájárulások) a projekt fejlesztésében - dokumentáció)

Az érintéses kapcsolótáblát a Deeptrace programban fejlesztették ki, figyelembe véve a későbbi gyártást a lézervasalás technológia (LUT) módszerével. A táblát 60x60mm-es méretben fejlesztették ki (a szabványos üveglap méretei 80x80mm). Az áramkört az Antenna magazin oldalaira nyomtatták, és egy Bosch vasalóval „Len” beállítással (maximális teljesítmény) vitték át egy 1.5 mm-es, 35 µm-es (más hiányában) kétoldalas fóliás üvegszálas táblára.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

A maratást vas(III)-klorid-oldattal végeztük, amelyet előzőleg 1.5 teáskanál/250 ml meleg víz arányban készítettek el. A folyamat 15 percig tartott.
A lyukak fúrása a rétegközi átmenetekhez és az akkumulátortartó rögzítéséhez DREMEL 3000 minifúróval, DREMEL 220-as fúróállványra szerelve, a rétegközi átmenetekhez 0,4 mm-es fúróval, az akkumulátortartó lyukak 1,1 mm-es fúróval történt. . A deszka szélei mentén a vágást ugyanazzal a minifúróval végeztük, DREMEL 540-es tartozékkal (Vágókör d=32.0mm). A metszés légzőkészülékben történt.
A maratott tábla ónozását Rose ötvözet felhasználásával végeztük vizes oldatban (1 teáskanál kristályos citromsav 300 ml vízben).

A forrasztási folyamat körülbelül egy órát vett igénybe, az idő nagy részét a rétegközi átmenetek furataiban lévő (ónozott, 0.4 mm átmérőjű) huzal forrasztásával töltötték.

A deszkát FLUX OFF aeroszolos tisztítószerrel mostuk.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

A készüléktest tervezése egy háromdimenziós számítógéppel segített tervezőszerkesztőben történt. A ház méretei: 78,5 mm X 78,5 mm x 12 mm.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

A tok és elemtartó fedelének elkészült modellje STL formátumban elmentésre került, majd ezeket a modelleket SLA nyomtatón történő nyomtatásra kellett előkészíteni (támaszok hozzáadása, tájolás). Ebben a szakaszban egy kis probléma merült fel, mivel a háztartási SLA nyomtatók nyomtatási területe kicsi. A nyomtatási időhöz képest legoptimálisabb helyzetben lévő készülékház modellje nem illett bele a nyomtatási terület méreteibe. A modell 45 fokos elhelyezése is kiábrándító eredményt hozott, a támasz súlya megegyezett a karosszéria-modell súlyával. Úgy döntöttek, hogy a modellt függőlegesen nyomtatják, az egyik elülső oldalára támasztva, előzetesen egyeztetve az utófeldolgozás tényével. A test nyomtatása 5 órát vett igénybe 50 mikronos rétegbeállítás mellett. Ezután a feldolgozást nagyon finom szemcsés csiszolópapírral végezték (nem írom le a számot, mert nem tudom :)). Az elemtartó fedelének nyomtatása 40 percig tartott.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Az Aliexpress üvegtábláit már ragasztott műanyag kerettel árusítják, a keret eltávolításával nem volt probléma. Az üveglapot normál hajszárítóval való előmelegítés után távolítottam el.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

A LED-es háttérvilágítás diffúzorja kétoldalas szalagból készült 3M 9088-200 akril ragasztóval. A fénycsöves világításhoz többféle anyag közül lehetett választani, kínai ragasztószalag és szalagra vágott ragasztópapír a hazai Luminofor cégtől. A hazai gyártó javára esett a választás, érzéseim szerint jobban és tovább ragyogott. A tetejére 3M 9088-200 kétoldalas szalaggal egy négyzet alakú papírt ragasztottak fel fluoreszcens pigmenttel.

Az üveget kétoldalas ragasztószalaggal, 3M VHB 4910 akril ragasztóval ragasztottuk a kapcsoló testére.
Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

A fedelet M 1,4 X 5 mm-es csavarral rögzítettük.

A készülék ára 890 rubel volt.

Következett a program rész. Volt néhány probléma. Kiderült, hogy a TTP223 szenzorchipek kiválóan működnek stabilizált 3.3 V-os tápegységgel, és nem túl jól, ha közvetlenül egy jól lemerült akkumulátorról táplálják. A készülék 2.5 V körüli tápellátással történő indításakor, plusz a Mysensors prezentáció kidolgozásakor egy további „lehúzás” után a TTP223 mikroáramkör (közvetlenül a kalibrálás után) az MK megszakítását okozta, mivel aktív triggerrel volt.

Megváltoztatták a mikroáramkör tápáramkörét (energiagazdálkodás TTP223 gpio MK-val), további földelést kapott, az rgb led vonalakon (amelyek a kapacitív szenzorkártya másik oldalán futnak) nagyobb ellenállású ellenállásokat cseréltek. Ez is hozzáadásra került a szoftverhez: a kapacitív mikroáramkör tápellátásának aktiválása a Mysensors keretrendszer elindítása és a bemutató kidolgozása után. A TTP223 chip automatikus kalibrálásának késleltetése tápellátás esetén megduplázódott. Mindezek a változtatások teljesen kiküszöbölték ezt a problémát.

A programkód megtekintése előtt azt javaslom, hogy ismerkedjen meg a Mysensors vázlatainak alapvető szerkezetével.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()
{

}

Érintőkapcsoló program tesztkód: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

A kapcsolón egy érintőgomb és egy tapintható gomb található a készülék hátulján. Ezt a tapintatos gombot a szolgáltatási módokhoz, a vezeték nélküli kötési módhoz és az eszköz visszaállításához használjuk. A gomb vaspattanásgátló funkcióval rendelkezik. A kapacitív érzékelő vonala és a tapintógomb vonala Schottky-diódákon keresztül csatlakozik a p0.05 analóg érintkezőhöz, valamint a kapacitív érzékelőtől és a tapintógomb vonalától a p0.25 és p0.27 MK tűkhöz vezet .0.05 az állapotok kiolvasásához a p0.05 érintkezőn lévő megszakítás aktiválása után. A pXNUMX érintkezőn egy megszakítás aktiválódik a komparátoron (NRF_LPCOMP) keresztül az EVENTS_UP-on keresztül. Ihletet kapott a probléma megoldásához itt и itt.

A kapcsolót hozzáadták a Mysensors hálózathoz, amelyet a Majordomo intelligens otthonvezérlő (projekt honlapja)

PHP-kód kapcsoló hozzáadásához a statusUpdate metódushoz

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

Az eredményt lásd a videóban

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Később készült egy boost konverter is, de ez nem kapcsolódik a TTP223 kapacitív mikroáramkör működéséhez, inkább a jó és egyenletes megvilágításra van vágy a billentyűk lenyomásakor az akkumulátor teljes élettartama alatt.

nézVezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Projekt Github - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

oroszul beszélő közösségi oldal Érzékelők

Telegram chat Mysensors - gyors megoldás a Mysensorokkal kapcsolatos problémákra, tippek, trükkök, táblák telepítése, atmega 328, stm32, nRF5 mikrokontrollerekkel való munka az Arduino IDE-ben - @mysensors_rus

Néhány képVezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Vezeték nélküli érintőkapcsoló további fluoreszkáló háttérvilágítással

Forrás: will.com

Hozzászólás