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

Функциональность компонента подобна VisLabel,
но в отличии от последнего текст изменяется не с помощью скрипта, а в
соотвсетсвии с правилами описаными в свойстве messageRules.
Информация может быть статической или динамически изменяющейся.
Статическая информация задаётся при помощи свойства text,
при этом свойство messageRules должно быть
пустым. На рисунке статической меткой является название маршрута.
Для реализации динамической метки необходимо задать
правила изменения информации (messageRules) и
набор тегов (eqVarSet). В процессе работы проекта,
происходит периодическая проверка правил, которая может изменить текст и вид
метки в зависимости от значений тегов.
Кроме отображения информации, метка может осуществлять вызов панели
редактирования параметров проекта. Для этого необходимо в свойстве eqParameters
задать ссылку на набор параметров проекта (EqParameters).
Если контроллер не определён, то перед вызовом
панели проверяются права пользователя на редактирование параметров, иначе
права проверяются контроллером. Подробнее здесь.
При необходимости редактировать только один параметр, в свойстве parameterIndex
нужно указать индекс нужного параметра.
Родительский класс: VisBase
Объект данного класса должен быть частью (дочерним объектом) одного из
потомков VisContainer.
Свойства
объекта
Описание
свойств
text
Текст метки.
pos
Положение метки.
size
Размер метки.
font
Стиль шрифта.
textColor
Цвет текста.
backgroundColor
Цвет фона метки.
autoFillBackground
Закрашивать фон.
Значение параметра равное "true" говорит что фон метки должен быть закрашен,
инача фон прозрачный.
shadow
Вид рамки вокруг метки.
Plain - плоская
Raised - выпуклая
Sunken - утопленная
shape
Стиль рамки вокруг метки.
alignment
Выравнивание текста.
wordWrap
Перенос слов.
messageRules
Правила отображения текста.
Правила задаются в виде списка строк, содержащих шесть полей разделённых
двумя символами "вертикальная черта" - "||". Одна строка - одно правило.
Назначение параметров:
- индекс тега из набора тегов
- правило сравнения
- значение с которым сравниваем
- текс который необходимо вывести, если резулттат сравнения - истина
- цвет текста
- цвет фона
Правила позволяют сравнивать значение тега с константой и, в зависимости
от результата сравнения, изменять информацию и внешний вид метки.
Например правила для отображения состояния SECD:
0||=||0||Выключен||#4c4c4c||#CCCCCC
0||=||1||Ожидание разрешения запуска...||#4c4c4c||#00FF00
0||=||2||Готов к старту. Нажмите СТАРТ||#4c4c4c||#00FF00
0||=||3||Запуск...||#4c4c4c||#00FF00
0||=||4||Работает||#4c4c4c||#00FF00
0||=||5||Останов...||#4c4c4c||#00FF00
0||=||6||Приостановлен||#4c4c4c||#00FF00
0||>=||7||?||#4c4c4c||#00FF00
eqVarSet
Ссылка на набор тегов.
Данное свойство должно содержать ссылку на набор тегов (EqVarSet).
Набор тегов может использовать в процессе выполнения скрипта для получения
значений тегов. Доступ к значениям тегов осуществляется по индексу тега в
наборе. Например, для получения значения первого (индекс = 0) тега
необходимо использовать выражение obj.getVar(0).
eqParameters
Ссылка на набор параметров.
Данное свойство должно содержать ссылку на набор параметров (EqParameters).
Если набор параметров определён, то при клике на метке происходит вызов
редактора параметров.
parameterIndex
Индекс редактируемого параметра.
Свойство позволяет вызвать либо панель редактирования параметров (значение =
-1), либо "простой" редактор одного параметра с соответствующим индексом
(значение >= 0).
controller
Контроллер действий пользователя.
ctrlInfo
Дополнительная информация для контроллера.
Если контроллер является графическим, то формат следующий
индекс тега1/делитель1, индекс тега2/делитель2
Пример 0,1/10,3
альтернативная запись
[индекс начала, индекс конца];делитель1, делитель2
Пример [1..10];1,8,4
если указаны просто индексы, то делитель по умолчанию равен 1
Использование
контроллера
Без использования контроллера, при клике на метке, происходить проверка прав
на редактирование параметров и, если права есть, вызов соответствующего
редактора.
Если нам необходимо иметь возможность разрешить редактирование параметров
пользователям с другим типом прав (например, право на редактирование
маршрутов), или перед вызовом редактора задать вопрос, или после
редактирования параметров сохранить соответствующее сообщение, то необходимо
использовать один из контроллеров действий пользователя.
О контроллерах см. "Контроллер действий
пользователя".
Метка использует контроллер в режиме "проверить права - задать вопрос -
действие (вызвать редактор параметров) - сохранить сообщение".
Метка предоставляет контроллеру следующие данные:
- Тип сообщения.
- Объект сообщения.
- Текст сообщения.
- Вопрос для подтверждения вызова панели редактирования параметров.
Есть два варианта формирования этих данных - простой и расширенный.
Простой вариант.
Контроллеру передаются только объект сообщения (указывается в свойстве ctrlInfo
без использования символа ";") и, если произошло изменение параметра,
текст сообщения.
Тип сообщения производит и вопрос остаются не определёнными (на "усмотрение"
контроллера).
Расширенный вариант.
Если в свойстве ctrlInfo используется символ ";"
хотя бы один раз, то используется данный вариант.
Данные задаются в следующем порядке: "тип;объект;текст;вопрос".
Любое из полей может быть не определено, соответственно будут не определены
соответствующие данные.
Например, если мы хотим передать только вопрос, то значение свойства будет
";;;вопрос".
Внимание! Пробел является допустимым значением.
.