Программное добавление элементов к графической схеме (управляемые формы)



Почему то фирма "1С" пошла особым путем и лишила нас, программистов, возможности полноценно работать с таким объектом, как графическая схема. Точнее, работать-то с ней можно, но как то однобоко…

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

Но для 8.3 там есть ошибка, когда для добавляемых элементов схемы пропадали связи со стрелками. Да и вообще подход у всех подобных публикаций одинаковый, запись в файл и анализ того, что в файле. Причем анализ достаточно сложный:

&НаСервере
//Получение текста шапки графической схемы
Функция ПолучитьТекстШапки(СтруктураГрафическойСхемы)

Возврат "{5,{{1,{3,3,{-10}},1" + "," +
Строка(СтруктураГрафическойСхемы.ШагСеткиПоГоризонтали) + "," +
Строка(СтруктураГрафическойСхемы.ШагСеткиПоВертикали) + ",3" +
",6,6,{""N"",10},7,{""N"",10},8,{""N"",10},9,{""N"",10},13,{""N"",0},16,{""N"",0}}}," +
Символы.ПС;

КонецФункции

Понятно, что при таком подходе, если завтра 1С изменит формат файла, то ничего работать не будет. Так как быть, если очень надо? Анализировать внутреннее представление графической схемы дело достаточно кропотливое.

Предлагаю другой подход к программной работе с графической схемой:

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

2) Для каждого из добавляемых элементов заведем отдельную графическую схему-эталон (макет графической схемы), в которой будет добавляемый элемент со стрелочками и прочим (см. третий скриншот). Эту схему тоже сериализуем, используя DOM в XML, выбираем все добавляемые элементы из схемы эталона.

3) Изменим в сериализованной схеме-эталоне внутренние идентификаторы добавляемых элементов на уникальные и изменим имя элемента.

4) Вставим схему эталон в схему источник, в блоке указываются все элементы. Тут простая работа со строками. Один XML файл вставляем в другой в определенное место.

5) Десериализуем полученную схему результат.

6) Профит! 🙂

Аналогично можно управлять положением, шириной и высотой элементов. Надо просто проанализировать XML-файл и изменить его.

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

Сайт: http://softonit.ru

13 Comments

  1. vasyak319

    Хорошая идея. А я в своё время плюнул и сделал свою рисовалку графических схем с блэджеком и шлюхами на основе табличного документа и его графических примитивов. Была надежда, что они хоть в 8.3 допилят объектную модель графической схемы (вроде даже обещали, причём не раз), да фигу там.

    Reply
  2. Diversus

    (1) Вообще, если честно, очень странно, что не дают использовать графическую схему программно. Ну вынесли бы конструкторы элементов графических схем, чтобы страшного случилось?

    Видимо программное изменение идет у 1С вразрез с чем-то (может с идеологией бизнес-процессов).

    Reply
  3. vasyak319

    (2) думаю, всё проще: у них эта задача честно стоит в плане. 20438-я по счёту, с 1243 важностью. И ведь не поспоришь — не самое это срочное, чего все ждут от одинэса.

    Reply
  4. Yashazz

    Блин. Гениальная и простая идея, на основе которой уже можно хоть свои процедуры кропать, типа столь нужных «ДобавитьЭлементСхемы», хоть редактор. Спасибо!

    Reply
  5. factor0
    РезультатПостроительDOM   = Новый ПостроительDOM;
    ЧтениеXML      = Новый ЧтениеXML;
    ЧтениеXML.УстановитьСтроку(ИсходнаяСхемаXML);
    РезультатДокументDOM   = РезультатПостроительDOM.Прочитать(ЧтениеXML);
    

    Тут что — то лишнее наверное ). За идею большое спасибо (скачал, изучил) — логично, не заморочено, и работает!

    Присвоение нового ID необязательно (вроде и так шуршит без нариканий).

    Reply
  6. Diversus

    (5) factor0, присвоение ID нужно. Потом вдруг захотите найти объект, а без уникального ID это сделать будет трудно 😉

    Reply
  7. djvu

    В общем, стырили мое решение далекого 2011 г.:

    http://infostart.ru/public/102902/

    Reply
  8. Diversus

    (7) djvu, полегче коллега. Обработку делал сам, искал в интернете что по проще, но ничего полезного не нашел. В ваше заглядывал краем глаза (или в какое-то другое?), но толкового там нет ничего, да еще и под обычные формы… Нужно было, что-то простое и универсальное, пришлось придумывать велосипед.

    Reply
  9. RainyAugust22

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

    Reply
  10. Diversus

    (9) API назвать это сложно. Просто идея как универсально работать с графической схемой.

    Reply
  11. CeHbKA

    Большое спасибо за разработку! Действительно — просто, удобно и работает!

    Вот только один момент — можете подсказать как примерно выглядит процедура удаления элемента со схемы?

    Я так понимаю, нужно заново десериализовать схему в XML, и при проходе элементов старого XML просто пропустить его при формировании нового?

    Reply
  12. Diversus

    (11) Верно

    Reply
  13. CeHbKA

    (12) чё-т не прокатывает… После удаления элемента, если потом добавить новый и начать его двигать, платформа падает 🙁

    UPD: хмм, очень странно ведёт себя платформа 8.3.10.2561… То падает, то нет. Попробовал выделить несколько элементов и удалить — упала. В другой раз дала. Чёрт-побери 🙁

    Reply

Leave a Comment

Ваш адрес email не будет опубликован. Обязательные поля помечены *