Создание панелей (Dashboards) в Node-RED

Материал из Wiren Board
Это утверждённая версия страницы. Она же — наиболее свежая версия.
Пример SVG-панели Node-RED

Описание

Node-RED позволяет создавать интерактивные панели (dashboards) с помощью набора виджетов или svg-изображения.

Подготовка

Для создания интерактивной SVG-панели на контроллере Wiren Board с помощью Node-RED нам понадобится:

Настройка делается через встроенный в Node-Red веб-интерфейс, который доступен по адресу http://wb-ip-address:1880, например, http://192.168.42.1:1880.

В примерах мы будем создавать флоу (flows) — это блок-схемы процесса.

Установка дополнительных модулей

Установленные модули

Установите модуль node-red-dashboard:

  1. Зайдите в веб-интерфейс Node-RED.
  2. В правом верхнем углу вызовите меню.
  3. В открывшемся окне выберите вкладку Управление палитрой (Manager palette).
  4. Перейдите на вкладку Установка (Install), введите в поле поиска dashboard и нажмите на клавиатуре Enter.
  5. Установите пакет с названием node-red-dashboard.
  6. Закройте окно с настройками. Установка модуля завершена.

Аналогично установите модуль node-red-contrib-ui-svg.

Концепция панелей в Node-RED

В Node-RED панель состоит из Вкладок (Tabs), которые содержат Группы (Groups). Группы в свою очередь могут содержать готовые или пользовательские Виджеты (Widgets), или svg-изображения. Ограничения на количество вкладок и групп в документации не описаны.

Между табами можно переключаться из меню, или с помощью ноды ui control. Если вы используете устройство с маленьким экраном, то меню можно отключить для экономии места.

Создание панели с виджетами

Панель с виджетами

Панель с типовыми виджетами — это быстрый способ получить несложный интерфейс, который закроет большинство потребностей. Притом, интерфейс получается адаптивный, то есть при нехватке места по горизонтали, группы располагаются друг под другом.

Создадим панель, на которую поместим элементы управления зуммером контроллера:

  1. Перейдите в веб-интерфейс Node-RED.
  2. В правом верхнем углу нажмите на треугольничек и выберите инструмент Dashboard.
  3. В Layout добавьте новую вкладку, а в ней — группу.
  4. В левой панели в группе dashboard найдите ноды switch и slider и перетащите их в рабочую область.
  5. По очереди дважды кликните на добавленных нодах, проверьте, что выбрана верная группа Group 1:
  6. В настройках ноды switch:
    • снимите флажок Pass through msg if payload matches valid state;
    • в поле Indicator выберите Switch icon shows state of the input;
    • В полях On Payload — a/z: 1, Off Payload — a/z: 0.
  7. В настройках ноды slider:
    • снимите флажок Pass through msg if payload matches valid state;
    • в поле Range установите значение max = 100;
    • в поле Output выберите only release.
  8. В левой панели в группе Wiren Board найдите ноду in и добавьте два экземпляра на панель.
  9. Дважды кликнете на каждой ноде in и в одной выберите канал buzzer/enabled, а в другой — buzzer/volume.
  10. В левой панели в группе Wiren Board найдите ноду out и добавьте два экземпляра на панель.
  11. Дважды кликнете на каждой ноде out и в одной выберите канал buzzer/enabled, а в другой — buzzer/volume.
  12. Соедините ноды между собой по картинке ниже и нажмите вверху кнопку Deploy.

Теперь в инструменте dashboardLayout нажмите на кнопку со стрелочкой, откроется новая страница с нашей панелью.

Создание svg-панели

Добавление вкладки

Переименованные элементы

Добавим новую вкладку и создадим в ней svg-панель:

  1. Чтобы было удобнее, переименуйте элементы созданной выше панели:
    • Group 1 → Buzzer
    • slider → Volume
    • switch → State
  2. Добавьте новую вкладку Tab 2 и группу SVG.
  3. В настройках группы укажите ширину 9.
  4. В левой панели в группе dashboard найдите ноду SVG graphics и перетащите её в рабочую область.
  5. Дважды кликнете на добавленной ноде и настройте её:
    • в поле Group выберите [Tab 2]SVG.
    • на вкладке SVG надо добавить код svg-изображения.

Создание изображения

В ноде SVG graphics есть демо-версия встроенного svg-редактора, но мы будем использовать популярный Inkscape.

Создадим изображение в Inkscape:

  1. Откройте редактор и меню File → Document Properties.
  2. Установите размер страницы, например, 480 x 480 px.
  3. Добавьте серый круг, выберите его и откройте панель с параметрами объекта, меню ObjectObject Properties. Справа откроется дополнительная панель.
  4. В панели Object Properties в поле ID напишите имя элемента: buzzer-status. Это имя мы будем использовать при фильтрации событий и обращении к его свойствам.
  5. Аналогичным образом добавьте другие элементы, например, текст и квадрат.
  6. Сохраните файл в формате SVG.

Импорт изображения

Функции импорта в ноде SVG graphics нет, поэтому мы просто скопируем содержимое нашего svg-файла и вставим его в специальное поле ноды:

  1. Откройте созданный выше svg-файл в текстовом редакторе и скопируйте содержимое вместе с тегами <svg>.
  2. Перейдите в настройки ноды SVG graphics и откройте вкладку SVG.
  3. Удалите весь текст и вставьте скопированное раньше содержимое svg-файла.
  4. Нажмите кнопку Done и Deploy.

Снова перейдите на страницу с панелью, теперь там должно появиться меню, кликните на него и выберите Tab 2.

Описание флоу

Пример флоу SVG-панели
Пример SVG-панели

Пример флоу и svg-файл файл можно скачать на GitHub node-red-demo-svg-dashboard. В примере используются только системные устройства, поэтому он должен работать на всех контроллерах Wiren Board без доработок.

Панель в примере состоит из двух вкладок:

  1. Tab 1 вкладка с виджетами:
    • State — переключатель, который отображает состояние зуммера и управляет им.
    • Volume — ползунок, который показывает и изменяет громкость зуммера.
    • SVG Dash — кнопка, которая открывает вкладку Tab 2.
  2. Tab 2 — вкладка с svg-изображением, которое хранится в ноде SVG graphics. Элементы изображения:
    • Серый круг #buzzer-state — кнопка, которая отображает и переключает состояние зуммера.
    • Текстовое поле #temperature — отображает температуру процессора. Чтобы изменять текст, надо обратиться к селектору #temperature > tspan.
    • Голубой квардрат #buzzer-control — кнопка, которая открывает вкладку Tab 1.

Нода ui control переключает вкладки панели и принимает на вход имя вкладки, которую нужно открыть.

В ноде SVG graphics на вкладке Event описаны события, которые будут генерировать элементы #buzzer-state и #buzzer-control. В обоих случаях на выход ноды SVG graphics будет отправлено сообщение с информацией о событии и элементе, вызвавшим его. Сообщения с описанием событий обрабатываются нодой switch-events.

На вкладке Binding ноды SVG graphics описаны свойства, которые можно менять с помощью соответствующих сообщений: у элемента #buzzer-state будет меняться свойство fill, а в элементе #temperature > tspan будет изменяться текст. Сообщения для изменения свойств генерируются нодами set-color и set-temperature, которые содержат примерно такой код:

return {
    "payload": {
        "buzzer": {
            "color": (msg.payload == '1')? 'yellow': 'gray'
        }
    },
    "topic": "databind"
};

Нода invert-state инвертирует состояние зуммера.

Нода change-tab генерирует событие при переключении вкладок панели и обновляет значение температуры процессора в текстовом поле svg-панели.

Хитрости

Верхнюю панель можно скрыть: перейдите dashboardSite и выберите Hide the title bar. Здесь же находятся настройки меню и размеров виджетов.

Тему можно изменить: перейдите dashboardTheme и выберите одну из тем.

Скрыть заголовок группы можно в настройках, параметр Display group name.

Чтобы скрыть однопиксельную рамку вокруг svg-панели, добавьте на вкладку SVG ноды SVG graphics перед тегом <svg> код:

<style>
    body.nr-dashboard-theme md-toolbar {
        background-color: #1a1a1a;
        color: #fff;
    }

    md-card.nr-dashboard-template {
        padding: 0px;
    }

    ui-card-panel.visible {
        top: 0 !important;
        left: 0 !important;
        border: none;
    }
</style>

Полезные ссылки