Привет, Хабр! 👋
Меня зовут Данил, и сегодня я расскажу про свой проект — DotPlus.
Это кроссплатформенное настольное приложение на Rust для генерации QR и штрихкодов в офлайн-режиме, без браузеров, API и регистрации. Оно поддерживает как графический, так и консольный интерфейс, и работает с CSV-файлами для пакетной генерации.
🔧 Зачем это нужно?
Проект появился из личной необходимости: нужно было быстро и массово генерировать QR- и штрихкоды для логистики — без сторонних сервисов и вручную через Excel. Существующие решения часто:
-
требуют подключения к интернету,
-
не поддерживают кириллицу или нестандартные поля,
-
не позволяют работать из командной строки.
Поэтому было решено сделать полностью офлайн-решение, которое:
-
запускается как
.exeбез установки, -
обрабатывает CSV-файлы,
-
экспортирует результат в PNG,
-
поддерживает массовую генерацию.
🏗️ Архитектура
DotPlus состоит из двух независимых интерфейсов:
-
GUI — визуальный редактор на
egui, с предпросмотром и настройкой параметров, -
CLI — запуск через терминал с аргументами и пакетной обработкой.
Оба интерфейса используют общее ядро, которое отвечает за парсинг, генерацию кодов и экспорт изображений.
# Пример CLI @echo off cd /d "%~dp0" dot-plus.exe ^ --mode barcode ^ --csv "%~dp0examples\magnit\data\barcode\magnit-barcodes-EAN-13.csv" ^ --output "%~dp0examples\magnit\img\barcode" ^ --barcode-type EAN-13 ^ --cols 3 ^ --rows 4 ^ --width 300 ^ --height 100 ^ --font-size 22 ^ --label-height 40 ^ --offset-y 10 ^ --spacing-x 20 ^ --spacing-y 20
📦 Используемые библиотеки
|
Компонент |
Библиотека |
Назначение |
|---|---|---|
|
GUI |
|
Кроссплатформенный интерфейс |
|
Диалоги |
|
Файловые open/save-диалоги |
|
Чтение CSV |
|
Парсинг входных данных |
|
QR-коды |
|
Генерация кодов с поддержкой UTF-8 |
|
Штрихкоды |
|
EAN-13, EAN-8, Code 39, 93, Codabar |
|
Работа с PNG |
|
Отрисовка кодов, вставка логотипов |
|
Настройки |
|
Конфигурация шаблонов и пользовательских параметров |
|
Утилиты |
|
Стабильность, логгинг, имена файлов |
🧱 Компонентная схема

📄 Как всё работает
1. CSV-файл на входе:
content A123456A D123456D
id,name,url 1,Продукт A,https://example.com/a 2,Продукт B,https://example.com/b
2. Генерация кодов
В зависимости от настроек, приложение создаёт QR или штрихкоды для каждого ряда. Поддерживаются подписи, логотипы и кастомная вёрстка.
3. Экспорт
На выходе получаем PNG-файлы (или PDF — в будущих версиях). Пример можно сразу отправить на печать на термопринтер или бумажный лист.
⚙️ CLI-интерфейс
CLI реализован вручную — без clap, но с полноценной поддержкой параметров, включая размеры сетки, шрифты и логотипы.
let csv_path = args.iter().position(|a| a == "--csv") .and_then(|i| args.get(i + 1)) .ok_or("❗ Missing --csv argument")?; let output_dir = args.iter().position(|a| a == "--output") .and_then(|i| args.get(i + 1)) .ok_or("❗ Missing --output argument")?; // далее — логика обработки
Это позволяет использовать .bat или .sh скрипты для пакетной генерации.
🖼️ Скриншоты
💡 Почему именно Rust?
Несколько причин:
-
Производительность и быстрый запуск (особенно при пакетной генерации)
-
Безопасность без garbage collector’а
-
Возможность объединения GUI и CLI на общей логике
-
Хорошая экосистема:
image,qrcode,barcodersработают стабильно
⚠️ Что было сложно
-
Вёрстка в
egui— ограниченные layout-возможности, особенно при попытке выстроить сетки и выравнивание по ячейкам. Пришлось писать свои обёртки и выравнивать вручную по координатам. -
Кириллица и шрифты —
eguiиimageне включают шрифты по умолчанию. Без явной загрузки TTF-шрифтов кириллица отображается некорректно или вовсе не рендерится. -
PNG и логотипы — вставка логотипа в QR-код оказалась нетривиальной: важно правильно вырезать центральную часть, чтобы сохранить читаемость и не повредить структуру кода. Также пришлось реализовать масштабирование логотипа по маске.
-
Ручной CLI-парсинг — захотелось обойтись без внешних зависимостей вроде
clap, но при большом количестве параметров это усложняет код и требует ручной валидации, особенно для опциональных и числовых значений. -
Размеры выходных PNG — при генерации сетки из QR/штрихкодов на лист формата A4 возникли трудности с расчётом DPI, отступов, шрифтов и интервалов, особенно при экспорте для печати на термопринтерах.
📥 Лицензия
Проект не является open-source — он создавался как практическое приложение под конкретные задачи, и пока код не планируется к публикации.
Тем не менее:
-
Бинарники доступны бесплатно — для личного, образовательного и некоммерческого использования.
-
Если вы хотите использовать DotPlus в коммерческом продукте, встраивать в процессы или распространять — напишите мне лично, я открыт к обсуждению.
🧪 Где может пригодиться
-
Логистика: создание этикеток для посылок
-
Торговля: штрихкоды на товары, упаковку
-
Складской учёт и инвентаризация
-
Учебные проекты и распечатка QR для документов
📎 Ссылки
-
GitHub: github.com/nigdanil/dotplus
-
Сайт: dot-plus.ru
-
Релизы: release-win
🔜 Что дальше?
-
Поддержка Linux и Docker-билдов
-
Экспорт в PDF и другие форматы
-
Улучшенная верстка и шаблоны генерации
Если вам интересны детали реализации PNG, логики CLI или хотите поддержку новых форматов — напишите в комментарии. Буду рад фидбэку!
ссылка на оригинал статьи https://habr.com/ru/articles/921570/
Добавить комментарий