Оглавление:
2025 Автор: John Day | [email protected]. Последнее изменение: 2025-01-13 06:58
Я использовал инфракрасный датчик, чтобы определять движения глаз и управлять светодиодом.
Я сделал завязку на LED Tape NeoPixel.
Шаг 1: Конституция
Я использовал два датчика QTR - 1A для отслеживания взгляда. Обнаружение с помощью Arduino и управление светодиодом.
компоненты
- SparkFun Arduino Pro Mini 328 - 5 В / 16 МГц
- Надстройка Adafruit LiIon / LiPoly Backpack для Pro Trinket / ItsyBitsy
- LiPo аккумулятор
- Полоса NeoPixel
- Датчик отражения QTR-1A
Шаг 2: шар для глаз со светодиодной подсветкой NeoPixel
Используется светодиодная лента NeoPixel. Светодиод 68 шт.
Светодиод крепится к чаше с помощью двустороннего скотча и зашивается проводом.
Шаг 3: сенсорный блок
Я использовал два датчика QTR - 1A для отслеживания взгляда. QTR-1A размещаются на пластиковом листе на расстоянии примерно ширины глаза.
Сенсорная часть и микроконтроллерная часть крепились к очкам с помощью зажима соответственно.
Шаг 4: Код Arduino
Когда диафрагма приближается к одному датчику, отраженный свет уменьшается, а значение датчика увеличивается. И наоборот, когда диафрагма удаляется, отраженный свет увеличивается, а значение датчика фотоотражателя уменьшается.
Движение зрачка светодиодного глазного яблока вправо и влево определяет увеличение и уменьшение одного значения датчика и контролирует его. При мигании значения обоих датчиков уменьшаются, поэтому, если значения двух датчиков уменьшаются одновременно, веки светодиодного глазного яблока опускаются.
Я использовал следующую библиотеку.
- QTRsensors:
- Adafruit_NeoPixel:
#include #include
#define NUM_SENSORS 2 // количество используемых датчиков # define NUM_SAMPLES_PER_SENSOR 10 // усреднение #define EMITTER_PIN QTR_NO_EMITTER_PIN
int iniSensorValL, sensorValL; int iniSensorValR, sensorValR; #define PIN A3 Adafruit_NeoPixel led = Adafruit_NeoPixel (68, PIN, NEO_GRB + NEO_KHZ800); int blackNum = 24; int pupilNum = 12; uint32_t color; int яркость = 40; byte eyeColor; int LR = 7; логическая крышка = ложь; int cnt = 0;
// Анимация черного глаза слева и справаint blackLED [15] [24] = {{12, 32, 35, 55, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {12, 13, 31, 36, 54, 55, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {11, 13, 14, 30, 37, 53, 54, 56, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {10, 11, 14, 15, 29, 38, 52, 53, 56, 57, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {9, 10, 11, 12, 15, 16, 28, 33, 34, 39, 51, 52, 55, 56, 57, 58, 68, 68, 68, 68, 68, 68, 68, 68}, {0, 8, 9, 10, 11, 12, 13, 16, 17, 27, 32, 35, 40, 50, 51, 54, 55, 56, 57, 58, 59, 67, 68, 68}, {0, 1, 7, 8, 9, 10, 13, 14, 17, 18, 26, 31, 36, 41, 49, 50, 53, 54, 57, 58, 59, 60, 66, 67}, {1, 2, 6, 7, 8, 9, 14, 15, 18, 19, 25, 30, 37, 42, 48, 49, 52, 53, 58, 59, 60, 61, 65, 66}, {2, 3, 5, 6, 7, 8, 15, 16, 19, 20, 24, 29, 38, 43, 47, 48, 51, 52, 59, 60, 61, 62, 64, 65}, {3, 4, 5, 6, 7, 16, 17, 20, 21, 23, 28, 39, 44, 46, 47, 50, 51, 60, 61, 62, 63, 64, 68, 68}, {4, 5, 6, 17, 18, 21, 22, 27, 40, 45, 46, 49, 50, 61, 62, 63, 68, 68, 68, 68, 68, 68, 68, 68}, {4, 5, 18, 19, 26, 41, 48, 49, 62, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {4, 19, 20, 25, 42, 47, 48, 63, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {20, 21, 24, 43, 46, 47, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {21, 23, 44, 46, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}};
// анимация ученика L&Rint pupilLED [15] [12] = {{33, 34, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}, {32, 33, 34, 35, 68, 68, 68, 68, 68, 68, 68, 68}, {12, 31, 32, 33, 34, 35, 36, 55, 68, 68, 68, 68}, {12, 13, 30, 31, 32, 33, 34, 35, 36, 37, 54, 55}, {13, 14, 29, 30, 31, 32, 35, 36, 37, 38, 53, 54}, {14, 15, 28, 29, 30, 31, 36, 37, 38, 39, 52, 53}, {15, 16, 27, 28, 29, 30, 37, 38, 39, 40, 51, 52}, {16, 17, 26, 27, 28, 29, 38, 39, 40, 41, 50, 51}, {17, 18, 25, 26, 27, 28, 39, 40, 41, 42, 49, 50}, {18, 19, 24, 25, 26, 27, 40, 41, 42, 43, 48, 49}, {19, 20, 23, 24, 25, 26, 41, 42, 43, 44, 47, 48}, {20, 21, 22, 23, 24, 25, 42, 43, 44, 45, 46, 47}, {21, 22, 23, 24, 43, 44, 45, 46, 68, 68, 68, 68 }, {22, 23, 44, 45, 68, 68, 68, 68, 68, 68, 68, 68}, {22, 45, 68, 68, 68, 68, 68, 68, 68, 68, 68, 68}};
// Анимация морганияint eyelid = 0; int eyelidNum [8] = {0, 4, 8, 16, 24, 34, 44, 56}; int eyelidLED [56] = {64, 65, 66, 67, 58, 59, 60, 61, 56, 57, 62, 63, 49, 50, 51, 52, 47, 48, 53, 54, 38, 39, 40, 41, 46, 55, 36, 37, 42, 43, 26, 27, 28, 29, 35, 44, 24, 25, 30, 31, 15, 16, 17, 18, 34, 45, 23, 32, 13, 14, 19, 20, 6, 7, 8, 9}; QTRSensorsAnalog qtra ((символ без знака ) {0, 1}, NUM_SENSORS, NUM_SAMPLES_PER_SENSOR, EMITTER_PIN); unsigned int sensorValues [NUM_SENSORS];
void blink (int eyelid, int LR) {if (eyelid! = 8) {// Pewter for (uint16_t i = 0; i <led.numPixels (); i ++) {led.setPixelColor (i, led. Color (66, 66, 66)); }
// Черный глаз для (uint16_t i = 0; i led.setPixelColor (blackLED [LR] , color);}
// ученик для (uint16_t i = 0; i
led.setPixelColor (ученикLED [LR] , led. Color (0, 0, 66)); }
// веко для (int i = 0; i <eyelidNum [eyelid]; i ++) {led.setPixelColor (eyelidLED , 0); }} иначе, если (веко == 8) {led.clear (); } led.show ();}
void setup () {
Serial.begin (115200); led.begin (); led.setBrightness (яркость); // Начальная яркость 40 led.show (); // Инициализируем все пиксели на «выключено» color = led. Color (0, 177, 55); // задержка цвета зрачка (100); qtra.read (sensorValues); iniSensorValL = sensorValues [0]; iniSensorValR = sensorValues [1]; мигание (веко, ЛП); }
void loop () {// QTR - значение датчика 1A qtra.read (sensorValues); sensorValL = sensorValues [0]; sensorValR = sensorValues [1];
double rasioL = (двойной) sensorValL / iniSensorValL;
double rasioR = (двойной) sensorValR / iniSensorValR;
Serial.print (rasioL);
Serial.print (""); Serial.println (rasioR);
if (rasioL> 0.985 && rasioR <0.985) {// правильно для (int i = LR; i <12; i ++) {blink (0, i); задержка (40); LR = i; }} else if (rasioL 0.985) {// осталось для (int i = LR; i> 2; i -) {blink (0, i); задержка (40); LR = i; }} else if (lid == false && rasioL <0.96 && rasioR <0.96) {// Мигает закрытие для (int i = 1; i 0.96 && rasioR> 0.96) {// Мигает открыто для (int i = 8; i > 0; я -) {мигание (я, LR); задержка (40); крышка = ложь; }} else if (lid == false && rasioL> 0.96 && rasioR> 0.96) {// нормально // cnt ++; // веко = 0; если (LR <= 7) {для (int я = LR; я <= 7; я ++) {blink (0, я); задержка (40); LR = i; }} else {для (int я = LR; я> = 7; я -) {blink (0, я); задержка (40); LR = i; }}}
// Обновление начального значения if (cnt> 10) {iniSensorValL = sensorValL; iniSensorValR = sensorValR; cnt = 0; }}
Шаг 5: Эксплуатация
Обнаруживайте движение влево и вправо и мигание зрачка с помощью датчика и управляйте светодиодным индикатором глазного яблока.