Разработка комплексного ПО для автоматизации лакокрасочного производства в торговых точках

ЗаказчикОдним из направлений деятельности заказчика является производство лакокрасочной продукции для различных видов покрытий в торговых точках.ЗадачаСоздать функционал для автоматизации этапов производственного цикла при формировании лакокрасочной продукции.

Клиент

Одним из направлений деятельности заказчика является производство лакокрасочной продукции для различных видов покрытий в торговых точках.

Специалисты компании заказчика разрабатывают рецептуры красок и покрытий для конкретных продуктов и брендов, в том числе проводя лабораторные исследования, а также предоставляют аппаратные средства (дозаторы) и ПО для колеровки и формирования готовой продукции на клиентских точках.

9917fcfee9cf9111c7b3c570baf1f10a.png

Цель и задачи проекта

Цель проекта — создать функционал для автоматизации этапов производственного цикла при формировании лакокрасочной продукции.

Задачи:

  • Разработка модуля для формирования и хранения рецептурной базы с возможностью добавления лакокрасочных брендов, продуктов, цветовых коллекций и колорантов.
  • Разработка модуля взаимодействия с дозатором для колеровки по выбранной рецептуре.
  • Настройка многопользовательского режима для просмотра и ввода/выгрузки данных для торговых точек.

Ситуация до начала проекта

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

Для модуля управления дозатором в торговых точках у заказчика были следующие требования:

  • кроссплатформенность (возможность использования с разными операционными системами);
  • единый инсталлер (простота установки модуля взаимодействия с дозатором в торговых точках);
  • работа в режиме оффлайн (использование локальной базы данных без подключения к локальной сети);
  • автоматическое обновление (единовременно во всех торговых точках для внесения изменений со стороны разработчика);
  • загрузка рецептурной базы и колеровка (по выбранной рецептуре или для собственных рецептур под конкретного клиента).

Кроме того, модуль для колеровки должен был осуществлять взаимодействие с различными типами дозатора через общий UDCP драйвер (отправка команд драйверу и обработки сообщений от драйвера).

Для модуля формирования и хранения рецептур были сформированы отдельные требования:

  • возможность переноса рецептурной базы (перегрузка уже готовых рецептур с сохранением данных о базовой красе, фасовке, поправочных коэффициентах и др.);
  • возможность ввода новых рецептур (в том числе составление новых цветовых коллекций и оттенков);
  • возможность онлайн и оффлайн выгрузки рецептурной базы (для последующей загрузки рецептурной базы в модуль взаимодействия с дозатором).

Реализация проекта

С учетом требований заказчика модуль формирования и хранения рецептурной базы решили реализовать как полноценный многопользовательский веб-сайт на ASP.NET Core платформе. Для разработки серверной части был выбран .NET Core 6.0 Framework (язык программирования C#), клиентская часть на React framework (язык программирования TypeScript). Для реализации многопользовательского режима выбрали бару данных Postgree SQL.

Модуль взаимодействия с дозатором решили реализовать как автономное десктоп-приложение. Для обеспечения кроссплатформенности всю функциональную часть реализовать как веб-сайт на ASP.NET Core платформе, используя аналогичный стэк (.NET Core 6.0 + React), и средствами Electron .NET Framework запаковать сайт в оконное приложение. Также мы использовали функционал (API) SignalR библиотеки для обновления клиентской части веб-сайта после обработки событий от UDCP драйвера на сервере.

Для обеспечения автономности работы модуля взаимодействия с дозатором в качестве локальной базы данных была выбрана SQLite, которая представляет собой файловую базу данных и не требует отдельной СУБД для подключения и работы с БД.

С учетом масштабности и целей проекта разработка проекта была разделена на несколько этапов.

На первом этапе был разработан начальный вариант модуля взаимодействия с дозатором и реализован функционал взаимодействия с дозаторами различных типов через общий UDCP драйвер, который включал в себя поддержку всех операций по взаимодействию с драйвером (инициализация, продувка сопел, перемешивание колорантов и т.д.), включая операцию ручной дозировки колорантов.

0dab40d65caa84e85f5755e587dbd1aa.png

Схема. Механизм выгрузки рецептурной базы из основного веб-сайта в модуль взаимодействия с дозатором

Аналогичное решение использовано для загрузки новых обновлений для дескттоп-приложения на веб-сайт и автоматического скачивания обновлений с последующей автоматической установкой.

Модуль управления дозатором имеет клиент-серверную архитектуру. С клиента на сервер отправляется запрос на формирование команды UDCP драйверу, далее запрос обрабатывается и формируется файл с параметрами команды. На самом сервере происходит постоянный опрос наличия ответа от UDCP драйвера, и при получении результата обработки команды сервер уведомляет клиента через SignalR API.

На втором этапе выполнены следующие задачи:

  • разработка веб-сайта для хранения и формирования рецептурной базы с функционалом аутентификации и разграничением ролей пользователей;
  • создание отдельных разделов для Marketing и R&D подразделений для удобства работы с ПО.

2c5962d2cb0798464dbec9fddceb17e6.png

  • разработка функционала хранения и редактирования информации для формирования рецептур (оттенки, формулы, колеровочные базы, фасовки, продукты и т.д.);
  • перегрузка имеющейся базы рецептур в новую систему.

124eb4cc014a5aa4e26bee79929dadfd.png

На третьем этапе был реализован механизм автоматической перегрузки рецептурной базы из веб-сайта в модуль управления дозатором.

Также был реализован визард для подбора рецептуры по требуемому цвету, продукту, фасовке с последующим формированием команды дозатору на колеровку выбранного цвета.

cc46d7cdce9f0ebe07451c8dc65b4589.png

На четвертом этапе в модуле взаимодействия с дозатором реализовали:

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

Результат

На момент публикации кейса система автоматизации производственного цикла лакокрасочной продукции прошла необходимые проверки и подтвердила работоспособность в 20 пилотных торговых точках заказчика, а общее количество торговых точек, в которые поставляется программное обеспечение, превышает 1500.

В модуле формирования и хранения рецептурной базы реализованы:

  • перегрузка рецептур из базы по всем используемым брендам и продуктам с использованием различных факторов (базовая краска, фасовка, поправочные коэффициенты и т.д.);
  • возможность ввода новых рецептур, включая составление новых цветовых коллекций, оттенков и др.;
  • возможность онлайн и оффлайн выгрузки рецептурной базы в нужном формате для последующей загрузки рецептурной базы в модуль взаимодействия с дозатором.

В модуле взаимодействия с дозатором реализованы:

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

Полный текст статьи читайте на CMS Magazine