Генерация QR-code и GS1 DataMatrix средствами платформы 1С

Публикация № 1702001 28.07.22

Приемы и методы разработки - Инструментарий разработчика

QR GS1 DataMatrix

Только встроенный язык 1С, без COM-объектов, внешних компонент и т.п.

Общие требования

Платформа 1С от версии 8.3.10.2168 и выше.

Принцип работы

Этап 1. Вычисляется результирующая матрица (в виде буфера двоичных данных). 

Этап 2. Обходя в двойном цикле матрицу (по строкам, по колонкам) создаётся SVG-изображение. Стиль полученного штрих-кода вы можете задавать сами (цвета, картинки и т.д.). Примечание: мобильная платформа 1С поддерживает SVG-изображения начиная с версии 8.3.17.

 

Технические подробности

Для ускорения работы некоторые данные предварительно рассчитаны и сохранены в hex-, base64- или в json-строки.

Alfa – элементы поля Галуа GF(28): α0, α1, α2, … , α255 

Log – порядковые номера элементов поля Галуа

PP – Порождающие многочлены. Хранятся в виде массива коэффициентов при x, начиная со старшей степени и оканчивая свободным членом. При этом хранятся не номера элементов, а значения. Например, порождающий многочлен x7 + α87x6 + α229x5 + α146x4 + α149x3 + α238x2 + α105x + α21 хранятся как массив: 1, 127, 122, 154, 164, 11, 68, 117, что соответствует Alfa[0], Alfa[87], Alfa[229], Alfa[146], Alfa[149], Alfa[238], Alfa[105], Alfa[21].

InfoTable – таблица параметров версий символов. Для каждой версии (от 1 до 40) хранится:

  • Size – размер символа;
  • Max – максимальный объем данных в битах (для каждого уровня коррекции ошибок);
  • Blocks – количество блоков данных (для каждого уровня коррекции ошибок);
  • Corr – количество кодовых слов коррекции ошибок для одного блока (для каждого уровня коррекции ошибок);
  • Len – количество бит при указании длины данных (для каждого режима).

Bin – двоичные строки для чисел от 0 до 255.
MC – Информация о формате (для каждого уровня коррекции ошибок)
NumericTable – вспомогательная таблица для кодирования в числовой режим;
AlphanumericTable - вспомогательная таблица для кодирования в алфавитно-числовой режим;

Шаблоны символов хранятся в виде двоичных данных размером Ширина*Высота*2, т.е. на каждый элемент в шаблоне отводится два байта. Состав шаблона:

  • 51001 – черная клетка
  • 51002 – белая клетка
  • 51003 – черная клетка квадратов поиска
  • 51004 – белая клетка квадратов поиска
  • 50000-50014 – информация о формате
  • 0-49999 – информация о данных в виде: НомерБайта*10 + НомерБита. Байты нумеруются с единицы, биты нумеруются с нуля.

Например, шаблон символа версии 1 (21х21) занимает 882 байта и выглядит следующим образом:

 После наложения закодированных данных на шаблон получается матрица размером Ширина*Высота, т.е. на каждый элемент в матрице отводится 1 байт. Состав матрицы:

  • 0 - белая клетка
  • 1 - черная клетка
  • 2 - белая клетка квадрата поиска
  • 3 - черная клетка квадрата поиска

Например, результирующая матрица символа версии 1 (21х21) имеет размер 441 байт:

Используя данные из матрицы можно построить:

  1. SVG-изображение
  2. HTML-элемент Table
  3. Табличный документ и т.д.

 

Примечания

  1. По стандарту ISO 18004 нужно сформировать восемь вариантов штрихкодов (используя разные xor-маски) и среди них выбрать "лучший". Но в нашей обработке, учитывая небольшую скорость вычислений в 1С, формируется только один вариант. Номер xor-маски можно указать в параметре "Маска".
  2. Перед кодированием данных выбирается один режим, в котором данные могут быть закодированы (числовой, алфавитно-числовой, байтовый). Далее данные кодируются в этом режиме. Переключения из режима в режим (для уплотнения данных) не предусмотрены.

 

Скачать файлы

Наименование Файл Версия Размер
Генерация GS1 DataMatrix средствами платформы 1С:

.epf 14,63Kb
0
.epf 14,63Kb Скачать
Генерация QR-code средствами платформы 1С

.epf 885,48Kb
4
.epf 885,48Kb 4 Скачать

Специальные предложения

Автор запретил комментарии

См. также

SALE! 25%

Из Excel в 1С "одним нажатием": УПД, ТОРГ-12, отчеты комиссионеров (ОЗОН, Вайлдберриз), заказы, счета, прайсы, номенклатура Промо

Загрузка и выгрузка в Excel Обработка документов Оптовая торговля v8 v8::УФ Платформа 1C v8.2 1cv8.cf БУ УУ Платные (руб)

Универсальная обработка для загрузки документов из Excel в 1С. Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С. Вместе с номенклатурой может найти контрагента, номер и дату документа, штрих-коды, серии ГТД, страну и т.д. Распознает документы ЛЮБОЙ ФОРМЫ (УПД, ТОРГ-12, заказ, отчет комиссионера и т.д.). Не требует MS Office. Содержит модуль работы с электронной почтой. Для поиска таблиц используются методы эвристического поиска. Загружает только то, что нужно, т.е. пропускает повторы шапки таблицы, заголовки, промежуточные итоги, подписи и т.д. Работает во всех основных конфигурациях 1С8. При покупке лицензии вы получите 1 месяц бесплатной тех.поддержки.

9000 7650 руб.

09.11.2016    175189    648    839    

Загрузка данных из 1С МиниДеньги в 1С:Деньги 8, редакция 2.0

Обмен между базами 1C Файловые протоколы обмена (TXT, XML, DBF), FTP v8 Домашние учет и финансы УУ Абонемент ($m)

Обработка для первоначальной загрузки данных (справочников и операций) в настольную программу 1С:Деньги 8, редакция 2.0 из файлы резервной копии мобильной программы 1С Миниденьги.

2 стартмани

01.10.2015    18103    15    Claus32    5    

Редактор чеков ККМ Розница 2.0 - 2.3

Обработка документов Кассовые операции Розничная торговля v8 Розница Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд БУ НУ Абонемент ($m)

Обработка чеков ККМ списком (редактирование, удаление, ...). Переформирование ОРП, связь чеков с ОРП. Редактирование времени КС. Редактирование суммы и времени выемки.

1 стартмани

06.08.2015    64603    597    Dima_    83    

Загрузка из Excel в 1С:Розница

Обработка документов Обработка справочников Загрузка и выгрузка в Excel Склад и ТМЦ v8 Розница Россия УУ Абонемент ($m)

Универсальная загрузка Excel файлов в 1С:Розница 2.0

1 стартмани

27.05.2015    16609    110    KarinaSV    7    

Универсальная выгрузка/загрузка данных для отличающихся конфигураций (JSON, Такси+ОФ) Промо

Обмен между базами 1C Универсальные обработки v8 1cv8.cf Абонемент ($m)

Простой перенос через JSON данных между двумя базами 1С (документов, справочников, ПВХ, ПВР, счетов). Аналогична произвольной выгрузке в типовой "Выгрузка/загрузка XML", но может использоваться для отличающихся конфигураций. Подходит для любых пар баз с любым интерфейсом (управляемый + обычный). Без настроек. Не требует идентичности конфигураций и платформ. При переносе типы данных сопоставляются по наименованиям метаданных, объекты и ссылки по UID.

1 стартмани

22.10.2014    233543    4506    ekaruk    192    

Автоматическая установка себестоимости номенклатуры для конфигурации Розница 2.0 (2.1) +Бонус, исправляем ошибки при настройке расписания запуска для внешних обработок в Рознице 2.0

Прайсы Обработка документов Розничная торговля Ценообразование, анализ цен v8 Розница Розничная и сетевая торговля (FMCG) Россия УУ Абонемент ($m)

Обработка для автоматического создания документов Установка себестоимости, в случае если себестоимость не установлена на момент продажи. Помогает упростить установку себестоимости номенклатуры, если у вас в базе ведется учет по нескольким магазинам. Тестировалась на релизе 2.0.8.12 и 2.1.7.14. Подойдет для тех систем, где себестоимость номенклатуры одинакова для всех магазинов.

1 стартмани

31.03.2014    30214    75    sanches    15    

Выемка денежных средств из КассыККМ. Розница 2.0

Кассовые операции ККМ v8 Розница УУ Абонемент ($m)

Уставшим от отсутствия ВыемкиДС после закрытия кассовой смены посвящается. Подключаемая обработка. Управляемый интерфейс.

1 стартмани

12.12.2012    81878    530    StepByStep    40