Habr پر "DIY or Do It Yourself" سیکشن کے تمام قارئین کو سلام! آج کا مضمون TTP223 چپ پر ٹچ سوئچ کے بارے میں ہوگا۔
پچھلے تمام منصوبوں کی طرح، یہ بھی ایک Arduino پروجیکٹ ہے، پروگرام Arduino IDE میں لکھا گیا ہے۔ ڈیوائس کے سافٹ ویئر کا نفاذ Mysensors پروٹوکول پر مبنی ہے۔
(ان کے لیے جو پڑھنا چاہتے ہیں-
ٹچ سوئچ بورڈ ڈیپ ٹریس پروگرام میں تیار کیا گیا تھا، جس میں لیزر آئرننگ ٹیکنالوجی (LUT) طریقہ استعمال کرتے ہوئے بعد میں ہونے والی تیاری کو مدنظر رکھا گیا تھا۔ بورڈ کو 60x60mm کے طول و عرض میں تیار کیا گیا تھا (ایک معیاری شیشے کے پینل کے طول و عرض 80x80mm ہوتے ہیں)۔ سرکٹ کو اینٹینا میگزین کے صفحات پر پرنٹ کیا گیا تھا اور "لین" سیٹنگ (زیادہ سے زیادہ پاور) کے ساتھ بوش آئرن کے ساتھ دو طرفہ فوائل فائبر گلاس بورڈ 1.5mm، 35µm (دوسرے کی غیر موجودگی میں) پر منتقل کیا گیا تھا۔
اینچنگ فیرک کلورائڈ کے محلول کے ساتھ کی گئی تھی، جو پہلے 1.5 چمچ فی 250 ملی لیٹر گرم پانی کے تناسب میں تیار کی گئی تھی۔ اس عمل میں 15 منٹ لگے۔
انٹرلیئر ویاس کے لیے سوراخ کرنے اور بیٹری ہولڈر کو باندھنے کے لیے DREMEL 3000 ڈرل اسٹینڈ پر نصب DREMEL 220 منی ڈرل کے ساتھ سوراخ کیے گئے تھے۔ انٹرلیئر ویاس کے لیے سوراخ 0,4mm ڈرل کے ساتھ کیے گئے تھے، بیٹری ہولڈر کے لیے سوراخ 1,1mm ڈرل کے ساتھ کیے گئے تھے۔ . بورڈ کی سرحدوں کے ساتھ تراشنا اسی منی ڈرل کے ساتھ DREMEL 540 اٹیچمنٹ (Cutting Circle 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 کے ساتھ ڈبل رخا ٹیپ سے بنا تھا۔ فلوروسینٹ لائٹنگ کے لیے منتخب کرنے کے لیے کئی مواد موجود تھے، چینی چپکنے والی ٹیپ اور چپکنے والے کاغذ کو گھریلو کمپنی Luminofor سے ٹیپ میں کاٹا گیا۔ انتخاب ایک گھریلو صنعت کار کے حق میں کیا گیا تھا؛ میرے جذبات کے مطابق، یہ روشن اور طویل چمکتا ہے. فلوروسینٹ پگمنٹ کے ساتھ کاغذ کا ایک مربع اوپر 3M 9088-200 ڈبل رخا ٹیپ سے چپکا ہوا تھا۔
شیشے کو 3M VHB 4910 ایکریلک چپکنے والی دو طرفہ ٹیپ کا استعمال کرتے ہوئے سوئچ باڈی پر چپکا دیا گیا تھا۔
کور کو ایک سکرو M 1,4 X 5 ملی میٹر کے ساتھ طے کیا گیا تھا۔
ڈیوائس کی قیمت 890 روبل تھی۔
اس کے بعد پروگرام کا حصہ آیا۔ کچھ مسائل تھے۔ یہ پتہ چلتا ہے کہ TTP223 سینسر چپس ایک مستحکم 3.3V پاور سپلائی کے ساتھ بہت اچھا کام کرتی ہیں اور اچھی طرح سے خارج ہونے والی بیٹری سے براہ راست چلنے پر بہت اچھی نہیں ہوتی۔ 2.5v کے ارد گرد پاور سپلائی کے ساتھ ڈیوائس کو شروع کرتے وقت، نیز ایک اضافی "ڈرا ڈاؤن" کے بعد جب Mysensors پریزنٹیشن پر کام کر رہے تھے، TTP223 مائیکرو سرکٹ (کیلیبریشن کے فوراً بعد) نے MK میں رکاوٹ پیدا کی کیونکہ یہ ایک فعال ٹرگر کے ساتھ تھا۔
مائیکرو سرکٹ کو پاور سپلائی سرکٹ تبدیل کر دیا گیا تھا (gpio MK کے ساتھ پاور مینجمنٹ TTP223)، اضافی گراؤنڈ فراہم کیا گیا تھا، اور rgb لیڈ لائنز (جو capacitive سینسر بورڈ کے دوسری طرف چلتے ہیں) پر زیادہ مزاحمت والے ریزسٹرس کو تبدیل کر دیا گیا تھا۔ اسے سافٹ ویئر میں بھی شامل کیا گیا تھا: مائیسینسر فریم ورک شروع کرنے اور پریزنٹیشن پر کام کرنے کے بعد کیپسیٹیو مائیکرو سرکٹ کے لیے پاور کو چالو کرنا۔ جب پاور لگائی جاتی ہے تو TTP223 چپ کے آٹو کیلیبریشن میں تاخیر کو دگنا کر دیا گیا ہے۔ ان تمام تبدیلیوں نے اس مسئلے کو مکمل طور پر ختم کردیا۔
پروگرام کوڈ دیکھنے سے پہلے، میں تجویز کرتا ہوں کہ آپ اپنے آپ کو 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()
{
}
ٹچ سوئچ پروگرام ٹیسٹ کوڈ: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
سوئچ میں ایک ٹچ بٹن اور ڈیوائس کے پچھلے حصے میں ایک ٹیکٹ بٹن ہے۔ یہ ٹیکٹ بٹن سروس موڈز، اوور دی ایئر بائنڈنگ موڈ، اور ڈیوائس ری سیٹ کے لیے استعمال کیا جائے گا۔ بٹن میں آئرن اینٹی باؤنس فیچر ہے۔ Capacitive sensor کی لائن اور tact بٹن کی لائن Schottky diodes کے ذریعے منسلک ہوتی ہے اور analog pin p0.05 سے منسلک ہوتی ہے، اور capacitive sensor اور tact بٹن سے MK پن p0.25 اور p0.27 پر بھی لائنیں ہوتی ہیں۔ پن p0.05 پر انٹرپٹ کو چالو کرنے کے بعد ریاستوں کو پڑھنے کے لیے .0.05۔ XNUMX۔ پن pXNUMX پر، EVENTS_UP کے ذریعے کمپیریٹر (NRF_LPCOMP) کے ذریعے ایک مداخلت چالو ہوتی ہے۔ مجھے مسئلہ حل کرنے کی ترغیب ملی
سوئچ کو Mysensors نیٹ ورک میں شامل کیا گیا تھا، جس کا انتظام سمارٹ ہوم کنٹرولر Majordomo (
اسٹیٹس اپ ڈیٹ کے طریقہ کار میں سوئچ شامل کرنے کے لیے پی ایچ پی کوڈ
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 capacitive microcircuit کے آپریشن سے نہیں ہے؛ بیٹری کی پوری زندگی کے دوران چابیاں دبانے پر اچھی اور یکساں روشنی کی زیادہ خواہش ہوتی ہے۔
Посмотреть
پروجیکٹ گیتھب -
روسی بولنے والا
کچھ تصویریں
ماخذ: www.habr.com