GraphViz1С: внешняя компонента 1С Native API для построения графов

22.12.20

Разработка - Разработка внешних компонент

Внешняя компонента Native API для Windows с исходными кодами на C++ для построения графов посредством библиотеки GraphViz. Граф строится на основании текстового описания в формате dot. Реализован экспорт в большинство графических форматов. Поддерживаются версии платформы от 8.3.14 и выше до 8.3.18.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Бесплатно
GraphViz1С.epf
.epf 1,71Mb ver:2.44.2.66
143
143 Скачать бесплатно
GraphViz1C.zip
.zip 87,83Kb ver:2.44.2.66
98
98 Скачать бесплатно

Ранее на Инфостарте уже публиковались внешние компоненты для построения графов на основе библиотеки GraphViz. Предлагаемая реализация выгодно отличается от них тем, что исходный код внешней компоненты доступен и поддерживается 64х битная версия клиента 1С.

Вот пример описания графа в формате dot.

digraph {
  node[shape=none label=""]
  edge[penwidth=2 color="darkgreen"]
  Команда[image="img/team.png"]
  Заказчик[image="img/businessman.png"]
  Программист[image="img/programmer.png"]
  Фрилансер[image="img/freelance.png"]
  Секретарь[image="img/secretary.png"]
  Техник[image="img/technician.png"]
  Механик[image="img/mechanic.png"]
  Сервер[image="img/server.png"]
  Заказчик -> Команда -> Программист
  Команда -> Секретарь
  Команда -> Фрилансер
  Механик -> Сервер
  Техник -> Сервер
}

Внешняя компонента допускает использование картинок для визуализации вершин графа и поддерживает метки в формате HTML. Рекомендуется использовать для экспорта формат картинок SVG, также доступны графические форматы BPM, GIF, PNG, JPEG, TIFF и другие. Полный список поддерживаемых форматов можно получить вызвав соответствующий метод компоненты.

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

&НаКлиенте
Перем ИдентификаторКомпоненты, ВнешняяКомпонента;

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)
	ОбработкаОбъект = РеквизитФормыВЗначение("Объект");
	МакетКомпоненты = ОбработкаОбъект.ПолучитьМакет("GraphViz1C");
	АдресКомпоненты = ПоместитьВоВременноеХранилище(МакетКомпоненты, УникальныйИдентификатор);
КонецПроцедуры

&НаКлиенте
Процедура ПриОткрытии(Отказ)
	ИдентификаторКомпоненты = "_" + СтрЗаменить(Новый УникальныйИдентификатор, "-", "");
	ВыполнитьПодключениеВнешнейКомпоненты(Истина);
КонецПроцедуры

&НаКлиенте
Процедура ВыполнитьПодключениеВнешнейКомпоненты(ДопПараметры) Экспорт
	НачатьПодключениеВнешнейКомпоненты(
		Новый ОписаниеОповещения("ПодключенаВнешняяКомпонента", ЭтаФорма, ДопПараметры), 
		АдресКомпоненты, ИдентификаторКомпоненты, ТипВнешнейКомпоненты.Native);
КонецПроцедуры

&НаКлиенте
Процедура ПодключенаВнешняяКомпонента(Подключение, ДополнительныеПараметры) Экспорт
	Если Подключение Тогда
		ВнешняяКомпонента = Новый("AddIn." + ИдентификаторКомпоненты + ".GraphViz1C");
	ИначеЕсли ДополнительныеПараметры = Истина Тогда
		НачатьУстановкуВнешнейКомпоненты(
			Новый ОписаниеОповещения("ВыполнитьПодключениеВнешнейКомпоненты", ЭтаФорма, Ложь), 
			АдресКомпоненты);
	КонецЕсли;
КонецПроцедуры

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

&НаКлиенте
Процедура СформироватьКартинку(Команда)
	ДвоичныеДанные = Новый ДвоичныеДанные(ИмяФайла);
	ОписаниеОповещения = Новый ОписаниеОповещения("ПолученаКартинка", ЭтаФорма);
	ВнешняяКомпонента.НачатьВызовСформировать(ОписаниеОповещения, ДвоичныеДанные, "svg", "dot");
КонецПроцедуры

&НаКлиенте
Процедура ПолученаКартинка(РезультатВызова, ПараметрыВызова, ДополнительныеПараметры) Экспорт
	Если ТипЗнч(РезультатВызова) = Тип("ДвоичныеДанные") Тогда
		АдресКартинки = ПоместитьВоВременноеХранилище(РезультатВызова, УникальныйИдентификатор);
	ИначеЕсли ТипЗнч(РезультатВызова) = Тип("Строка") Тогда
		Сообщить("ОШИБКА: " + РезультатВызова);
	КонецЕсли;
КонецПроцедуры

К сожалению, библиотека GraphViz больше не поддерживает экспорт в формат Microsoft Visio. Прилагаемая внешняя обработка дополнительно содержит пример экспорта простого графа в приложение Microsoft Visio через вызов методов COM-объекта Visio.Application. Возможно вам придется доработать его самостоятельно. Можете взять его за основу.

Чтобы получить статическую сборку библиотеки GraphViz пришлось скорректировать её исходный код, преимущественно исправить файлы CMakeLists.txt. Также потребовалось статическая сборка библиотеки Expat для поддержки меток в формате HTML. Полностью вся сборка внешней компоненты, примера обработки и публикация релиза осуществляется автоматизированно посредством облачного сервиса AppVeyor. Вы можете посмотреть как это делается во всех подробностях.

Исходный код внешней компоненты выложен на GitHub: https://github.com/lintest/GraphViz1C

GraphViz

См. также

Разработка внешних компонент POS терминал Рабочее место Розничная торговля Программист Пользователь Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Управленческий учет Платные (руб)

Медиадисплей покупателя может отображать текущую покупку на кассовом месте, показывать видеорекламу, баннеры, во время простоя разворачивать рекламу на весь экран. Экран можно использовать в качестве графического меню-борда в кафе и видеовывески. В качестве устройства отображения можно использовать Android-планшеты, смарт-телевизоры с Android, мониторы или проекторы под управлением Windows или Linux-компьютера. Linux-версия успешно запускается на одноплатных компьютерах Raspberri Pi и Orange Pi. Настраивается ЛЮБОЙ ДИЗАЙН экрана при помощи встроенного графического редактора! Решение можно масштабировать от одного экрана до тысяч экранов с централизованным управлением.

18000 руб.

30.05.2017    53746    9    69    

46

Разработка внешних компонент Телефония, SIP Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    46861    122    66    

66

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    28299    138    100    

90

Разработка внешних компонент Программист Платформа 1С v8.3 Платформа 1C v8.2 Платные (руб)

Внешняя компонента, позволяющая посылать команды и получать ответы по GraphQL протоколу из 1С.Может быть использована при интеграции. В 1С работает на стороне "клиента".

4600 руб.

27.06.2023    3430    2    0    

4

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента в виде библиотеки (.dll файл), позволяющая посылать команды и получать ответы по протоколу WebSocket из 1С. Компонента работает только на стороне "клиента".

4440 руб.

22.06.2020    18175    18    33    

22

Разработка внешних компонент Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    36518    113    127    

114

Разработка внешних компонент Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    6874    starik-2005    32    

44
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SerVer1C 816 22.12.20 10:00 Сейчас в теме
Интересное решение. Было бы практично, если бы вы добавили возможность построение графа на основании 1с-ного дерева.
5. kandr 207 26.12.20 01:32 Сейчас в теме
(1) Мне потребовалась внешняя компонента, которая бы поддерживала 64-х битную версию платформы. В используемой нами конфигурации она применяется для построения отчёта по взаимосвязям между контрагентами, юридическими и физическими лицами. Полагаю, что имея такую компоненту любой программист 1С сможет самостоятельно сделать пример, который строит граф на основании метаданных конфигурации.
2. tormozit 7238 25.12.20 14:54 Сейчас в теме
При клике опознается объект графа?
4. kandr 207 26.12.20 01:23 Сейчас в теме
(2) Нет, сейчас на клик не реагирует, но поскольку это SVG в поле HTML документа, Вы легко сможете подключить свой обработчик нажатия. Вот пример как это делается: https://stackoverflow.com/a/10210322/109870
6. dabu-dabu 307 29.12.20 19:30 Сейчас в теме
(4) С помощью параметра URL можно отрабатывать клики. Например:
ДанныеГрафа = "
|digraph {
|
|node [shape=""box"",style=filled,fillcolor=pink]
|
|node [color=black,fontcolor=black,URL=""https://en.wikipedia.org/wiki/MediaWiki:Gadgets-definition""];
|edge [color=black];
|""MediaWiki:\nGadgets-definition""
|
|node [color=black,fontcolor=black,URL=""https://en.wikipedia.org/wiki/MediaWiki:Gadget-refToolbar.js""];
|edge [color=black];
|""MediaWiki:\nGadget-refToolbar.js"";
|
|""MediaWiki:\nGadgets-definition""->""MediaWiki:\nGadget-refToolbar.js"";
|}";

Далее можно обрабатывать необходимым образом в событии ПриНажатии поля HTML
7. tormozit 7238 29.12.20 19:48 Сейчас в теме
(4) Так я хочу не просто клики обрабатывать, а клики на опознанных объектах графа. Задача проверки попадания точки в полигон и линию - нудная. Поэтому я ожидаю получить ее решение в готовом виде. Хочу например событие "OnElementClick(ElementName)"
8. kandr 207 29.12.20 22:26 Сейчас в теме
(7) Объекты SVG ассоциированы с вершинами графа, задача легко решаема.

Для примера с картинками:

document.querySelectorAll('g.node').forEach(
    node => node.on click = () => alert(node.querySelector('title').innerHTML)
)


только уберите пробел между "on click", который зачем-то вставляет редактор комментариев
3. dabu-dabu 307 25.12.20 18:27 Сейчас в теме
9. alex_pavl 17.09.21 10:27 Сейчас в теме
При построении графа с картинками, картинки сначала отображаются, потом перерисовываются вопросительными знаками. В чем может быть причина?
Прикрепленные файлы:
10. kandr 207 17.09.21 10:48 Сейчас в теме
(9) Попробуйте закомментировать в модуле формы в обработке код процедуры ТекстHTMLДокументСформирован, которая подменяет базовый путь к картинкам
11. alex_pavl 17.09.21 11:13 Сейчас в теме
(10)
ТекстHTMLДокументСформирован

Это магия!! Все работает, благодарю. Инструмент бомба. Попутно вопрос. На тестовом сервере компонента работает идеально. На рабочем сервере пишет что компонента установлена, но не подключается, всегда Ложь. Связано это с правами или может быть другая причина?
12. kandr 207 17.09.21 11:43 Сейчас в теме
(11) На сервере может не запускаться потому, что не хватает какой-то графической библиотеки для работы GDI+. Если установить библиотеку необходимой версии, то заработает.
13. alex_pavl 17.09.21 15:06 Сейчас в теме
14. alex_pavl 02.10.21 19:59 Сейчас в теме
Подскажите, как заставить работать компоненту в веб клиенте?
15. kandr 207 02.10.21 21:38 Сейчас в теме
(14) сделайте вызов компоненты на стороне сервера, этого будет достаточно. На веб клиенте работать не будет.
Оставьте свое сообщение