Так как у меня нет машины, то мне не нужно везде носить с собой ключи. Из-за этого оказывалось, что я несколько раз оказывался без ключей вне дома и мне приходилось ждать, пока кто-либо из родственников вернётся домой и впустит меня, и в какой-то момент я решил, что нужно что-то с этим сделать и сконструировал самодельный гаражный замок.
В этом проекте я расскажу, как сделать замок с отпечатком пальца на входную дверь.
Шаг 1: Материалы
Вот список необходимых материалов и инструментов.
Электроника:
- Сканер отпечатков пальцев (и коннектор JST)
- Набор LCD (c ATmega328)
- ATtiny85
- NPN-транзистор
- Динамик-пищалка
- Провод для спикера
- Кейс (в шаге 9 будут файлы для 3Д-печати)
- Медная плёнка
- Регулятор напряжения 5V
- Батарейка 9V
- Коннектор для батарейки 9V
- SPDT-выключатель
Для удобства я приложу готовый вишлист на сайте Sparkfun.
Инструмент:
- Паяльник и припой
- Изолента
- Провода и джамперы
- Кусачки / стриппер
- Плата прототипирования
- Разные резисторы
- Винты
- Дрель
- Несколько светодиодов для тестирования
- Плата FTDI 5V
- Пистолет с горячим клеем
- Доступ к 3Д-принтеру
- Опционально: сокет для интегральных схем (8-пиновый для ATtiny и 28-пиновый для ATmega)
- Опционально: еще одна плата Ардуино / конденсатор 10uF (подробности в шаге 5)
Шаг 2: Схема устройства
Приобретённый в Sparkfun LCD-набор шёл с ATmega328, управляющей дисплеем. ATmega328 достаточно мощна и может быть использована не только для управления дисплеем, но и для других задач. Ввиду этого мы можем использовать её вместо Ардуино для коммуникации со сканером отпечатков пальцев и отправки команд на ATtiny85, управления дисплеем и пищалкой.
Чтобы биометрический дверной замок не работал всё время, я встроил в него выключатель, срабатывающий в тот момент, когда кейс закрывается. Если кейс закрыт — питание на девайс не подается, и мы экономим ресурсы батарейки.
Важная заметка: Сканнер отпечатков пальцев работает при напряжении 3.3V, так что я рекомендую использовать разделитель напряжения, который будет преобразовывать сигналы от ATmega к 3.2V. Разделитель напряжения состоит из резистора на 560 Ом между D10 / вторым пином сканера и резистором на 1 КОм между GND / вторым пином сканера.
Распиновка LCD:
- D10 — пин 1 сканера (черный провод)
- D11 — пин 2 сканера (через разделитель напряжения)
- D12 — ATtiny85
- D13 — Пищалка
Распиновка ATtiny85:
- Пин 5 (0 в коде программы) — вход с ATmega
- Пин 3 (4 в коде программы) — транзистор / желтый светодиод
- Пин 7 (2 в коде программы) — светодиод индикации
Шаг 3: Собираем компоненты из LCD-набора
Название шага говорит само за себя: handy-dandy quick start/assembly guide
Шаг 4: Собираем схему на плате прототипирования
Размещение компонентов на плате остается за вами, просто старайтесь припаивать провода так, чтобы они смотрели в одну сторону и не заламывались.
После сборки я покрыл верх и низ платы горячим клеем — это закрепило и изолировало элементы схемы. Горячий клей не повредит микросхему.
Как и с основной платой, припаяйте все к плате ATtiny и нанесите горячий клей для закрепления и изоляции компонентов. Регулятор напряжения может очень сильно греться, поэтому будет хорошей идеей не наносить горячий клей на него и поверхности, располагающиеся рядом с ним. Также лучше не покрывать горячим клеем плату ATtiny, ведь вы можете захотеть снять и перепрограммировать её.
Шаг 5: Программирование ATmega328
Как уже говорилось в шаге 2, у ATmega328 достаточно сильный процессор и достаточно пинов для управления LCD, в то время как он управляет другими дополнительными компонентами. Чтобы добиться этого, нужно запрограммировать чип.
Если у вас есть Arduino Uno или Duemilanove, вы можете просто снять с них чип и заменить его тем, который шел в наборе. Либо вы можете найти плату FTDI Basic Breakout (5V) и припаять насадки к её стороне (смотрите картинки в шаге 3)
Также вам нужно будет залить код в режиме «Duemilanove w/ ATmega328».
Код внизу — рабочая программа для проверки работоспособности девайса.
#include "LiquidCrystal.h" LiquidCrystal lcd(2,3,4,5,6,7,8); void setup() { pinMode(9, OUTPUT); //подсветка pinMode(13, OUTPUT); //пищалка lcd.begin(16, 2); //16 знаков в ширину, 2 в высоту digitalWrite(9, HIGH); //включаем подсветку lcd.print(" Hello world! "); //центрируйте текст при помощи пробелов delay(2000); } void loop() { //пищалка включается и выключается, её состояние отображается на дисплее lcd.clear(); lcd.print(" Buzzer is on "); tone(13, 262, 1000); delay(1000); lcd.clear(); lcd.print(" Buzzer is off "); delay(1000); } Файлы
Шаг 6: Настраиваем сканер отпечатков пальцев
Для коммуникации со сканером я использовал эту библиотеку . Прямая ссылка на скачивание .
Для проверки работоспособности кода загрузите эту программу проверки «миганием».
У сканера отпечатков есть своя встроенная память для хранения данных. Так что после того, как вы убедитесь, что сканер работает, загрузите эту программу, чтобы добавить ваш отпечаток в базу данных под id #0. Откройте последовательную консоль и просто следуйте инструкциям.
Программа мигания светодиода для проверки сканера
/* Этот простой код включит и выключит светодиод. Он используется для того, чтобы понять, работает ли коммуникация. */ #include "FPS_GT511C3.h" #include "SoftwareSerial.h" //Настройка железа - сканер пальцев соединён с: //цифровым пином 10(arduino rx, fps tx) //цифроывм пином 11(arduino tx - резистор 560ohm fps tx - резистор 1000ohm - GND) //это понижает 5v tx примерно до 3.2v и мы не сожжем наш сканер FPS_GT511C3 fps(10, 11); void setup(){ Serial.begin(9600); fps.UseSerialDebug = true; // вы сможете увидеть сообщения на последовательном дебаг-экране fps.Open(); } void loop(){ // тест мигания светодиодов для сканера fps.SetLED(true); // включает LED внутри сканера delay(1000); fps.SetLED(false);// выключает LED внутри сканера delay(1000); }Программа регистрации данных в сканер
#include "FPS_GT511C3.h" #include "SoftwareSerial.h" //Настройка железа - сканер пальцев соединён с: //цифровым пином 10(arduino rx, fps tx) //цифроывм пином 11(arduino tx - резистор 560ohm fps tx - резистор 1000ohm - GND) //это понижает 5v tx примерно до 3.2v и мы не сожжем наш сканер FPS_GT511C3 fps(10, 11); void setup(){ Serial.begin(9600); delay(100); fps.Open(); fps.SetLED(true); Enroll(); } void Enroll(){ // Тест регистрации // поиск открытого id int enrollid = 0; fps.EnrollStart(enrollid); // регистрация Serial.print("Press finger to Enroll #"); Serial.println(enrollid); while(fps.IsPressFinger() == false) delay(100); bool bret = fps.CaptureFinger(true); int iret = 0; if (bret != false) { Serial.println("Remove finger"); fps.Enroll1(); while(fps.IsPressFinger() == true) delay(100); Serial.println("Press same finger again"); while(fps.IsPressFinger() == false) delay(100); bret = fps.CaptureFinger(true); if (bret != false) { Serial.println("Remove finger"); fps.Enroll2(); while(fps.IsPressFinger() == true) delay(100); Serial.println("Press same finger yet again"); while(fps.IsPressFinger() == false) delay(100); bret = fps.CaptureFinger(true); if (bret != false) { Serial.println("Remove finger"); iret = fps.Enroll3(); if (iret == 0) { Serial.println("Enrolling Successfull"); } else { Serial.print("Enrolling Failed with error code:"); Serial.println(iret); } } else Serial.println("Failed to capture third finger"); } else Serial.println("Failed to capture second finger"); } else Serial.println("Failed to capture first finger"); } void loop(){ delay(100000); } ФайлыШаг 7: Программируем ATtiny85
ATtiny85 — это что-то типа дешевого Ардуино, собранного в одном чипе. ATtiny85 может быть запрограммирована другим Ардуино, включая ATmega328, который есть в нашем наборе LCD. В проекте он используется для запуска очень простых команд: проверить сигнал с ATmega и открыть ворота, если сигнал правильный.
Чтобы запрограммировать его, подключите всё согласно приложенным фотографиям. Затем скачайте необходимые файлы и следуйте этой инструкции .
После загрузки кода, пин 13 на Ардуино (встроенный светодиод) должен загореться, оповещая, что код загружен.
Итоговый код:
//Получает краткий сигнал от основного модуля для закрытия реле void setup(){ pinMode(2,OUTPUT); //LEd индикации через резистор на 10K pinMode(4,OUTPUT); //пин странзистора, открывающий гараж pinMode(0,INPUT); //ввод delay(500); //даём девайсу время для старта digitalWrite(2, HIGH); //LED индикации } void loop(){ if(digitalRead(0)){ //простой паттерн для переключения транзистора delay(125); if(digitalRead(0)==false){ delay(55); //ждём, так как таймер ATtiny не идеален if(digitalRead(0)){ delay(55); if(digitalRead(0)==false){ delay(55); if(digitalRead(0)){ delay(55); if(digitalRead(0)==false){ digitalWrite(4, HIGH); //транзистор "нажимает" кнопку delay(1000); digitalWrite(4,LOW); digitalWrite(2,LOW); delay(1000); digitalWrite(2, HIGH); } } } } } } } Файлы
Шаг 8: Итоговый код
Ниже приложена программа для Ардуино, которую я написал с использованием библиотек сканера и дисплея. Чтобы было понятно, что происходит в каждой части программы, я постарался закомментировать всё наилучшим образом. После загрузки этого кода всё должно заработать и всё что останется сделать — интегрировать систему в дверь.
Предупреждение: если библиотека сканера не работает, то попробуйте использовать старую версию IDE Ардуино .
Код для ATmega238:
#include "LiquidCrystal.h" //библиотека дисплея #include "FPS_GT511C3.h" //библиотека fps (сканера отпечатков) #include "SoftwareSerial.h" //используется библиотекой сканера //Настраиваем пины дисплея и сканера LiquidCrystal lcd(2, 3, 4, 5, 6, 7, 8); //распиновка дисплея FPS_GT511C3 fps(10, 11); //RX, TX boolean isFinger = false; //true если библиотека fps засечет палец на сканере //выходные пины const int buzzerPin = 13; const int backlightPin = 9; const int attinyPin = 12; const String idNames = { "self","Bro", "Ryan", "Mom", "Dad", "Auntie", "Grandma", "Zeide", "Person", "person", "Thumb"}; void setup(){ //настраиваем выходы pinMode(buzzerPin, OUTPUT); pinMode(backlightPin, OUTPUT); pinMode(attinyPin, OUTPUT); //для отладки //Serial.begin(9600); fps.UseSerialDebug = false; //становится true для отладки fps через последовательный порт //инициализация библиотек lcd.begin(16,2); digitalWrite(backlightPin, HIGH); //подсветка LCD fps.Open(); fps.SetLED(true); //светодиод на fps //звук загрузки for(int i=0; i<30; i++){ tone(buzzerPin, 50+10*i, 30); delay(30); } tone(buzzerPin, 350); //вывод стартового сообщения lcd.print("Put your finger "); //команда вывода на экран lcd.setCursor(0, 1); //устанавливаем курсор на нулевую колонку первой строки lcd.print(" on the scanner "); delay(150); noTone(buzzerPin); //останавливаем стартовый звук } void loop(){ //сканируем и распознаём отпечаток, когда приложен палец waitForFinger(); lcd.clear(); //очищаем экран и устанавливаем курсов в положение 0,0 fps.CaptureFinger(false); //захватываем отпечаток для идентификации int id = fps.Identify1_N(); //идентифицируем отпечаток и сохраняем id if(id <= 10){ lcd.print(" Access granted "); //сообщение об успехе lcd.setCursor(0,1); //выводим на экран имя когда дверь открывается String message = " Hey " + idNames + "!"; lcd.print(message); tone(buzzerPin, 262, 1000); delay(1500); //отправляем сигнал для открытия двери digitalWrite(attinyPin, HIGH); //первый импульс синхронизирует задержку (10ms) delay(5); digitalWrite(attinyPin, LOW); delay(3); digitalWrite(attinyPin, HIGH); //следующие два - открывают дверь delay(15); digitalWrite(attinyPin, LOW); delay(5); digitalWrite(attinyPin, HIGH); delay(10); digitalWrite(attinyPin, LOW); delay(1000); lcd.clear(); lcd.print("Don"t forget to "); lcd.setCursor(0,1); lcd.print(" shut me off! "); delay(2000); waitForFinger(); //нажмите чтобы продолжить запись while(true){ //сохраняет новый отпечаток //выводит сообщение на экран lcd.clear(); lcd.print(centerText("So you want to")); lcd.setCursor(0,1); lcd.print(centerText("scan a new one?")); delay(2000); //Скопировано и слегка модифицировано из примера регистрации данных: int enrollid = 11; //выбираете какой id переписать\создать //отпустите палец, когда хотите записать id/имя, напечатанное на экране waitForFinger(); //ждёт, когда будет нажат fps while(enrollid==11){ for (int i = 1; i1){ lcd.print(i); enrollid = i-1; break; } } } //предупреждение, если в данном слоте уже есть данные if(fps.CheckEnrolled(enrollid)){ lcd.clear(); lcd.print(" Warning! ID #"); lcd.print(enrollid); lcd.setCursor(0,1); lcd.print(" has data. OK? "); delay(2500); waitForFinger(); //ждёт, когда будет нажат fps fps.DeleteID(enrollid); //удаляет данные delay(100); } //Enroll fps.EnrollStart(enrollid); lcd.clear(); lcd.print("Place finger to "); lcd.setCursor(0,1); lcd.print("enroll #"); lcd.print(enrollid); //выводит id, который был добавлен waitForFinger(); //ждёт, когда будет нажат fps //захватывает отпечаток и сохраняет его в память трижды для точности данных bool bret = fps.CaptureFinger(true); //картинка высокого качества для записи int iret = 0; //в случае ошибки if (bret != false){ //первая регистрация lcd.clear(); lcd.print(" Remove finger "); fps.Enroll1(); while(fps.IsPressFinger() == true) delay(100); //ждёт пока уберут палец lcd.clear(); lcd.print(" Press again "); waitForFinger(); //ждёт, когда будет нажат fps bret = fps.CaptureFinger(true); if (bret != false){ //вторая регистрация lcd.clear(); lcd.print(" Remove finger "); fps.Enroll2(); while(fps.IsPressFinger() == true) delay(100); lcd.clear(); lcd.print("Press yet again "); waitForFinger(); bret = fps.CaptureFinger(true); if (bret != false){ //третья регистрация iret = fps.Enroll3(); if (iret == 0){ //проверяет, были ли какие-нибудь ошибки lcd.clear(); lcd.print(" Success! "); delay(2000); beep(); //выключает Ардуино } else{ //запускает этот код в случае любой ошибки lcd.clear(); lcd.print("Fail. Try again "); delay(1000); } } lcd.clear(); lcd.print(" Failed 3rd "); //ошибка на третьей записи delay(1000); } lcd.clear(); lcd.print(" Failed 2nd "); //ошибка на второй записи delay(1000); } lcd.clear(); lcd.print(" Failed 1st "); //ошибка на первой записи delay(1000); } } else{ lcd.print("Fingerprint is"); //если отпечаток не распознан lcd.setCursor(0,1); lcd.print(" unverified "); delay(2000); lcd.clear(); lcd.print("Please try again"); lcd.setCursor(0,1); lcd.print("Use your pointer"); //pointer - указательный палец (можете использовать любой и заменить это слово) delay(500); } delay(250); } void beep(){ //издаёт звуки, чтобы кто-нибудь закрыл кейс lcd.clear(); lcd.print("Please close the"); lcd.setCursor(0,1); lcd.print(" case! "); for(int i=0;i=80 && !fps.IsPressFinger()){ beep(); } } timer = 0; //обнуляет таймер как только функция завершится } String centerText(String s) { //центрует текст на дисплее, чтобы он лучше смотрелся while(16-s.length()>1){ //если текст нуждается в центровке s = " " + s + " "; //равномерно добавляет пробелы с обеих сторон } return s; } Файлы
Для создания такого проекта автору пришлось модифицировать пусковую систему своего транспортного средства. Главным соединением служит проводник IG от замка зажигания, через который подаётся напряжение питания на регулятор напряжения, после чего уже на сам Arduino для его включения, а также включения датчика сканирования пальца. Если сканирование пальца проходит успешно система активирует релейный блок, а он управляет реле стартера. Теперь можно завести автомобиль . Датчик работает 10 секунд, и запустить его повторно можно повторив цикл запуска зажигания. Если же за отведённое время датчик не обнаружил отпечаток пальца или он не совпадает с заданным, тогда система запуска будет отключена, и пуск двигателя не произойдёт.
Поскольку у каждого авто своя система конфигурации запуска, то необходимо заглянуть в электрическую схему перед модификацией системы запуска двигателя.
В этой статье описано подключение противоугонного устройства на 2-х дверный купе Mitsubishi Lancer 2000.
Материалы:
- Arduino Uno.
- Датчик отпечатков пальцев.
- Источник питания.
- Релейный блок.
- NPN-транзистор BC547B
- Резистор 1 кОм
Схема подключения:
Схема немного модифицирована в соответствии с используемыми компонентами. Следует помнить что она действительная только для этой модели автомобиля.
Шаг 1 Подготовка программных компонентов:
В среде разработки Arduino IDE загружается и добавляется библиотека .
Загружается файл из библиотеки blank.ino в Arduino, который будет служить как интерфейс между датчиком и микроконтроллером.
Устанавливается программа , и датчик подключается к Arduino как показано на схеме. После чего загружается отпечаток пальца через установленную программу.
Теперь датчик подключили как показано на следующей схеме. После чего автор приступает к загрузке основной программы. Светодиод с резистором подключается к выводу 12.
Программа будет работать в основном по учебному материалу Adafruit Fingerprint. В программный код добавлен разве что таймер отключения датчика в 10 секунд. Скачать код можно под статьей.
Шаг 3 сборка:
Часть 1:
Для начала выкручиваются винты под приборной панелью. Снимается нижняя часть панели, и в свободное место можно будет поместить датчик.
Часть 2:
В выбранном месте для датчика вырезается зона для его надёжной установки.
часть 3:
Плата Arduino устанавливается позади датчика отпечатков пальцев. Место для установки Arduino было немного подточено что б плата могла занять правильное положение.
часть 4:
Регулируемый источник питания устанавливается сзади приборной панели на стороне водителя.
часть 5:
Остальные компоненты оборудования подключаются согласно схеме в начале статьи.
Шаг 4 установка:
Необходимые провода подсоединяются, и устройство устанавливается под приборной панелью. Автор убеждается что нет короткого замыкания.
Что нужно
- Модуль отпечатков пальцев FPM10A
- RFID-модуль RC522
- Arduino mega (теоретически можно использовать и другие платы но я остановился на данной из-за количества выводов)
- 1 лицензия на 1С 8.2 (толстый клиент в моём случае, под тонкий пилите сами)
- Связь по Com порту с помощью MsCommLib.MsComm (нужна лицензия, ягуглится даже тут)
- Среда разработки для ардуино (использована 1.8.5)
- Планшет с USB интерфейсом.
- Обвязка: Резистор 1 Кило ОМ, кнопка на замыкание, проводочки, "синяя" изолента, терморектальный крипоанализатор по желанию (можно скрутить проводочки если с данным прибором вас связывают тесные непередаваемые ощущения), USB кабель для ардуиино, прямые руки и кривые извилины среднестатистического 1с ника в т.ч. для изготовления корпуса для всего этого чуда.
Примечания: на фото цвета проводов разнятся - в процессе монтажа порвал несколько проводов т.к. они были совсем Huawei и пришлось брать других доступных цветов.
Система сообщений дублируется в критических моментах специально.
Сразу предупреждаю что может у среднестатистического инженера могут потечь слезы из глаз из канифоли но это мой вообще первый Ардуино проект да еще и такой сложности и вроде оно работает и работает стабильно. Сначала была идея сделать всё через сеть (wifi + проводная) но прикинув затраты на отладку и создание своего http сервиса и внедрение всё в 1с я решил использовать com, в любом случае всю логику можно без изменения конфы вынести во внешнюю обработку.
Можно ещё вставить систему фотографирования входящего сотрудника через web камеру планшета, добавить реле и управлять электронными воротами, допилить интеграцию с ЗУП через внешнюю обработку, передаваемую через параметры запуска и аннигиляцию масленницы для особо опасных проходных секретной важности).
Полезная критика приветствуется.
Пролог
Видя цены на существующие пропусные системы и системы учета времени меня медленно начала душить зеленая сущность. Долго ходив около ардуинки и её модулей наткнулся на модуль отпечатков пальцев FPM10A. Данный модуль в зависимости от версии может запоминать большое количество отпечатков пальцев - от 50 до бесконечности её флеш памяти и используется в большинстве модулей производителей биометрического контроля. Однако в моём проекте из-за библиотеки оно ограниченно 254. Сразу предупреждаю что выкладываю свою измученно-найденную библиотеку для ардуино т.к. долго мучался с поиском и угробил 3 дня на поиски и отладку библиотеки для данного модуля.
Описание модулей
Библиотека, использованная в проекте позволяет использовать до 256 (byte) отпечатков пальцев. Мне это количество было избыточным, в крайнем случае можно использовать по 1 модулю на каждых 256 сотрудников.
Количество RFID меток ограниченно лишь уникальностью их UID т.к. база может хранится в 1С и привязанна к сотрудникам. Метки можно использовать все совместимые. Теоретически могут подходить всякие ключи от домофонов, карты метро и карты тройка.
Соединение с 1с идёт по com порту через библиотеку MsCommLib.MsComm но можно переписать под любую другую. Драйвера для com порта для Ардуинки должны ставится вместе со средой разработки ардуино но так же ягуглятся.
Всё спаенное прячется в коробку, связывается по сети (я использовал WiFi но можно и внешнюю USB сетевую карту использовать).
Алгоритм работы
Аппаратно:
- Модули ардуино спаиваем/скручиваем
- Подключаем к ПК-программатору и заливаем прошивку в арду, запускаем тест, убеждаемся в работоспособности команд
- Через USB соединяются с планшетом на Windows 10. На планшете заменяем либо через автозагрузку:
А) через батник:
пуск - выполнить: shell:startup
создаем там через "блокнот" файл с именем hz.bat и содержанием (уверен что сами справитесь с параметрами файловой базы - у меня sql): "C:\Program Files\1cv8\ ... \bin\1cv8.exe" ENTERPRISE /SServerName:Port\DBName" /NUser /PPassword
Б) более совершенный через замену шелла делаем через VB script (обязательно создайте кроме пользователя по умолчанию другого без запуска шелла):
создаем через "блокнот" файл с именем C:\hz\hz.vbs и содержанием
set oShell=createobject("wscript.shell")
sCmd="""C:\Program Files\1cv8\ ... \bin\1cv8.exe"" ENTERPRISE /SServerName:Port\DBName" /NUser /PPassword"
oShell.run sCmd,true
sCmd="shutdown /r /t 0"
oShell.run sCmd
пуск - выполнить: regedit, идём по ветке: Current User\Software\Microsoft\Windows NT\CurrentVersion\Winlogon
добавляем строковый параметр "Shell" (REG_SZ)
редактируем его: "wscript C:\hz\hz.vbs" (без кавычек в параметре)
ребут и тест. 1с должна запускаться без explorera
- Далее убеждаемся в работоспособности и упаковываем в коробку
Программно:
- В обычном состоянии ардуино опрашивает сканер отпечатков пальцев, RFID сканер, кнопку администрирования и посылает по com порту команды ожидания.
- Как только в поле зрения считывателей появляется палец посылаем команду в com порт и 1с видит либо ID пальца, либо UID метки через чтение переменных.
- Кнопка нужна для администирования отпечатков. При её нажатии 1с опрашивает пароль-логин и дальше может присвоить сотруднику либо ID сканера либо UID карты через систему сообщений.
Для связи с 1с используется следующие строки (обработку я делал для своей конфы и своего табеля, она в проекте просто для примера но включена в исходники):
Подключение к com порту
Процедура СтартСистемы() ComPort = Новый COMОбъект("MsCommLib.MsComm"); Попытка ComPort.CommPort = 3; ComPort.Settings = "9600,N,8,1"; ComPort.Handshaking = 0; ComPort.InBufferCount = 0; ComPort.InBufferSize = 70; ComPort.InputLen = 0; ComPort.InputMode = 1; ComPort.NullDiscard = 0; ComPort.PortOpen = Истина; Исключение Предупреждение("Не возможно открыть порт!"); ЭтаФорма.Закрыть(); КонецПопытки; чСекунд = 0; ПодключитьОбработчикОжидания("ВывестиДанныеСПорта", 1, Ложь); // Подключим обработчик для мониторинга порта КонецПроцедуры
Отключение от com порта
Процедура КонецСистемы() ОтключитьОбработчикОжидания("ВывестиДанныеСПорта"); ComPort.PortOpen = Ложь; ComPort = ""; КонецПроцедуры
Считывание данных с com порта
Процедура ВывестиДанныеСПорта() Экспорт ДанныеСПорта = ""; Если ComPort.PortOpen Тогда //ComPort.Output = "1"; ДанныеСПорта = ComPort.Input; ОбработатьЗашифрованнуюСтроку(ДанныеСПорта); Если СокрЛП(ПредСотрудник) <> "" Тогда чСекунд = чСекунд + 1; КонецЕсли; Если чСекунд > 60 Тогда ПредСотрудник = 0; чСекунд = 0; КонецЕсли; Иначе Предупреждение("Порт не открывается"); ЭтаФорма.Закрыть(); КонецЕсли; КонецПроцедуры Процедура ОбработатьЗашифрованнуюСтроку(ДанныеСПорта) Массив = ДанныеСПорта.Выгрузить(); ИндексМин = ДанныеСПорта.GetLowerBound(0); ИндексМакс = ДанныеСПорта.GetUpperBound(0); СтрокаИнфо = ""; Для Индекс = ИндексМин По ИндексМакс - 1 Цикл СимволПолученный = СокрЛП(Массив.Получить(Индекс)); Если СимволПолученный = "13" Тогда Если Не Приостановить Тогда СтрокаИнфо = ОбработкаСтроки(СтрокаИнфо); //Тут обработка сообщений КонецЕсли; Иначе СтрокаИнфо = СтрокаИнфо + Символ(Число(СимволПолученный)); КонецЕсли; КонецЦикла; КонецПроцедуры
Отправка информации в com порт
Процедура ОтправитьВПорт(Отправить) Если ComPort.PortOpen Тогда ComPort.Output = СокрЛП(Отправить); Иначе Сообщить("Порт не открывается",СтатусСообщения.ОченьВажное); КонецЕсли; КонецПроцедуры
Код проекта для Arduino Mega
#include
Эпилог
Цена планшета около 10 000 руб. (на самом деле от 7000 новые можно купить с 1 Gb ОЗУ но с 4Gb 1с будет поприятнее двигаться, я вообще взял б.у. с рук за 6000 в идеальном состоянии с 1Gb но повозился с оптимизацией).
Проходная делалась для мебельного производства поэтому корпус я изготовил там же. Думаю что можно напилить "смесь опилок с картоном" в магазине за 1 000 руб. и скрутить саморезами/склеить суперклеем. В крайнем случае можно взять готовый ящик (например электрошкафчик) и выпилить там окно.
Модули ардуинки и прочее около 2 000 руб.
Удовольствие от мозгового штурма и изготовления - бесценно!
Для создания связи с датчиком отпечатков, была использована инструкция от Джоша Хоули (прямая загрузка инструкции ).
Чтобы отладить работу сканера отпечатков пальцев с буквенным табло, надо синхронизации.
Датчик отпечатков пальцев имеет собственную память для хранения отсканированных снимков. Так что после того, как датчик начнет работать, загрузите этот , добавив его в базу данных отпечатков пальцев под адресом 0. Откройте на компьютере консоль управления и следуйте всплывающим подсказкам.
Коды – Blink Example:
/* Library example for controlling the GT-511C3 Finger Print Scanner (FPS) */ #include "FPS_GT511C3.h" #include "SoftwareSerial.h" //Hardware setup - FPS connected to: //digital pin 10(arduino rx, fps tx) //digital pin 11(arduino tx - 560ohm resistor fps tx - 1000ohm resistor - ground) //this brings the 5v tx line down to about 3.2v so we dont fry our fps FPS_GT511C3 fps(10, 11); void setup(){ Serial.begin(9600); fps.UseSerialDebug = true; // so you can see the messages in the serial debug screen fps.Open(); } void loop(){ // FPS Blink LED Test fps.SetLED(true); // turn on the LED inside the fps delay(1000); fps.SetLED(false);// turn off the LED inside the fps delay(1000); }
Коды – Enroll Example:
/* FPS_Enroll.ino - Library example for controlling the GT-511C3 Finger Print Scanner (FPS) */ #include "FPS_GT511C3.h" #include "SoftwareSerial.h" //Hardware setup - FPS connected to: //digital pin 10(arduino rx, fps tx) //digital pin 11(arduino tx - 560ohm resistor fps tx - 1000ohm resistor - ground) //this brings the 5v tx line down to about 3.2v so we dont fry our fps FPS_GT511C3 fps(10, 11); void setup(){ Serial.begin(9600); delay(100); fps.Open(); fps.SetLED(true); Enroll(); } void Enroll(){ // Enroll test // find open enroll id int enrollid = 0; fps.EnrollStart(enrollid); // enroll Serial.print("Press finger to Enroll #"); Serial.println(enrollid); while(fps.IsPressFinger() == false) delay(100); bool bret = fps.CaptureFinger(true); int iret = 0; if (bret != false) { Serial.println("Remove finger"); fps.Enroll1(); while(fps.IsPressFinger() == true) delay(100); Serial.println("Press same finger again"); while(fps.IsPressFinger() == false) delay(100); bret = fps.CaptureFinger(true); if (bret != false) { Serial.println("Remove finger"); fps.Enroll2(); while(fps.IsPressFinger() == true) delay(100); Serial.println("Press same finger yet again"); while(fps.IsPressFinger() == false) delay(100); bret = fps.CaptureFinger(true); if (bret != false) { Serial.println("Remove finger"); iret = fps.Enroll3(); if (iret == 0) { Serial.println("Enrolling Successfull"); } else { Serial.print("Enrolling Failed with error code:"); Serial.println(iret); } } else Serial.println("Failed to capture third finger"); } else Serial.println("Failed to capture second finger"); } else Serial.println("Failed to capture first finger"); } void loop(){ delay(100000); }
Файл синхронизации:
Файл регистрации эскизов:
Этап 7: программирование процессора ATtiny85
Микрочип ATtiny85 стоит дешево, и полностью совместим с платой Arduino, наверное, он самая лучшая электродеталь из когда-либо созданных!
Программатор Arduino также нужен, чтобы перепрошить микросхему ATmega328, которая управляет работой ЖК-дисплея.
В собираемом устройстве процессор ATtiny будет выполнять очень простые команды: проверять наличие сигнала от ATmega и открывать дверь гаража, когда сигнал будет подтвержден.
Чтобы запрограммировать работу процессора, его надо подключить при помощи макетной платы к программатору вместе с конденсатором 10 мкФ, как показано на картинке ниже.
А затем загрузить окончательный код и следовать рекомендациям инструкции от High-Low Tech .
После , выход 13 на плате Arduino, соединённый со светодиодом, нужно перевести в состояние HIGH для отслеживания работы по световой индикации.
Окончательный код для ATtiny :
//fpsAttiny by Nodcah //Recieves a brief signal from the main module to close a relay void setup(){ pinMode(2,OUTPUT); //indicator led through 10K resistor pinMode(4,OUTPUT); //trasistor pin that opens the garage pinMode(0,INPUT); //input delay(500); //give things time to start up digitalWrite(2, HIGH); //indicator LED } void loop(){ if(digitalRead(0)){ //simple pattern to trigger the transistor delay(125); if(digitalRead(0)==false){ delay(55); //the timings are off because the ATtiny"s timer isn"t perfect if(digitalRead(0)){ delay(55); if(digitalRead(0)==false){ delay(55); if(digitalRead(0)){ delay(55); if(digitalRead(0)==false){ digitalWrite(4, HIGH); //transistor "presses" the button delay(1000); digitalWrite(4,LOW); digitalWrite(2,LOW); delay(1000); digitalWrite(2, HIGH); } } } } } } }
Биометрический замок – окончательный код, вырезание крышки, подготовка гаража GPS часы на Arduino Биометрический замок – Схема и сборка ЖК дисплея