अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

Habr वरील “DIY or Do It Yourself” विभागातील सर्व वाचकांना शुभेच्छा! आजचा लेख TTP223 चिपवर टच स्विचबद्दल असेल | माहिती पत्रक. स्विच nRF52832 मायक्रोकंट्रोलरवर चालतो | माहिती पत्रक, प्रिंटेड अँटेना असलेले YJ-17103 मॉड्यूल आणि बाह्य MHF4 अँटेनासाठी कनेक्टर वापरला गेला. टच स्विच CR2430 किंवा CR2450 बॅटरीवर चालतो. ट्रान्समिट मोडमध्ये वापर 8 mA पेक्षा जास्त नाही, स्लीप मोडमध्ये 6 µA पेक्षा जास्त नाही.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

मागील सर्व प्रकल्पांप्रमाणे, हा देखील एक Arduino प्रकल्प आहे, प्रोग्राम Arduino IDE मध्ये लिहिलेला आहे. डिव्हाइसची सॉफ्टवेअर अंमलबजावणी Mysensors प्रोटोकॉलवर आधारित आहे GitHub लायब्ररी, nRF5 बोर्ड गिटहबला सपोर्ट करतो Mysensors मध्ये. इंग्रजी-भाषा समुदाय मंच - http://forum.mysensors.org, रशियन-भाषा समुदाय मंच - http://mysensors.ru/forum/
(ज्यांना अभ्यास करायचा आहे त्यांच्यासाठी - दस्तऐवजीकरण, सिरियल प्रोटोकॉल, API, प्रोटोकॉल, पार्सर | मदत करू इच्छिणाऱ्यांसाठी (योगदान) प्रकल्पाच्या विकासामध्ये - दस्तऐवजीकरण)

टच स्विच बोर्ड डीपट्रेस प्रोग्राममध्ये विकसित करण्यात आला, लेझर इस्त्री तंत्रज्ञान (LUT) पद्धतीचा वापर करून त्यानंतरच्या उत्पादनाचा विचार करून. बोर्ड 60x60 मिमी (मानक काचेच्या पॅनेलची परिमाणे 80x80 मिमी आहे) च्या परिमाणांमध्ये विकसित केले गेले. सर्किट अँटेना मासिकाच्या पृष्ठांवर मुद्रित केले गेले आणि बॉश लोहासह “लेन” सेटिंग (जास्तीत जास्त पॉवर) सह दुहेरी बाजू असलेल्या फॉइल फायबरग्लास बोर्ड 1.5 मिमी, 35µm (दुसऱ्याच्या अनुपस्थितीत) वर हस्तांतरित केले गेले.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

खोदकाम फेरिक क्लोराईडच्या द्रावणाने केले जाते, पूर्वी 1.5 चमचे प्रति 250 मिली कोमट पाण्यात तयार केले होते. प्रक्रियेस 15 मिनिटे लागली.
इंटरलेअर व्हियास आणि बॅटरी होल्डरला फास्टनिंगसाठी ड्रिलिंग होल DREMEL 3000 ड्रिल स्टँडवर बसवलेल्या DREMEL 220 मिनी-ड्रिलसह केले गेले. इंटरलेअर व्हियाससाठी छिद्र 0,4 मिमी ड्रिलने ड्रिल केले गेले, बॅटरी धारकासाठी 1,1 मिमी ड्रिलसह छिद्रे . DREMEL 540 संलग्नक (कटिंग सर्कल d=32.0mm) सह त्याच मिनी-ड्रिलसह बोर्डच्या किनारी ट्रिमिंग केले गेले. छाटणी श्वसन यंत्रात केली गेली.
कोरलेल्या बोर्डचे टिनिंग गुलाब मिश्र धातु वापरून जलीय द्रावणात (प्रति 1 मिली पाण्यात 300 चमचे क्रिस्टलाइज्ड सायट्रिक ऍसिड) केले जाते.

सोल्डरिंग प्रक्रियेस सुमारे एक तास लागला, बहुतेक वेळ इंटरलेअर व्हियाससाठी छिद्रांमध्ये सोल्डरिंग वायर (टिन केलेला, 0.4 मिमी व्यासाचा) घालवला गेला.

बोर्ड फ्लक्स ऑफ एरोसोल क्लिनरने धुतला होता.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

डिव्हाइस बॉडीची रचना त्रि-आयामी संगणक-सहाय्यित डिझाइन एडिटरमध्ये केली गेली. केस परिमाणे 78,5mm X 78,5mm X 12mm.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

केस आणि बॅटरी कंपार्टमेंट कव्हरचे पूर्ण झालेले मॉडेल STL फॉरमॅटमध्ये सेव्ह केले गेले होते, त्यानंतर SLA प्रिंटरवर (सपोर्ट्स, ओरिएंटेशन जोडणे) प्रिंट करण्यासाठी हे मॉडेल तयार करणे आवश्यक होते. या टप्प्यावर, एक लहान समस्या उद्भवली, कारण घरगुती SLA प्रिंटरचे मुद्रण क्षेत्र लहान आहे. प्रिंटिंग वेळेच्या तुलनेत सर्वात इष्टतम स्थितीतील डिव्हाइस केसचे मॉडेल मुद्रण क्षेत्राच्या परिमाणांमध्ये बसत नाही. मॉडेलला 45 अंशांवर ठेवताना, त्याने एक निराशाजनक परिणाम देखील दिला; समर्थनाचे वजन शरीराच्या मॉडेलच्या वजनाइतके होते. पोस्ट-प्रोसेसिंगच्या वस्तुस्थितीसह आगाऊ सहमती देऊन, समोरच्या एका बाजूस आधार बनवून, मॉडेल अनुलंब मुद्रित करण्याचा निर्णय घेण्यात आला. 5 मायक्रॉनच्या लेयर सेटिंगसह बॉडी प्रिंट करण्यासाठी 50 तास लागले. पुढे, अतिशय बारीक सँडपेपर वापरून प्रक्रिया केली गेली (मी नंबर लिहिणार नाही कारण मला माहित नाही :)). बॅटरी कव्हर प्रिंट करण्यासाठी 40 मिनिटे लागली.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

Aliexpress मधील काचेचे पॅनेल आधीपासूनच चिकटलेल्या प्लास्टिकच्या फ्रेमसह विकले जातात; फ्रेम काढण्यात कोणतीही समस्या नव्हती. मी काचेचे पॅनेल नेहमीच्या हेअर ड्रायरने प्रीहीट केल्यानंतर काढून टाकले.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

एलईडी बॅकलाइटसाठी डिफ्यूझर अॅक्रेलिक अॅडेसिव्ह 3M 9088-200 सह दुहेरी बाजू असलेला टेपचा बनलेला होता. फ्लोरोसेंट लाइटिंगसाठी निवडण्यासाठी अनेक साहित्य होते, चायनीज अॅडहेसिव्ह टेप आणि अॅडहेसिव्ह पेपर हे घरगुती कंपनी ल्युमिनोफोरच्या टेपमध्ये कापले गेले. निवड घरगुती निर्मात्याच्या बाजूने केली गेली होती; माझ्या भावनांनुसार, ती अधिक उजळ आणि लांब झाली. 3M 9088-200 डबल-साइड टेपसह फ्लोरोसेंट रंगद्रव्यासह कागदाचा चौरस वर चिकटलेला होता.

3M VHB 4910 अॅक्रेलिक अॅडेसिव्हसह दुहेरी बाजू असलेला टेप वापरून काचेला स्वीच बॉडीला चिकटवले होते.
अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

कव्हर M 1,4 X 5 मिमी स्क्रूने निश्चित केले होते.

डिव्हाइसची किंमत 890 रूबल होती.

पुढे कार्यक्रमाचा भाग आला. काही समस्या होत्या. असे दिसून आले की TTP223 सेन्सर चिप्स स्थिर 3.3V पॉवर सप्लायसह उत्तम काम करतात आणि चांगल्या प्रकारे डिस्चार्ज केलेल्या बॅटरीमधून थेट पॉवर केले जातात तेव्हा ते फार चांगले नसते. 2.5v च्या आसपास वीज पुरवठ्यासह डिव्हाइस सुरू करताना, तसेच अतिरिक्त "ड्रॉडाउन" नंतर मायसेन्सर्स सादरीकरणावर काम करताना, TTP223 मायक्रोक्रिकिट (कॅलिब्रेशननंतर लगेच) सक्रिय ट्रिगरसह असल्याने MK मध्ये व्यत्यय आला.

मायक्रोसर्किटला पॉवर सप्लाय सर्किट बदलण्यात आले (जीपीओ एमके सह पॉवर मॅनेजमेंट TTP223), अतिरिक्त ग्राउंड पुरवले गेले आणि आरजीबी एलईडी लाईन्सवर (जे कॅपेसिटिव्ह सेन्सर बोर्डच्या दुसऱ्या बाजूला चालतात) वर जास्त रेझिस्टन्स असलेले रेझिस्टर बदलले गेले. हे सॉफ्टवेअरमध्ये देखील जोडले गेले: मायसेन्सर्स फ्रेमवर्क सुरू केल्यानंतर आणि सादरीकरण कार्यान्वित केल्यानंतर कॅपेसिटिव्ह मायक्रोसर्कीटसाठी पॉवर सक्रिय करणे. पॉवर लागू केल्यावर TTP223 चिपच्या स्वयं-कॅलिब्रेशनसाठी होणारा विलंब दुप्पट झाला आहे. या सर्व बदलांनी ही समस्या पूर्णपणे काढून टाकली.

प्रोग्राम कोड पाहण्यापूर्वी, मी शिफारस करतो की आपण मायसेन्सर्समधील स्केचच्या मूलभूत संरचनेसह स्वतःला परिचित करा.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()
{

}

टच स्विच प्रोग्राम चाचणी कोड: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

स्विचमध्ये टच बटण आणि डिव्हाइसच्या मागील बाजूस एक टॅक्ट बटण आहे. हे टॅक्ट बटण सेवा मोड, ओव्हर-द-एअर बाइंडिंग मोड आणि डिव्हाइस रीसेटसाठी वापरले जाईल. बटणामध्ये लोह विरोधी बाउंस वैशिष्ट्य आहे. कॅपेसिटिव्ह सेन्सरची ओळ आणि टॅक्ट बटणाची रेषा Schottky diodes द्वारे जोडलेली असते आणि analog pin p0.05 शी जोडलेली असते, तसेच capacitive sensor आणि tact बटन वरून MK पिन p0.25 आणि p0.27 ला जोडलेले असतात. .0.05 पिन p0.05 वर व्यत्यय सक्रिय केल्यानंतर स्थिती वाचण्यासाठी. XNUMX. पिन pXNUMX वर, EVENTS_UP मार्गे तुलनाकर्ता (NRF_LPCOMP) द्वारे एक व्यत्यय सक्रिय केला जातो. समस्या सोडवण्याची प्रेरणा मला मिळाली येथे и येथे.

मायसेन्सर्स नेटवर्कमध्ये स्विच जोडला गेला, जो स्मार्ट होम कंट्रोलर मेजोर्डोमो (प्रकल्प)

स्टेटसअपडेट पद्धतीमध्ये स्विच जोडण्यासाठी PHP कोड

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

व्हिडिओमध्ये निकाल पहा

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

नंतर, बूस्ट कन्व्हर्टरसह एक पर्याय तयार केला गेला, परंतु हे TTP223 कॅपेसिटिव्ह मायक्रोसर्कीटच्या ऑपरेशनशी संबंधित नाही; संपूर्ण बॅटरी आयुष्यभर की दाबताना चांगल्या आणि एकसमान प्रकाशाची अधिक इच्छा असते.

पहाअतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

प्रोजेक्ट गिथब - github.com/smartboxchannel/EFEKTA_WIRELESS_TOUCH_SWITCH

रशियन भाषिक समुदाय साइट मायसेन्सर्स

टेलीग्राम गप्पा मायसेन्सर्स — Arduino IDE मधील मायसेन्सर, टिप्स, युक्त्या, बोर्ड स्थापित करणे, atmega 328, stm32, nRF5 मायक्रोकंट्रोलर्ससह कार्य करणे या समस्यांचे द्रुत निराकरण — @mysensors_rus

काही फोटोअतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

अतिरिक्त फ्लोरोसेंट बॅकलाइटसह वायरलेस टच स्विच

स्त्रोत: www.habr.com

एक टिप्पणी जोडा