Espruino Pico. Учимся программировать
Вообще говоря, Espruino — это несколько вариантов микроконтроллерных устройств, в которых прошит встроенный интерпретатор JavaScript. Espruino Pico — самое миниатюрное из них. Оригинальный интерпретатор JavaScript, используемый в Espruino, предназначен для быстрой разработки на устройствах с ограниченными процессорными ресурсами. Есть его версии для целого перечня платформ, начиная с ESP8266 и до Raspberry Pi.
Для Espruino существует большое число готовых подгружаемых модулей для самого разнообразного периферийного оборудования, совместимого с экосистемой Arduino (см. раздел модули на сайте Espruino) и инструкций по его подключению (в разделе инструкций и примеров). Есть официальный форум.
История Espruino
Платформа Espruino — не самый молодой проект. Первые публичные упоминания о ней датируются еще 2012-м, и в 2013-м была проведена успешная кампания на Kickstarter по сбору средств на развитие проекта. Ее успех позволил в конце 2014 года провести следующую кампанию, на проект более компактной версии под названием Espruino Pico в форм-факторе размером в половину обычной флешки.
Характеристики Espruino Pico
- Espruino Pico — самая миниатюрная из плат Espruino, ее размеры 3,3 × 1,5 см.
- На контакты платы выведено 22 порта ввода-вывода общего назначения, в том числе девять аналоговых входов, 21 с поддержкой ШИМ (PWM), два последовательных порта, три порта SPI, три порта I2C; все GPIO могут работать с 5 В (что важно для совместимости с модулями, разработанными для Arduino).
- Встроенный разъем USB Type-A позволяет включать устройство непосредственно в USB-порт компьютера без дополнительных кабелей аналогично обычной флешке.
- Два встроенных светодиода и одна кнопка позволяют реализовать минимальное управление устройством без внешних компонентов.
- 32-битный процессор ARM Cortex M4 84 МГц — STM32F401CDU6.
- 384 Кбайт флеш-памяти, 96 Кбайт ОЗУ.
- Встроенный регулятор напряжения 3,3 В 250 мА, работающий в диапазоне от 3,5 до 16 В, позволяет подключать внешний аккумулятор без дополнительных компонентов.
- Потребляемый ток в режиме сна: < 0,05 мА — более двух с половиной лет от батареи 2500 мА ∙ ч.
- Встроенный полевой транзистор для управления цепями с высоким рабочим током.
Все примеры кода предназначены исключительно для образовательных целей. Данное решение обладает пониженным уровнем безопасности, секретный ключ хранится на устройстве в открытом виде. Не используй этот код в критически важных системах. Применяй для авторизации промышленно выпускаемые устройства.
Быстрый старт
Для Windows тебе, скорее всего, понадобится установить драйвер виртуального COM-порта.
Под Linux нужно будет сделать следующее: копируем файл 45-espruino.rules
в /etc/udev/rules.d
, перегружаем правила командой sudo udevadm control --reload-rules
и проверяем командой groups
, что текущий пользователь входит в группу plugdev
. Если это не так, исправляем командой sudo adduser $USER plugdev
.
На Mac никаких дополнительных манипуляций потребоваться не должно.
Устанавливаем среду Espruino Web IDE из Crome Web Store.
Рабочая область Espruino Web IDE разделена на две части. В левой расположено окно консоли, в правой — редактор. Нажав на символ </>
, редактор можно переключить в графический режим, основанный на среде Blockly, аналогичной Scratch, что может подойти начинающим.
Для подключения к плате необходимо нажать на желтую иконку с разъемом в верхнем левом углу окна. Будет выведен запрос на выбор порта.
При успешном подключении будет выведено приглашение консоли Espruino:
Connected
>
>
Проверим работоспособность вводом 1+2
:
>1+2
=3
>
Обновление прошивки
Если доступно обновление прошивки, в правом верхнем углу появится соответствующая иконка. При нажатии на эту иконку запустится мастер обновления, который пошагово проинструктирует, что нужно сделать для обновления прошивки.
Загрузка первой программы в Espruino — управление встроенными светодиодами
Следующий шаг стандартный — «помигать светодиодом». Для этого в правой части среды разработки уже есть готовый код:
var on = false;
setInterval(function() {
on = !on;
LED1.write(on);
}, 500);
Единственное, что можно прокомментировать в этих строках, — это использование встроенного объекта LED1
, представляющего собой экземпляр специального класса Pin
, который предназначен для управления портами ввода-вывода. В данном случае метод write
используется для задания уровня на выходе порта (логические ноль/единица), к которому подключен красный светодиод, установленный на плате.
Нажмем на иконку «Send to Espruino».
Через мгновение в консоль будет выведен лого и замигает красный светодиод:
_____ _
| __|___ ___ ___ _ _|_|___ ___
| __|_ -| . | _| | | | | . |
|_____|___| _|_| |___|_|_|_|___|
|_| http://espruino.com
1v94 Copyright 2016 G.Williams
>
=undefined
>
Для отключения функции setInterval()
можно ввести в консоли clearInterval()
.
LED
, LED1
и B2
(номер контакта микроконтроллера, к которому подключен светодиод) соответствуют красному светодиоду, LED2
и B12
(он подключен к контакту B12
) — зеленому. Адресовать светодиоды можно и с помощью номеров контактов, к которым они подключены: B2
эквивалентно LED
и LED1
, B12
— LED2
.
Можно воспользоваться и хорошо знакомой ардуинщикам функцией digitalWrite()
:
digitalWrite(LED2, 1)
Есть возможность изменить состояние на заданный период функцией digitalPulse()
:
digitalPulse(LED1, 1, 50);
Или задать целую последовательность:
digitalPulse(LED1, 1, [50,200,50]);
Порты, к которым подключены светодиоды, смонтированные на плате, не поддерживают режим широтно-импульсной модуляции (ШИМ), или Pulse-Width Modulation (PWM), и попытка изменить их яркость, записав что-то в эти порты функцией analogWrite()
, приведет к ошибке. Но управление яркостью светодиодов все-таки возможно с помощью встроенного режима программной эмуляции ШИМ:
analogWrite(B2, 0.1, {soft:true});
Более того, можно одновременно с этим задать периодическое включение и отключение:
analogWrite(LED2, 0.1, { soft: true, freq: 16 });
Отработка нажатий на встроенную кнопку
Прочитать состояние кнопки позволяет функция digitalRead()
:
>digitalRead(BTN)
=0
Мониторить состояние кнопки можно, периодически считывая ее состояние с помощью setInterval()
, однако более корректным будет использование функции watch()
:
clearWatch(); // Удалить старые триггеры (если были)
setWatch( // Задать новый триггер (watch)
function(e) { // Callback при срабатывании триггера
// e.state — состояние кнопки
digitalPulse(LED1, 1, 50);
},
BTN, // Мониторим состояние встроенной кнопки
{ // Параметры триггера
repeat: true, // Мониторить многократно
debounce : 50, // Предотвращение дребезга контактов (в миллисекундах)
// edge: "rising", // Срабатывать только при нажатии
// edge: "falling", // Срабатывать только при отпускании
edge: "both", // Срабатывать как при нажатии, так и при отпускании
}
);
Продолжение см. на источнике: https://xakep.ru/2017/12/11/espruino-pico/