From OpenSCADAWiki
Jump to: navigation, search
Other languages:
English • ‎mRussian • ‎Українська
Name Version License Source Languages Author Icon
Main elements library of the user interface 2.2 GPLv2 vcaBase.db (SQL, GZip) > VCA.wlb_Main en, uk, ru Roman Savochenko
  Maxim Lysenko (2011-2012) — the page initial translation
LibMainGraphElements.png
Description
Provides the library of the main elements of the user interface of common and the industrial automation.
-

The library is created to provide main elements of the user interface and it contains graphic elements, often need when forming the user interface of the automation of technological and common processes. The library is built on the basis primitives of the widgets and the internal programming language JavaLikeCalc.

The element's names and their parameters are available in languages: English, Ukrainian and mRussian. Their source code wrote in the human-language independent mode with calls for the translations by the function tr() and the message's translation also allowed for English, Ukrainian and mRussian.

For connection the library to a project of the OpenSCADA station you can obtain the database file as:

  • supplied with a ready and proper package of the Linux distribution like to "openscada-libdb-vca", "openscada-LibDB.VCA";
  • directly taken for most actual one from the subversion repository and converted to the DB SQLite file in the way:
wget http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/vcaBase.sql
sqlite3 -init vcaBase.sql vcaBase.db .exit

This obtained file next you can place into the project directory of the station and create the database object for the DB module "SQLite", registering the database file in the configuration.

1 Widgets — graphical elements

Contains general-purpose widgets that are intended to be placed on the main frames. These main frames can also be frames outside of this concept of the signal objects of the root page "RootPgSo", but it should be taken in account that they often refer to and call certain control panels!


1.1 Analog show (anShow)

1.3 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element on Figure 1.1 is used to display the current value of the analog parameter and the regulator mode, if the parameter is a regulator. Also this element generates notifications of violations on the corresponding parameter settings. The element commonly uses and represents the representative structure of the "Analog signal" DAQ-template.

Fig.1.1. The element "Analog show" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer to create mnemonic schemes with displaying of values of the analog parameters and PID-regulators. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size, by scaling, and link to the data source parameter.

Using — runtime
In the runtime mode, in the main field of the element, there are displayed the parameter name, the regulator mode (only for the regulators) and the current value-variable of this parameter; which, depending on the presence of a violation, are displayed in the color style: labColorGood, labColorWarning, labColorAlarm; and in which value the image of the inquieted parameter may blink. At the hardware errors and non validity the data, the last value is grayed out and crossed out. In the tooltip the user may get the linked parameter description and its errors.

In the active mode of the element you can obtain the parameter passport clicking the right mouse button on the body of the widget. The passport will present all properties of the parameter. Pressing the left mouse button in the widget body will cause to appear in the panels area for control panel of the parameter, and the selection of this widget will be displayed with the blinking frame.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
pErr Parameter: error String Input link Parameter|err Code and text of the parameter error. It is used to generate alarm. The following error codes are processed:
  • 1,2 — failure, parameter is not valid, be shown in gray and cross out besides the case with redEVAL;
  • 3,4 — above and below the alarm limit, be shown in the styled color labColorAlarm;
  • 5,6 — above and below the warning limit, be shown in the styled color labColorWarning;
  • 10,11 — the user alarm codes of the statuses warning and alarm, be sown accordingly in the styled color labColorWarning and labColorAlarm.
pModeA Parameter: regulator mode: auto Boolean Input link Parameter|auto The large letter "A" is displayed on the left when the value checked.
pModeC Parameter: regulator mode: cascade Boolean Input link Parameter|casc The large letter "C" is displayed on the left when the value checked.
pName Parameter: name String Input link Parameter|NAME Short name of the parameter displayed over the value and inserted to the alarm messages.
pPrec Parameter: precision Integer Input link Parameter|prec Number signs after the dot, for positive values, and precision (signs in whole), for negative, to display the real end variable on the screen.
pVal Parameter: value Real Input link Parameter|var Engineeric real value of the parameter.
redEVAL Red parameter name in case of failure Boolean Constant By default, the color of the parameter's name for the "failure" state (EVAL value) is gray. But some critical for the process parameters must have the "failure" state displayed with the red parameter's name.
spName Speech name String Constant The parameter name for speech synthesis during the formation of alarm messages taking into account accents of words, pauses, etc. Empty value disables the speech notification!

1.2 Analog show 1 (anShow1); Analog show 1, short (anShow1s)

1.4 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element on Figure 1.2 is used to display the current value of the analog parameter and a short prefix of the measured value type. Also this element generates notifications of violations on the corresponding parameter settings. The element commonly uses and represents the representative structure of the "Analog signal" DAQ-template.

These two elements differ only in their initial horizontal size, that is, the second "Analog show 1, short" is a short version for very short cases and it is directly inherited from the first one.

Fig.1.2. The element "Analog show 1" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer to create mnemonic schemes with displaying of values of the analog parameters with a prefix and/or as an element of the static screen table. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size, by scaling, and link to the data source parameter.

Using — runtime
In the runtime mode, in the main field of the element, there are displayed the short prefix and the current value-variable of this parameter; which, depending on the presence of a violation, are displayed in the color style: labColorGood, labColorWarning, labColorAlarm; and in which value the image of the inquieted parameter may blink. At the hardware errors and non validity the data, the last value is grayed out and crossed out. In the tooltip the user may get the linked parameter description and its errors.

In the active mode of the element you can obtain the parameter passport clicking the right mouse button on the body of the widget. The passport will present all properties of the parameter. Pressing the left mouse button in the widget body will cause to appear in the panels area for control panel of the parameter, and the selection of this widget will be displayed with the blinking frame.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
pErr Parameter: error String Input link Parameter|err Code and text of the parameter error. It is used to generate alarm. The following error codes are processed:
  • 1,2 — failure, parameter is not valid, be shown in gray and cross out;
  • 3,4 — above and below the alarm limit, be shown in the styled color labColorAlarm;
  • 5,6 — above and below the warning limit, be shown in the styled color labColorWarning;
  • 10,11 — the user alarm codes of the statuses warning and alarm, be sown accordingly in the styled color labColorWarning and labColorAlarm.
pNAME Parameter: name String Input link Parameter|NAME Short name of the parameter inserted to the alarm messages.
prec Parameter: precision Integer Input link Parameter|prec Number signs after the dot, for positive values, and precision (signs in whole), for negative, to display the real end variable on the screen.
pVal Parameter: value Real Input link Parameter|var Engineeric real value of the parameter.
spName Speech name String Constant The parameter name for speech synthesis during the formation of alarm messages taking into account accents of words, pauses, etc. Empty value disables the speech notification!
pName Short name String Constant Short name-prefix value.
pNameSz Short name size Integer Constant Size of the short name-prefix in pixels, use the zero value to disable the field.


1.3 Text label (TextLab)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element on Figure 1.3 is used to display the dynamic text labels, which form on basis of the discrete signals. Also this element generates notifications of violations on the locally defined condition, the attribute ntf. The element commonly uses and represents the representative structure of DAQ-templates of the discrete block and the code state.

Fig.1.3. The element "Text label" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer to create mnemonic schemes with displaying of text labels and/or as an element of the static screen table. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size and link to the data source parameter.

Using — runtime
In the runtime mode, in the main field of the element, there are displayed the text label, what related to values of the discrete signals of the parameter and the attribute digStts configuration; where the background, depending to availability of a violation related to the attribute ntf condition, sets to the violation color; and to what the inquieted parameter may blink. At the hardware errors and non validity the data, the background shows in the gray color.

In the active mode of the element you can obtain the parameter passport clicking twice the left mouse button on the body of the widget. The passport will present all properties of the parameter. Pressing the left mouse button in the widget body will cause to appear in the panels area for control panel of the parameter, and the selection of this widget will be displayed with the blinking frame. The commands are duplicated in the context menu that appears when the right mouse button is pressed in the widget area.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
NAME Parameter: name String Input link Parameter|NAME Short name of the parameter to be inserted in the notification of violations and actions of the user-operator.
DESCR Parameter: description String Input link Parameter|DESCR Description or long name of the parameter to be inserted in the notification of violations and actions of the user-operator.
st_open Parameter: status-open Boolean Input link Parameter|st_open The state "Opened" of the parameter or the common state of the switch at missing the state signal "Closed".
st_close Parameter: status-close Boolean Input link Parameter|st_close The state "Closed" of the parameter.
st_text Parameter: status (text) String Input link Parameter|st_text Text of the parameter state, at the mode "Code state".
digStts Parameter: statuses String Input link Parameter|digStts Configuration of the parameter statuses with the structure {openedLabel}-{color};{closedLabel}-{color}, for the discrete block.
com Parameter: command Boolean Full link Parameter|com The command "Open" of the parameter or the common command of the switch at missing the command signal "Close".
close Parameter: close Boolean Full link Parameter|close The command "Close" of the parameter.
stop Parameter: stop Boolean Full link Parameter|stop The command "Stop" of the parameter.
com_text Parameter: command text (from digComs) String Full link Parameter|com_text Text of the parameter command, at the mode "Code state".
digComs Parameter: commands String Input link Parameter|digComs Configuration of the parameter commands with the structure {openLabel}-{color};{closeLabel}-{color}, for the discrete block, and {com1Label}-{color};{com2Label}-{color};...;{comNLabel}-{color}, for the code status.
ntf Notification "{st}:{modes}:{Speech text}" String Constant Configuration of the notification forming at the status (st) [0|1] and the notification modes-methods (modes), as a string of the digital methods, and by the speech, if pointed such method.


1.4 Image label (ImgLab)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element on Figure 1.4 is used to display the dynamic image labels, which form on basis of the discrete signals. Also this element generates notifications of violations on the locally defined condition, the attribute ntf. The element commonly uses and represents the representative structure of DAQ-templates of the discrete block and the code state.

  • Sponsored by: Vinnica Poultry Farm
Fig.1.4. The element "Image label" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer to create mnemonic schemes with displaying of image labels and/or as an element of the static screen table. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size and link to the data source parameter.

Using — runtime
In the runtime mode, in the main field of the element, there are displayed the image label, what related to values of the discrete signals of the parameter and the attribute imgs configuration; where the background, depending to availability of a violation related to the attribute ntf condition, sets to the violation color; and to what the inquieted parameter may blink. At the hardware errors and non validity the data, the background shows in the gray color.

In the active mode of the element you can obtain the parameter passport clicking twice the left mouse button on the body of the widget. The passport will present all properties of the parameter. Pressing the left mouse button in the widget body will cause to appear in the panels area for control panel of the parameter, and the selection of this widget will be displayed with the blinking frame. The commands are duplicated in the context menu that appears when the right mouse button is pressed in the widget area.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
NAME Parameter: name String Input link Parameter|NAME Short name of the parameter to be inserted in the notification of violations and actions of the user-operator.
DESCR Parameter: description String Input link Parameter|DESCR Description or long name of the parameter to be inserted in the notification of violations and actions of the user-operator.
st_open Parameter: status-open Boolean Input link Parameter|st_open The state "Opened" of the parameter or the common state of the switch at missing the state signal "Closed".
st_close Parameter: status-close Boolean Input link Parameter|st_close The state "Closed" of the parameter.
st_img Parameter: status "{img}:{bCol}:{blink}" String Input link Parameter|st_text Image of the parameter state, at the mode "Code state", where:
  • img — image name, see the image attributes;
  • bCol — background color;
  • blink — blink sign [0|1] of the background.
imgs Images, for "{openedImage}-{bCol}:{closedImage}-{bCol}:{EVAL}-{bCol}" String Constant Configuration of the parameter statuses with the structure {openedLabel}-{color};{closedLabel}-{color};{EVALLabel}-{color}, for the discrete block.
digStts Parameter: statuses String Input link Parameter|digStts Standard configuration of the parameter statuses with the structure {notUsed}-{openedColor};{notUsed}-{closedColor}', for the discrete block and missing of the attribute imgs.
com Parameter: command Boolean Full link Parameter|com The command "Open" of the parameter or the common command of the switch at missing the command signal "Close".
close Parameter: close Boolean Full link Parameter|close The command "Close" of the parameter.
stop Parameter: stop Boolean Full link Parameter|stop The command "Stop" of the parameter.
com_text Parameter: command text (from digComs) String Full link Parameter|com_text Text of the parameter command, at the mode "Code state".
digComs Parameter: commands String Input link Parameter|digComs Configuration of the parameter commands with the structure {openLabel}-{color};{closeLabel}-{color};{stopLabel}-{color}, for the discrete block, and {com1Label}-{color};{com2Label}-{color};...;{comNLabel}-{color}, for the code status.
ntf Notification "{st}:{modes}:{Speech text}" String Constant Configuration of the notification forming at the status (st) [0|1] and the notification modes-methods (modes), as a string of the digital methods, and by the speech, if pointed such method.


1.5 Alarms — active (alarmsAct)

1.4 GPLv2 * en, uk, ru Roman Savochenko

The element in Figure 1.5 serves to dynamically display the active violations in a tabular form and to highlight them in color and text. The violations are obtained from the buffer of current-active violations of OpenSCADA. In fact, the element implements the primitive "Protocol" functions for violations and extension opportunities.

Messages sorting is fixed by the rule "active + highest level + last" to the messages top, which can only be changed by editing the element's source code.

For detailed study of current violations, the element provides a function of increasing the height up or down in focus.

The element is created, and is usually used, in pair with the full-format frame of presenting the violations history, which is completed with most features of this element but also for the violations history.

The main user extension is the ability to define visible table fields from a list of options:

  • atm — time of the violation appearing;
  • qttm — time of the violation confirmation (quietation), for quieted violations;
  • lev — level of the violation;
  • type — type-name of the violation from the level lev and the attribute "types";
  • cat — category of the violation;
  • mess — full and unparsed text of the violation message;
  • prm — address of the DAQ-parameter of the data source;
  • dscr — description of the violation from the source DAQ-parameter;
  • dscrCust{N} — description of the user field N;
  • alrm — text of the violation;
  • cmnt — commentary of the violation.

At.png This element and its fields generally represent the structure of the violation message, which is described in detail in the Program manual.

As you can see from the list of possible table fields, this item supports confirmation (quietation), commenting, and user fields.

  • Sponsored by: Ustijancev Michael
  • Sponsored by, for appending the new user field "Type" on 0.2 HD[!]: INSERTEC LTDA
Fig.1.5. The element "Alarms — active" in the development and runtime modes (top to down).

Using — development
This widget can be used by the developer in creating mnemonic schemes with constant display of active violations or for their general display on the root page. To use it you need to add this widget to a mnemonic scheme or the root page, adjust for the horizontal, vertical size, configure vertical extension and adjust other properties, such as the list and the order in which the table fields are displayed.

If you want to exclude the validation function then you have to exclude the validation time "qttm" from the list and make the element inactive.

Using — runtime
In the runtime mode, a table is created to list the active violations, by defined fields, rules of sorting and highlighting; the contents of which are updated periodically and dynamically. When the table is selected and the focus is obtained, its height can be expanded to display more messages if this feature is enabled and the condition accordance is got for a certain number of violations.

The user is given the opportunity to confirm the violation, by changing the value of the confirmation time field or by using the control panel that pops up after selecting the element and the violation item.

The user can also comment on the violation by correcting appropriate field of the table.

Linking and configuring the attributes

Identifier Name Type Description
active Active Boolean Turn off if there disabled confirmation, focus gaining and editing in general — purely displaying.
hHdrVis Show header: horizontal Boolean
vHdrVis Show header: vertical Boolean
formDtTm Data and time format (%Y-%m-%d %H.%M.%S[.%MS,%US]) String Format of displaying the time of violation and confirmation.
expOnItems Expand on focus: items (<=0-disabled) Integer Maximum number of messages to trigger the element expansion, height increasing, at focus gaining.
expOnFocus Expand on focus: pixels (0-disabled,>-down,<-up) Integer Set to the desired value of the element extension, height increasing, at focus gaining.
colms Columns

List separated by ',' from the variants: atm, qttm, lev, type, cat, mess, prm, dscr, dscrCust{N}, alrm, cmnt.

String Determine in the desired sequence and the fields filling.
highLght Highlight rules

Rows in the form "{lev}[{slev}]{quitt}:{color}:{font}:{fontColor}".

Text Highlight rules, where:
  • lev — main level of the message [0...7];
  • slev — sub-level of the message [0...9], optional;
  • quitt — sign of the message confirmation (quietation) [0|1];
  • color — background color of the message row;
  • font — text font of the message row;
  • fontColor — text color of the message row.

Te example:

#<SnthHgl font="monospace">
# <rule expr="^#[^\n]*" color="gray" font_italic="1"/>
# <rule expr="^[0-9]*" color="blue">
#  <rule expr="[01]$" color="red"/>
# </rule>
# <rule expr="(?<=:).*" font_weight="1"/>
#</SnthHgl>
50:gray
40:red
150:yellow
colDscrCustNames Names list of the user fields, separated by ';' String (translate) At the support of user fields and their visibility, their names are given here.
types Types list at the level from 0, separated by ';' String (translate) Types-names of alarms at their level, typically "Debug;Info;Notice;Warning;Error;Critical;Alert;Emergency"
messCat Message category String Category of the processing alarm messages, typically it is empty for all alarms.


1.6 Object properties (objProps)

1.2 GPLv2 * en, uk, ru Roman Savochenko

The element on Figure 1.6 serves to display the properties of the data source in tabular form and to highlight them in color, as an object, and to allow the values of the recordable properties to be changed. This element also generates violation notifications according to the features of the object. The element generally uses and represents a representative structure "Complex objects" of the DAQ-templates.

  • Sponsored by: PAC HARTRON
Fig.1.6. The element "Object properties" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer in creating mnemonic schemes with consolidated rendering of the object as a whole and entity with properties. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size, by scaling, and link to the data source parameter at the DAQ-template "Complex objects".

Using — runtime
In the runtime mode, a table is displayed with properties in the rows where the first column is the property name and the second column is its value. Row can be backlit by an alarm color in case of violation of this property. Of particular importance is the title of the widget, which displays the name of the object background color which can become an emergency color in the presence of violations in the object.

The properties table is active and at selecting the property row, which means the writing, a field for setting the property value will appear below.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
objName Object: name String Input link Object|NAME The object name for the title.
objDescr Object: description Text Input link Object|DESCR The object description for tooltip to the title.
objErr Object: error String Input link Object|err The object error to form notifications and to highlight the title, the conception error codes are processed.
objItems Object: items Object Input link Object|items Descriptive object of the properties of the physical object, according to the concept.


1.7 Calendar (calendar)

1.0 GPLv2 * en, uk, ru Roman Savochenko

The element on Figure 1.7 is used to display the month of the calendar by week, which allows you to select the year, month and day, as well as switch to the current day.

  • Sponsored by: SVItoVYR LTD
Fig.1.7. The element "Calendar" in the development and runtime modes (left to right).

Using — development
This widget can be used by the developer to create mnemonic schemes with displaying the calendar. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size, by scaling, and use the attribute "selTime" of this widget to obtain and to set the date.

Using — runtime
In the runtime mode, the year, month, and day are displayed according to the "selTime" attribute.

The user can select the year and month from the list, as well as the day in the represented weeks. An appropriate button is provided for a quick return to the current day.

Linking and configuring the attributes

Identifier Name Type Description
selTime Selected time Integer The calendar in seconds from the UNIX-epoch.


1.8 Weather (weather)

1.0 GPLv2 * en, uk Roman Savochenko

The element on Figure 1.8 is used to display weather data from parameters on the DAQ-template "Weather".

Fig.1.8. The element "Weather" in the development and runtime modes (left to right).

Using — development
This widget can be used the developer to create mnemonic schemes with displaying the weather. To use it you need to add this widget to a mnemonic scheme, adjust for the horizontal, vertical size, by scaling, and link to the data source parameter at the DAQ-template "Weather".

Using — runtime
In the runtime mode, the current weather is displayed in the top and forecast displayed in the bottom with details on the images' tooltip.

At.png Images for some weather conditions can be missed yet due to the images are still appended!

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
current Weather: Current Object Input link Parameter|current The object with current data.
forecast Weather: Forecast Object Input link Parameter|forecast The object with forecast data.


2 Root page (SO) (RootPgSo)

2.7 GPLv2 * en, uk, ru Roman Savochenko 1000 ms

The element-frame, shown in Figure 2, serves as the basis for the user interfaces creating, initially for control the technological processes, grounded on the signal objects (SO).

The root page contains four areas:

  • signal objects area of the buttons-indicators (top);
  • navigation area by types of view (right-top);
  • container of the main frames of the user interface (in the centr);
  • container of the control panels (right-bottom).

Signal objects area of the buttons-indicators provides information on the presence of violations in the signal object and for switching between them.

To show the signal objects selection the background color is used, by the styles: backColorButton and backColorButtonSel. And the violations are displayed in the color of the text according to the styles: labColorGood, labColorWarning, labColorAlarm; and in which value the text of the inquieted signal object may blink.

Buttons are currently generated dynamically by copying the first and only, according to the virtual pages of the signal objects in the project tree, with the serial digital identification from 1 (one). The limitation on the number of buttons or signal objects is only the total length of the names of the signal objects that can be placed in two rows of these buttons. That is, for short names we can get up to near 100 signal objects. If the signal object is one, even this single base button is hidden.

Navigation area by types of view — indication of the choice and selection of the type of view, such as: "Mnemonic schemes", "Graph groups", "Contour groups", "Documents" and more; and the listing buttons or the direct selection combobox of the frames into the signal object.

The buttons area of the types of view is dynamic, in the sense of occupying the space of the missing ones, and the meaning of the types of view themselves are configured to different from the default value, i.e. there are two main types of view (view1 and view2), three auxiliary (view3, view4 and view5), as well as one common to the whole interface (view6).

Below are also the buttons of quietation those appear in the event of violations, and at the top is a customizable logo.

Container of the main frames of the user interface — the area of the container for inclusion in it of the basic frames by their choice of buttons of types of view or change of the signal object.

The generic table of active violations — contains coloured rows of actual alarms sorted by their importance with the more important on the top. The widget disabled initially.

Container of the control panels — container area to include control panels of various objects in the container area of the main frames, for example — panel of the parameter, document, graph and more.

Under the control panels container placed a button to start the demo mode — mode in which performed periodic switching for representative frames, changing regimes and other operations by a scenario.

  • Sponsored in the dynamization by: Vinnica Poultry Farm
Fig.2a. The "Root page (SO)" frame in the development mode.

Using — development
This widget can be used only in the root page mode that should be placed in the project's tree as an element "so". Additionally, around the main page should be made following tree hierarchy:

/control/* — logical container, contains a variety of control panels;
/so/ — this frame as a container, contains of logical containers of the signal objects:
{n}/ — logical container of the signal object n (1...), contains logical containers and templates of the types of view:
[view1|mn]/* — the type of view 1 (typically and early it is the mnemonic schemes), contains a lot of pages of the end frames;
[view2|ggraph]/* — the type of view 2 (typically and early it is a template of the graphics group), contains a lot of pages of the end frames;
[view3|gcadr]/* — the type of view 3 (typically and early it is a template of the contours group), contains a lot of pages of the end frames;
[view4|gview]/* — the type of view 4 (typically and early it is a template of the overview frames panel), contains a lot of pages of the end frames;
[view5|doc]/* — the type of view 5 (typically and early it is a logical container of the documents), contains a lot of pages of the end frames;
greg/* — the specific page template of the PID-regulator configuration, contains a lot of pages of the end PID-regulators configuration, statically connected and which are call only by the "PID" button of the element cadre.
[view6|rg]/ — logical container of the global type of view 6 (typically and early it is the result graphics — common graphs for the entire interface):
[view6|rg]/* — the type of view 6 (typically and early it is a template of the result graphics), contains a lot of pages of the end frames.

At.png Identifiers of the pages of the types of view, specified as [view1|mn], must be specified in the tree either in the new scheme "view1" or in the old scheme "mn". Mixing is not supported and the view items must not be empty, that is contain at least one active page!

As the text of the signal object buttons, there are used name of the logical container with the corresponding n identifier. The description of this container also takes the text of the tooltip to this button if it is not empty. Description of the container also taken into tooltip for this button, if it is not empty.

All further adjustments and edits around this frame must be made for its copy-link in the project tree, and it is strongly not recommended to edit it in the library, otherwise you will lose the ability to update the library or these changes when updating it!

The text and the tooltip of the buttons of the types of view are directly changed in the corresponding properties of these widgets. The fast keys of the type of view are taken from the toolbar brackets, such as "Graphs (CtrlAlt+G)", and processed accordingly. To change the image of the type of view, it is enough to override the icon of the corresponding view, such as "view1", by loading the image with the appropriate name in the project Mime-data.

To enable the generic table of active violations just set 1 (one) in the frame links configuration for "alarms > en".

To enable and configure the returning to some non privilege user after some time of the inactivity just set {minutes)-{user} in the frame links configuration for "defUser".

You can change the image of the logo in the same way as the image of the type of view, that is, upload a new image called "logo" to the project's Mime-data, and then adjust the geometry of the logo widget to the desired proportions. You can move the image widget to the left by moving the signal object button to the right by the size of the logo. If you do not need the logo at all then to nullify the widget width, but do not remove it!

Potentially, you can also move the navigation bar and the control panel container to the left by moving the main frame container, and maybe the signal object button, to the right.

If necessary, the root page can be appended with additional elements that do not require special processing, that is, changes to the initial procedure of the frame, that is no longer using but editing. At.png It should be noted here that reducing the size of the containers will lead to the appearance of scrollbars and-or will require adjusting the frames of placement in the container but this may not be necessary given the extension of the container to unused button rows of the signal objects.

Using — runtime
When starting the frame in the runtime mode, there are first constructed the buttons of the signal objects, which are formed in two rows, after which the container of the main frames expands up for one row if there is enough one, or for two if the signal object is one. Next, there are formed buttons of the types of view, present of which are activated and expanded to fill the space of the missing ones.

After the dynamic forming, the frame periodically controls the frame change in the main frame container, which is displayed by the corresponding background color in a button of the signal object and the type of view to which the frame belongs. Between the listing buttons, information about the total number of frames and the current position is updated, and the buttons themselves are activated according to the possibility of listing in the current frame position. For the combobox of direct frames selection from list, respectively, the current list of frames is formed and the name of the current one is set. It also monitors the status of violation-notification of the signal objects, which is accordingly displayed by the text color of the buttons of the signal object and its flashing, as well as the quietation buttons are activated or deactivated.

At.png The frame supports now of working with very big "Periodic processing" value or disabling the periodic processing in whole (the value -2) and that value also propagated to the child pages and widgets if they want such behaviour (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Changing of the frame in the control panel container are not tracked and their are generally called from the main frame interface, unless it is cleared by changing the main frame by opening the panel-terminator.

From the basic actions, the frame allows the user to select the signal object, the type of view and the corresponding frame. By pressing the button of the signal object, the type of view, directly selecting in the combobox or listing; resulting in a call to the corresponding frame in the main frame container. From the ancillary actions, the user can quiet the violation-notification and start the Demo-mode, if one provided. The default frame setting involves servicing a number of hotkeys, such as CtrlAlt+[1...0] to call the signal objects 1 to 10, and CtrlAlt+[MGCVDR] to call appropriate types of view.

Fig.2b. The "Root page (SO)" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Description
alarms > en (config) Alarms > Enabled Boolean The generic table of active violations enabling
defUser (config) Default to return, {minutes)-{user} String Enabling and configuring the returning to some non privilege user after some time of the inactivity by the string {minutes)-{user}.
demoPlayProc Procedure of the Demo play Text A procedure on the JavaLikeCalc language to play some demo. Enables the Demo-mode button in the runtime mode. To an example of such procedure see the demo-projects AGLKS and Boiler!
The visualizer specific attributes common for both UI.Vision (more) and UI.WebVision (more)
keepAspectRatio Keep aspect ratio on scale Boolean Keep aspect ratio of the pages on scale.
stBarNoShow Do not show the status bar Boolean Hide the status bar of the main window.
The visualizer specific attributes for UI.Vision (more)
runWin Run window Integer numbers selection Setting the mode of the main window execution:
  • "Original size (0)".
  • "Maximize (1)".
  • "Full screen (2)".
statLine Status line items Text Text field with description of the status line items.
winPosCntrSave Windows position control and save Boolean Enabling the windows position control and save.
Main procedures of the notification mechanism
notify0 Notification: type 0 (Light) Text
notify1 Notification: type 1 (Buzzer) Text
notify2 Notification: type 2 (TextSpeech) Text

3 Main frames

Contains elements-frames of the template and end types, as well as elements-widgets and panels from which they are built and used. These frames are intended to be placed in the project tree of the pages, built on the concept of the signal objects of the root page "RootPgSo". However, they may be located as separate entities or as part of your own concept of the page management, but it should be take in account that frames often refer and call certain control panels of the common usage and related elements!


3.1 Graphics group (grpGraph); Graphics group 10 (grpGraph10)

1.6 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-frame shown in Figure 3.1 is provided for simultaneous observation of trends and control the parameters in the signal object, includes both instances of the widget "Graphics group element" of each parameter (up to 8 or 10) and the primitive "Diagram" to monitor the parameters' trends and browsing history, and also the scroll bar for fast navigation on allowed history of selected parameters for show. The variant in 10 trends is inherited from the base variant in 8 trends and you can create your own variants by inherit the base and append more graphics group elements.

Fig.3.1a. The "Graphics group" frame in the development mode.

Using — development
The frame is designed to perform the role of page-template, and should therefore be placed directly in the project's tree. In the project-template "Signal groups", for each signal object, this frame is included in the role of a template that allows you to create on its basis a set of pages of the graphics group. To each frame can be connected up to eight-ten parameters, setting the links. Trends, for which there are not set the links, will be hidden at runtime or allowed for user's selection at case of presence the list of the parameters to select in the attribute "Select: parameters accessible to select" (the list format described in the parameters selection dialog).

The default trend depth in the past is set at 10 minutes — for current operational control, which can be changed directly by editing the corresponding field of the diagram widget, for example, for the project template page, to spread to all end pages.

Using — runtime
In the runtime mode, the trends, for which links have been set, are displayed. Control of the parameters from the graphics group element, described in detail in the section of the "Graphics group element (ElViewGraph)" widget. Additionally you can control the display properties of graphs, for what, together this page, there automatically opens the graph control panel or you have to click the left mouse button in the graph area.

At.png The frame supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Fig.3.1b. The "Graphics group" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
name Name String Constant Group name
allowSelLst Select: parameters accessible to select Text No Place here the parameters for selection by the user in a list of the DAQ-paths to them (for more details see the "Graph parameter selection" dialog):
/LogicLev/proc/prm_CPU/prm_load
/LogicLev/proc/prm_MEM/prm_use
/LogicLev/proc/prm_CPU/prm_T 
perUserSel Select: save the selection per user Boolean No Set to save the user selection separately
Element {n} from 1 to 8(10)
el{n} List of the linking parameters corresponds to the list of the "Graphics group element (ElViewGraph)" widget


3.1.1 Graphics group element (ElViewGraph)

1.5 GPLv2 * en, uk, ru Roman Savochenko 2000 ms

The element-widget shown in Figure 3.1.1 is provided to create graphics groups. The widget contains information about parameter, the regulator mode, if the parameter is such, the units of analog parameter, as well as the color corresponding to the parameter's trend. The widget commonly uses and represents the representative structure of the DAQ-templates "Analog signal" and "Discrete block".

Fig.3.1.1a. The "Graphics group element" widget in the development mode.

Using — development
Though this widget is not intended for independent use in isolation from the graphics groups, it can be used, for example, placing it to the mnemonic scheme and linking with the data source parameter.

Using — runtime
In the runtime mode, in the main field of the element, there are displayed the parameter name, the regulator mode (only for the regulators), the current value-variable and the unit of this parameter; which, depending on the presence of a violation, are displayed in the color style: labColorGood, labColorWarning, labColorAlarm. At the hardware errors and non validity the data, the last value is greyed out.

Except the available visual data, a number of control elements are provided:

  • "Selection" — at pressing the left mouse button in the widget area, in the right side will appear the control panel, and the widget selection will be displayed by the border flashing.
  • "Hide/Show" — double-clicking in the widget area toggles the show-hiding of the item's graph.
  • "Context menu functions" — a number of functions are provided through the context menu:
    • "Passport" — getting the passport of the parameter, which will present all it properties.
    • "Hide/Show" — toggling the display or hiding of a graph of this element, similar to a double click.
    • "Show one" — single graph display of the selected parameter in its native scale by hiding the rest of the items in the group.
    • "Show all" — display all parameter graphs in the group.
    • "Calculating" — calling the calculating dialog above the visible data of the selected parameter.
    • "Select" — calling the selection dialog of the parameter from the list of ones available for selection — the attribute "Select: parameters accessible to select" of the owner cadre. This item is only available if a selection list is available. From the dialog the user can clear the parameter also and what for statically preset parameters means of return to the static parameter.

The widget saves of a user selected parameter in the session table of the project and loads the parameter at next run, include the trend color which default value typically takes from a style.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Fig.3.1.1b. The "Graphics group element" widget in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
name Name String Input link Parameter|NAME Parameter name-code, to display in the name field.
dscr Description Text Input link Parameter|DESCR Parameter description, to place in the tooltip and statusbar.
addr Address Address Input link Parameter|var Address to the parameter attribute for the trend building.
color Graphic color String No Working color of the trend
colorDef Default color from the style String No Default color of the trend on the cadre level
Analog parameters
ed Dimension String Input link Parameter|ed
prec Precision Integer Input link Parameter|prec Number signs after the dot, for positive values, and precision (signs in whole), for negative, to display the real end variable on the screen.
log Logarithmic scale Boolean Input link Parameter|log
max Maximum Real Input link Parameter|max Upper limit value of the parameter.
min Minimum Real Input link Parameter|min Minimum limit values of the parameter.
aMax Border up alarm Real Input link Parameter|aMax
aMin Border down alarm Real Input link Parameter|aMin
wMax Border up warning Real Input link Parameter|wMax
wMin Border down warning Real Input link Parameter|wMin
pModeA Regulator mode: auto Boolean Input link Parameter|auto The regulator mode "Automatic".
pModeC Regulator mode: cascade Boolean Input link Parameter|casc The regulator mode "Cascade".
Discrete parameters
digComs Digital: commands String Constant Names and colors of the buttons of the commands are in the format {On}[-color]:{Off}[-color][:{Stop}[-color]]. Default colors are: green, red and yellow.
digStts Digital: states String Constant Names and colors of the labels of the states are in the format {On}[-color]:{Off}[-color]. Default colors are: green and red.
digRevers Digital: reversion Boolean Constant Discrete signal reverse.


3.1.2 Graph parameter selection (graphSelPrm)

1.5 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element, shown in Figure 3.1.2, implements a dialog of selection the data source, often the archive ones, for the trend formation in the "Graphics group" frame. Selection is provided from the list, specified in the attribute "Select: parameters accessible to select (allowSelLst)" of the frame-initiator. For the selected source you can specify the name, scale, logarithmic scale, dimension and the color of the trend.

In the "Select: parameters accessible to select (allowSelLst)" attribute the data sources should be placed in the following way:

  • {DAQ_Arh_addr}[:Name[:min:max[:dim]], where:
    • "DAQ_Arh_addr" — address of the parameter, for the group linking, or address of the attribute with data from the "Data acquisition (DAQ)" subsystem, as well as the address of the values' archive, for example:
      • /LogicLev/gen/prm_F3 — address of the "F3" parameter ;
      • /DAQ/System/AutoDA/prm_CPULoad/load — address of the "load" attribute of the "CPULoad" parameter;
      • /Archive/va_LC21_1_var — address of the "LC21_1_var" archive.
    • "Name" — name of the source to display. At the group linking the name will be taken from the "NAME" attribute.
    • "min", "max" — display scale. At group linking the scale will be taken from the "min" and "max" attributes, respectively. In the case of the scale absence (min >= max) the auto-scale will be enabled.
    • "dim" — dimension (measuring unit) of the parameter to display. At the group linking it will be taken from the "ed" attribute.
  • <varhs> — template of the group selection, if you specify it all available archives in the system will be included into the selection list.

Examples of the "Select: parameters accessible to select (allowSelLst)" attribute's content:

/System/AutoDA/prm_CPULoad/load:CPU Load:0:100:%
/LogicLev/gen/prm_F3
<varhs>
Fig.3.1.2. The "Graph parameter selection" frame in the development and runtime mode.

Using — development
This frame should be placed to the panels' logical container of the project tree. The "Select: parameters accessible to select (allowSelLst)" attribute must be defined to a list of sources according to the rules described above in the "Graphics groups", which should provide the selection of the sources by the user. As a result, the "Select" item will appear in the context menu of the Graphics group element.

Using — runtime
Calling the dialogue is made by the "Select" item of the Graphics group element context menu. The dialogue provides the user to the possibility of selection the data source from the list, as well as an indication of its basic parameters: name, scale, logarithmic scale, dimension and the color of the trend, which you also can select typical/styled one by clearing. When you accept the dialogue the selected parameters are applied to the graphics group element chart, replacing the links. The "<Clear>" item selection and applying causes to clearing all the links and the graph's item. Into a text field under the list you can rapidly find any needed parameter.


3.1.3 Graph parameter calculation (graphCalc)

1.0 GPLv2 * en, uk, ru Roman Savochenko

The element, shown in Figure 3.1.3, implements a dialog of user calculation of the selected graph parameter for the graphically visible data. The user is given an option to select calculations from the built-in library, the privileged user ("root" or in the "ITW" group) has the opportunity to edit or write their own calculation procedure.

In general, the built-in library currently contains the following functions of the user calculation:

  • Sum, at hour.
  • Average and range.
Fig.3.1.3. The "Graph parameter calculation" frame in the development and runtime mode.

Using — development
This frame should be placed to the panels' logical container of the project tree.

Using — runtime
Calling the dialogue is made by the "Calculation" item of the Graphics group element context menu. The dialog gives the user the choice of the function of calculation the visible data of the selected parameter and the ability to edit-write their own function, for the privileged user. The calculation result is located in the corresponding text box.


3.2 Contours group (grpCadr)

1.3 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-frame, shown in Figure 3.2, provides for simultaneous monitoring and control of contours of several parameters, up to eight, includes both instances of the widget "Element cadre for each contour, and the primitive "Diagram" to monitor the trends of the contours and viewing history.

Fig.3.2a. The "Contours group" frame in the development mode.

Using — development
The frame is designed to perform the role of page-template, and should therefore be placed directly in the project's tree. In the project-template "Signal groups", for the first signal object, this frame is included in the role of a template that allows you to create on its basis a set of pages of the contours group. To each frame can be connected up to eight parameters, setting the links. Contours and trends, for which there are not set the links, will be hidden at runtime.

The default trend depth in the past is set at 10 minutes — for current operational control, which can be changed directly by editing the corresponding field of the diagram widget, for example, for the project template page, to spread to all end pages.

Using — runtime
In the runtime mode, the contours and trends, for which links have been set, are displayed. Control of the parameters by contours, described in detail in the section of the "Element cadre" panel. In addition to this you can control the trends display properties, which requires the left mouse button to click in the trend's area and by means of appeared trend's control panel to make the necessary actions.

At.png The frame supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Fig.3.2b. The "Contours group" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
grpName Group name String Constant Group's name
Element {n} from 1 to 8.
el{n} The list of the linking parameters corresponds to the "Element cadre (ElCadr)" panel


3.3 Group of overview frames (ViewCadr)

1.1 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-frame shown in Figure 3.3 is used to display the current parameter trends in individual frames-widgets with up to 24 units (6x4) for which scaling is supported depending on their configured number. The frames-widgets of the parameter trends are implemented with the satellite widget "Frame of the group of overview".

Fig.3.3a. The "Group of overview frames" frame in the development mode.

Using — development
The frame is designed to perform the role of page-template, and should therefore be placed directly in the project's tree. In the project-template "Signal groups", for the first signal object, this frame is included in the role of a template that allows you to create on its basis a set of pages of the group of overview. Frames-widgets, for which there are not set the links, will be hidden at runtime and will be performed the proportional scaling to missing full rows and columns to fill the entire frame.

Using — runtime
In the runtime mode, the frames-widgets, for which links have been set, are displayed. Control of the parameters from the frames-widgets, described in detail in the section of the "Frame of the group of overview" widget.

Fig.3.3b. The "Group of overview frames" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
name Name String Constant Frame's name
Frame-widget {r}_{c}, where {r} — rows from 1 to 4 and {c} - columns from 1 to 6.
el{r}_{c} The list of linked parameters corresponds to ones of the "Frame of the group of overview (ElViewCadr)" widget


3.3.1 Frame of the group of overview (ElViewCadr)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-widget, shown in Figure 3.3.1, serves as the basis for the group of overview frames and is not usually used independently. The widget displays the text information about parameter in the form of the name and value, and a trend of the parameter for small period of time (2 minutes) to observe the current trend of the parameter with auto-scaling on the value scale. The widget commonly uses and represents the representative structure of the DAQ-template "Analog signal".

Fig.3.3.1. The "Frame of the group of overview" widget in the development and runtime modes (left to right).

Using — development
Though this widget is not intended for independent use, in isolation from the group of overview frames, it can be still used, for example, placing it to the mnemonic scheme and linking with the data source parameter.

Using — runtime
In the runtime mode, the main field of the element displays the parameter name, the current value-variable and the trend of the parameter; which are always displayed in the style color: labColorGood.

In the active mode of the element you can obtain the parameter passport clicking the right mouse button on the body of the widget. The passport will present all properties of the parameter. Pressing the left mouse button in the widget body will cause to appear in the panels area for control panel of the parameter, and the selection of this widget will be displayed with the blinking frame.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
name Name String Input link Parameter|NAME Parameter name (code) for display in the name's field.
addr Address Address Input link Parameter|var Address to the value attribute of the parameter to construct the trend.
var Variable Real Input link Parameter|var Directly the parameter value to be displayed in the value field.


3.4 Result graphics (ResultGraph)

1.1 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-frame shown in Figure 3.4 is used to display a group of the current parameter trends (up to 5) in individual frames-widgets with up to 16 units (4x4) for which scaling is supported depending on their configured number. The frames-widgets of the parameter trends are implemented with the satellite widget "Frame of the result graphics".

Summary the total number of displayed graphs in one frame reaches 80, and it is intended to form a separate type of view that is used outside the signal objects — globally for the entire visualization project.

At.png The frame doesn't support any control.

Fig.3.4a. The "Result graphics" frame in the development mode.

Using — development
The frame is designed to perform the role of page-template, and should therefore be placed directly in the project's tree. In the project-template "Signal groups", at the root page level it has a special virtual page "Result graphics" with the result graphics template, that allows you to create on its basis a set of pages of the result graphics. Frames-widgets, for which there are not set any links, will be hidden at runtime and will be performed the proportional scaling to missing full rows and columns to fill the entire frame.

Using — runtime
In the runtime mode, the frames-widgets, for which links have been set, are displayed.

Fig.3.4b. The "Result graphics" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
grpName Group name String Constant Group name
Frame-widget {n} from 1 to 16.
el{n} The list of linking parameters corresponds to the "Frame of the result graphics (ResultGraphEl)" widget.


3.4.1 Frame of the result graphics (ResultGraphEl)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element-widget, shown in Figure 3.4.1, serves as the basis for the result graphics and is not usually used independently. The widget displays the name of the group and up to five trends, with their text labels, over a fixed period of time (10 minutes) to observe the current trend of the parameters. The widget commonly uses and represents the representative structure of the DAQ-template "Analog signal".

Fig.3.4.1. The "Frame of the result graphics" widget in the development and runtime modes (left to right).

Using — development
Though this widget is not intended for independent use, in isolation from the result graphics, it can be still used, for example, placing it to the mnemonic scheme and linking with the data source parameter.

Using — runtime
In the runtime mode, the main element field displays the group header, headers and trends of the parameters in the configuration-defined or styled colors.

At.png The widget supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent widget/page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
title Title String Constant Displays at the top of the graphs, in the absence the graphs field expands up.
Parameter {n} from 1 to 5.
p{n}_addr Parameter{n}: address Address Input link Parameter {n}|var Address to the parameter attribute for plotting the graph {n}.
p{n}_clr Parameter{n}: color Color From style labColorGrph{n}
p{n}_max Parameter{n}: maximum Real Input link Parameter {n}|max Upper limit of the trend.
p{n}_min Parameter{n}: minimum Real Input link Parameter {n}|min Lower limit of the trend.
p{n}_name Parameter{n}: name String Input link Parameter {n}|NAME Short name of the parameter to display in the field on the left.


3.5 Regulator's control panel (cntrRegul)

1.2 GPLv2 * en, uk, ru Roman Savochenko

Element-frame, shown in Figure 3.5, is used for adjustment of PID-regulator, includes information about the parameter-regulator, fields of the regulator's settings and the "Diagram" primitive, to monitor the trends of the regulator and browsing history. The frame commonly uses and represents the representative structure of the DAQ-template for the analog and pulse PID-regulators.

Fig.3.5a. The "Regulator's control panel" frame in the development mode.

Using — Development
This frame can be used as a panel, called from the control of panel of the parameters, as well as a template-page. The frame should be placed directly in the project's tree, namely to the panels container, where the dynamic linking will be performed to the regulator parameter. To create a static list of contours of the regulators' configuration, with the possibility of listing in it, you must place them in the container "greg" of the regulators' contours of each signal object and statically link them with the corresponding parameter, and to ensure equality of the panel's ID and the linked parameter.

The default trend depth in the past is set at 20 minutes — for current operational control, which can be changed directly by editing the corresponding field of the diagram widget.

Using — runtime
In the runtime mode, you can see:

  • name of the regulator parameter;
  • field with the regulator properties in the composition: identifier, name, description, measuring unit, set-point, variable output, scale and mode;
  • coefficients of the regulator configuration: Gain, Ci, Ti, Cd, Td, TdLg, Zin, H1, H2, C1, C2, C3, C4, Tpl, Tml and Rfkt;
  • the diagram area with displaying the trends: variable (green, the style "labColorGrph4"), set-point (blue, the style "labColorGrph3"), the analog output (cyan, the style "labColorGrph5"), the regulator mode "Automate" (magenta, the style "labColorGrph7") and the digital outputs (orange, the style "labColorGrph2").

Users have an ability to change the PID-regulator's coefficients, mode, set-point, output and immediately to see the reaction on the diagram. In addition, the user may learn the history of the regulator work, which requires the left mouse button click in the graph area and by means of appeared trend's control panel to make the necessary navigation actions. To return the control panel of the parameter the left mouse button must be clicked in an empty area of the frame.

Fig.3.5b. The "Regulator's control panel" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
SHIFR Parameter: code String Input link Parameter|SHIFR
NAME Parameter: code String Input link Parameter|NAME
DESCR Parameter: description String Input link Parameter|DESCR
max Parameter: scale maximum Real Input link Parameter|max
min Parameter: scale minimum Real Input link Parameter|min
ed Parameter: dimension of variable String Input link Parameter|ed
prec Parameter: precision Integer Input link Parameter|prec Number of digits after coma, placed in value and set-point of the PID.
var Parameter: variable Real Input link Parameter|var
var_addr Parameter: variable address Address Input link Parameter|var Address for the trend building of the variable.
PID-regulator
auto_addr Parameter: auto Address Input link Parameter|auto Address for the trend building of the mode "Auto".
sp Parameter: set-point Real Input link Parameter|sp
sp_addr Parameter: set-point address Address Input link Parameter|sp Address for the trend building of the set-point.
out Parameter: output Real Input link Parameter|out
out_addr Parameter: output address Address Input link Parameter|out Address for the trend building of the analog output.
Hdwn Parameter: bottom output border Real Full link Parameter|Hdwn Limit the analog output value at the bottom.
Hup Parameter: upper output border Real Full link Parameter|Hup Limit the analog output value at the top.
Kp Parameter: gain coefficient Real Full link Parameter|Kp
Ki Parameter: coeff. of integration Real Full link Parameter|Ki
Ti Parameter: time of integration Real Full link Parameter|Ti
Kd Parameter: coeff. of differential Real Full link Parameter|Kd
Td Parameter: time of differentiation Real Full link Parameter|Td
Tzd Parameter: differential part lag time Real Full link Parameter|Tzd
Zi Parameter: insensitivity area Real Full link Parameter|Zi
K1 Parameter: input 1 coefficient Real Full link Parameter|K1
K2 Parameter: input 2 coefficient Real Full link Parameter|K2
K3 Parameter: input 3 coefficient Real Full link Parameter|K3
K4 Parameter: input 4 coefficient Real Full link Parameter|K4
Pulse PID-regulator
impQdwn_addr Parameter: address of impulse output down Address Input link Parameter|impQdwn Address for the trend building of the pulse output "Down".
impQup_addr Parameter: address of impulse output up Address Input link Parameter|impQup Address for the trend building of the pulse output "Up".
KImpRfact Parameter: rate factor Real Full link Parameter|KImpRfact Asymmetry in up and down pulse width generation.
TImpMin Parameter: minimal impulse time Integer Full link Parameter|TImpMin Pulses are generated from the specified width.
TImpPer Parameter: pulses period Integer Full link Parameter|TImpPer Periodicity of repetition of pulse generation.


3.6 Alarms — state (alarmsSt)

1.5 GPLv2 * en, uk, ru Roman Savochenko

The element-frame in Figure 3.6 serves to display the violations history and to update their dynamically for the current time in a full-format tabular form, to highlight them in color and text and the possibility of multilevel filtering. The violations are obtained from the buffer of current-active violations of OpenSCADA and archive(s), specified in the configuration field "alArch". In fact, the element implements the primitive "Protocol" functions for violations and extension opportunities.

The frame in general contains elements:

  • the messages table — the main area;
  • a button of the mass confirmation — the top left;
  • a combobox of selection of the data model level sort rule, it provides sorting by the selected column from the list defined in colms and by default this is time, as the second criterion (last on the top) — the next one top left;
  • a navigation panel at the messages history-archive — the top centre and right, consisting of:
    • the top-end time of the data;
    • size — depth of the data requesting;
    • the buttons of fast listing — per one and five intervals-depths forward and backward and at the current time;
    • a button to quickly move to the next part of a large query interval, divided by the limit on the number of messages in the table — for very dense-active messages generation;
    • a button to call-form of the report document for the actual table's data.
  • elements of the five-level filter with displaying the next level at activation the last one, by selecting a column from the list of specified ones in colms — the top after the previous one.

According to the announced list of the control elements, message sorting can be modified by the user, both by the built-in column sorting mechanism of a single visualizer and at the data model level, if such function the visualizer is not provided. Considering the basic purpose of the frame is the status of the violations (ie history), the default sorting rule is the "last" to the messages top.

The frame is created, and is usually used, in pair with the widget of dynamically display the active violations, which is completed with main features of this frame but only for active violations and in the small widget.

The main user extension is the ability to define visible table fields from a list of options:

  • atm — time of the violation appearing;
  • qttm — time of the violation confirmation;
  • nrmtm — time of coming-returning the violation to the state "NORM";
  • lev — level of the violation;
  • type — type-name of the violation from the level lev and the attribute "types";
  • cat — category of the violation;
  • mess — full and unparsed text of the violation message;
  • prm — address of the DAQ-parameter of the data source;
  • dscr — description of the violation from the source DAQ-parameter;
  • dscrCust{N} — description of the user field N;
  • alrm — text of the violation;
  • cmnt — commentary of the violation.

At.png This frame and its fields generally represent the structure of the violation message, which is described in detail in the Program manual.

As you can see from the list of possible table fields, this item supports confirmation, commenting, and user fields.

  • Sponsored by: Ustijancev Michael
  • Sponsored by, for appending the new user field "Type" on 0.2 HD[!]: INSERTEC LTDA
Fig.3.6a. The frame "Alarms — state" in the development mode.

Using — development
The widget is designed to perform the role of page, and should therefore be placed directly in the project's tree. After adding, the frame must be adjusted for the properties, such as the list and the order in which the table fields are displayed.

At.png Because the frame displays the status and the history of the violations, the creation and use of the message archiver is mandatory. Therefore, create or use a template archiver "Alarms" of the startup project with duplicate exclusion options, and specify it (FSArch.alarms) in the frame property "alArch".

The combobox of selecting sorting rule is disabled by default for the sake of using the built-in column sort function of the table of the corresponding visualizer. If this feature is not provided by the visualizer then enable this combo box.

If you want to exclude the validation function then you have to exclude the validation time "qttm" from the list and make the table element inactive.

The report building at the table data is also disabled by default. To enable it, you have to place the frame of alarms reporting in the logical container of panels of the project tree and then enable the characteristic report generation button in the upper right corner of this frame.

Using — runtime
In the runtime mode, a table is created from the active violations list, for the current time, and violations from the history by defined fields, with the activity control and marking and rules of the highlighting; the contents of which are updated periodically and dynamically for the current time.

The user can use the navigation bar to determine the time interval of the data in the table, specifying the top-end and depth of the required data. In the process of requesting too tight data spaces, only the number of messages specified in the property messLim will be readable, and the user can use the button in the navigation bar, what appears in that case, to move to the next piece.

The data obtained in the table can be filtered by the content of the column selected accordingly, which can be performed at up to five levels, the filter elements of which will appear after the last filter level is selected.

The user is given the opportunity to confirm the violation, by changing the value of the confirmation time field or by using the control panel that pops up after selecting the table element and the violation item. The user may also confirm all active violations by clicking the mass confirmation button.

If there is a column sort function in the visualizer, or enable sorting at the data model level, the user can select a column to sort the table rows at that content.

The user may also comment on the violation by correcting appropriate field of the table.

To generate a separate report, the user can click the characteristic button in the top right corner if this feature is enabled.

Fig.3.6b. The frame "Alarms — state" in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Description
messCat Message category String Category of the processing messages, typically it is "al*:*".
messLim Messages limit, quantity Integer Maximum quantity of the messages in the table, typically it is 1000.
alArch Alarms archiver, "{ArhMod}.{Arh}" String An archiver from which the violations will be taken, empty for all ones.
alarms.active Active Boolean Turn off if there disabled confirmation, focus gaining and editing in general — purely displaying.
hHdrVis Show header: horizontal Boolean
vHdrVis Show header: vertical Boolean
formDtTm Data and time format (%Y-%m-%d %H.%M.%S[.%MS,%US]) String Format of displaying the time of violation and confirmation.
colms Columns

List separated by ',' from the variants: atm, qttm, nrmtm, lev, type, cat, mess, prm, dscr, dscrCust{N}, alrm, cmnt.

String Determine in the desired sequence and the fields filling.
highLght Highlight rules

Rows in the form "{lev}[{slev}]{quitt}{act}:{color}:{font}:{fontColor}".

Text Highlight rules, where:
  • lev — main level of the message [0...7];
  • slev — sub-level of the message [0...9], optional;
  • quitt — sign of the message confirmation [0|1];
  • act — sign of the message activity [0|1];
  • color — background color of the message row;
  • font — text font of the message row;
  • fontColor — text color of the message row.

Te example:

#<SnthHgl font="monospace">
# <rule expr="^#[^\n]*" color="gray" font_italic="1"/>
# <rule expr="^[0-9]*" color="blue">
#  <rule expr="[01]{2}$" color="red">
#   <rule expr="[01]$" color="darkorange"/>
#  </rule>
# </rule>
# <rule expr="(?<=:).*">
#  <rule expr="[^:]*" font_weight="1"/>
#  <rule expr="(?<=:).*" font_italic="1"/>
# </rule>
#</SnthHgl>
501:gray
401:red
1501:yellow
511:gray:Arial 11 0 1
411:red:Arial 11 0 1
1511:yellow:Arial 11 0 1
colDscrCustNames Names list of the user fields, separated by ';' String (translate) At the support of user fields and their visibility, their names are given here.
types Types list at the level from 0, separated by ';' String (translate) Types-names of alarms at their level, typically "Debug;Info;Notice;Warning;Error;Critical;Alert;Emergency"


3.6.1 Report (alarmsStReport)

1.0 GPLv2 * en, uk, ru Roman Savochenko

The element-frame, shown in Figure 3.6.1, implements a dialog to display a report document based on a list of violations received from the full-format frame of presenting the violations history.

The main purpose and function of this frame is to provide an opportunity to print the violations history table and export data from it.

  • Sponsored by: Ustijancev Michael
Fig.3.6.1. The frame "Alarms — report".

Using — development
This frame should be placed to the panels' logical container of the project tree.

Using — runtime
Calling the dialogue is made by a characteristic button, at the top right, of the full-format frame of presenting the violations history. The dialog provides the text of the report document and a button at the bottom right to close it.


3.7 Users manager (userManager)

1.6 GPLv2 * en, uk, ru Roman Savochenko -2 ms (disabled)

The element-frame, shown in Figure 3.7, serves to control users from the user interface itself. That is, typically this feature is provided to the SCADA programmer at the Security subsystem configuration, but sometimes there is a need to provide this capability from the user interface and with a few restrictions on controlled users and their groups that this frame performs and generally provides:

  • forming a list of controlled users;
  • the ability to view and change user information for: name, full name, description, password and groups;
  • adding new and deleting existing users;
  • the possibility to edit the unprivileged user own information and password.
  • Sponsored by: Vinnica Poultry Farm
Fig.3.7a. The "Users manager" frame in the development mode.

Using — development
The widget is designed to perform the role of a page, and should therefore be placed directly in the project's tree. Additionally, into the panels folder of the project, you need to place the acception dialog frame and some attribute configuration is required, below, where no links are provided.

Using — runtime
In the runtime mode, a list is formed with available users and, at their selection, on the right displayed their information that can be changed. The user can be added and removed by the appropriate interface commands under the list of users.

Fig.3.7b. The "Users manager" frame in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Description
owner Owner String Owner and group of the frame that have access to it, typically "root:Security" — to allow the frame to be accessed, the user must be included in the "Security" group.
perm Access Integer numbers selection Frame access rules, typically "RWRW__" — the frame is viewable and controllable only for "root" and users in the "Security" group.
denyUsers Deny to control: users, separated by ';' String A list of do not controlled users, typically "root;".
denyGroups Deny to control: groups, separated by ';' String A list of do not controlled groups, typically "root;users;Archive;BD;DAQ;ModSched;Protocol;Security;Special;Transport;UI;".
newUseGrps Groups of new created user String Groups to which the user is automatically included, after creation, are typically "UI;Guest".
storeDB DB of saving new users String Database of storage of newly created users, by default — the work one.


3.8 Storehouse (storeHouse)

1.4 GPLv2 * en, uk Roman Savochenko -1 ms (parent)

The element-frame, shown in Figure 3.8, serves to manage of storehouses on different classes-categories of the storing-managing things. Initially that was developed and tested on the class "Library". The frame means of the direct accessing the DB by SQL and currently supports only MySQL/MariaDB.

During the frame implementing, the view "Table" of the primitive "FormEl" significantly expanded on both visualizers for:

  • VCAEngine,QTStarter,Vision,WebVision: Appended by the new cell type 't'-text mostly for allowing the edition confirming the type 's'-string by pressing Enter.
  • VCAEngine,Vision,WebVision: Appended of the column, row and cell space option "prec" of the real value precision control; and by the column and cell attribute "align" implementation.
  • WebVision,Vision: Appended for switching the tables in preventing of double storing the source content at the content size more for 10000.
  • FIX:Vision: Using the common table delegate with the feature of multiline edition.
  • Improved in the columns, rows and cells show at the table updation and commonly:
  • in limiting the visual size of the cell content in 300 symbols and the rows height in 70% from the whole table size;
  • more precision columns width alignment;
  • in fitting at the development mode and also at the vertical header show;
  • in the table close filling by consideration the visible vertical scrollbar size;
  • in fitting after the table whole resizing only, so allow the columns resizing manually also and to provide that true fitting always.
  • Implemented for the light processing of the width changing and updating:
  • light edition without the columns refitting all updating time, only at: first row appearing, columns count change and the column title change, font change and resize;
  • apply the column force width and the row height calculation with limits independently from the common attribute "colsWdthFit" value;
  • setting the value, early resizing and the table fitting, moved to the space of the table content presence and after the sorting.
  • The export function in runtime append of export the view Table of the primitive "FormEl" in CSV.
  • WebVision:
  • Improved in the columns, rows and cells show at the table updating and commonly:
  • the not fitting mode (the attribute "colsWdthFit" missing) implementation, using the automatic table layout mode for calculation the fixed widths and next switching to the fixed table layout mode;
  • multiline text edition of the text cells in whole width and height of the cell, with the edition apply by Ctrl+Enter;
  • view limiting the string cells in 300 symbols;
  • display the boolean cells as an image at the TRUE state;
  • table cells in the editing mode allowed for the system-browser context menu.
  • Implemented for the light processing of the width changing and updating:
  • the table changes detection and updating switched to the mode of not storing double source content;
  • prevented from the complete updating at the attribute "value" modification.
  • Appended for the sorting support by columns. Set to the first visible column for sorting at the sorting enable.


The frame provides currently and in future for next features:

  • Class edition mode: observing, creation and edition the storehouse classes with a function of storing data at the field type change.
  • Main data observing and edition mode:
    • observing main data of the selected or fixed storehouse classes in a big table with possibility of sorting and filtering by up to five columns;
    • editing of content of the table cells in the edition mode;
    • adding, copying and removing of records-rows of the table in the edition mode;
    • generation of the report document of the selected item, which is ready to print and convenient in complete observing;
    • generation of the report document of the main table with accounting the filter settings and natural show the specific fields;
    • detailed control panel-form of the selected item with the specific fields.

The storehouse classes are stored in the table "classes" with the fixed table structure "CLASS, ID, NAME, TP , TBL, FILTER, PROC", where:

  • CLASS [varchar(20)] — class ID;
  • ID [varchar(20)] — specific field ID of the class;
  • NAME [text] — specific field localised name of the class, where the first line for the default value and the next lines form in the view {2SymbolLang}:{LocalizedText};
  • TP [varchar(100)] — specific field type of the class, which correspond directly to the MySQL data types and some specific ones:
  • "file[:{max}[:{storage}[:{MIME}[:{OverViewSz}]]]]" — attaching files with the parameters:
  • max — maximum files allowed to attach;
  • storage — storage of the files on the File System with the specified path, and empty to store directly in the DB field of the type LONGTEXT;
  • MIME — files type, allowed to attach-load, where empty for any and like to "image/*" for only images;
  • OverViewSz — enable a field of the image files overview on the item form with the specified size in pixels.
  • TBL [varchar(100)] — specific field properties of representing data in the table, has the format {align}:{width}:{pos}, where:
  • align — column alignment, supports the values: "left", "center", "right"; where the "left" value is default one for strings and "center" for other;
  • width — forced width for the column, in percents at symbol "%" in the end or in pixels;
  • pos — the column position in the string view, so you can write that like to "005" for true sort.
  • FILTER [text] — specific field properties of filtering and indexing lists preparing for the filter selection, for the variants: index and list{SepSymb}, where:
  • index — the column value means as whole one for indexing;
  • list{SepSymb} — the column value means as a list of items for indexing, separated by symbol SepSymb.
From the second line you can specify rules of the highlighting in the form "{ID}:{FLGS}:{color}:{font}", where:
  • ID — indexed or listed value in the cell;
  • FLGS — flags list in values [0|1], currently that is only "Highlight [Cell|Row]";
  • color — the background color;
  • font — the text font.
  • PROC [text] — a procedure of calculation the cell value on the internal language JavaLikeCalc.JavaScript of OpenSCADA, the column is become the logical one; cells of the logical columns aren't accessible for the manual edition; all cells of the record-row are accessed in the procedure as them IDs, including the calculated one which you have to assign in some value; you can use that feature also as a temporary one, that is install a procedure for calculation and next clean up that;
At.png Setting here a procedure will clean up (set to NULL) all the column cells!

Data of storehouse of the corresponded class stores in different table with name "sh_{CLASS}" and the structure "ID, NAME, DSCR, SP_{ID}1, ..., SP_{ID}N", where:

  • ID [INT] — automatic index of the table, allowed for change the visibility;
  • NAME [varchar(200)] — name of the item, allowed for change the type;
  • DSCR [text] — description of the item;
  • SP_{ID}X — specific field of the class corresponding to ID in the class table.

For the special means there in the table "classes" reserved and forcibly created fields "*TITLE" for the whole storehouse localised name and "*NAME", "*DSCR" which control the corresponded fixed fields.

Fig.3.8a. The "Storehouse" frame in the development mode.

Using — development
The widget is designed to perform the role of a page, and should therefore be placed directly in the project's tree. Additionally, into the panels folder of the project, you need to place the accepting dialog frame and some attribute configuration is required, below, where no links are provided.

To enable the reporting, you have to place the frame of alarms reporting in the logical container of panels of the project tree.

Using — runtime
In the runtime mode you will see a single big table for class (Fig.3.8b) and data (Fig.3.8c) representing with edition right in the table or in the item edition form (Fig.3.8d).

In the main class data representing mode the users can observe the table, filter and sort the representing data at the specified fields.

In the main class data edition mode the users, allowed to edit, can add, copy, remove the rows/records and edit the fields.

In the class edition mode, the users, allowed to edit, can add new and remove present (after removing the last item) classes; and add, remove the specific class fields and edit properties of that fields.

For user access limitation there provided now only a mechanism of including the allowed for the class and data edition users to the group "ITW".

To generate a separate report, the user can click a characteristic button in the top right corner.

At.png The frame supports now of working with very big "Periodic processing" value and that value is set now to from parent (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Fig.3.8b. The "Storehouse" frame in the runtime mode at the class representing.
Fig.3.8c. The "Storehouse" frame in the runtime mode at the data representing.
Fig.3.8d. The "Storehouse" frame in the runtime mode at the item edition form.

Linking and configuring the attributes

Identifier Name Type Description
class Class: initial String Forced/initial class for first opening.
classEditable (Constant) Class: editable Boolean Flag of allowing for the class edition.
classFix (Constant) Class: fixed String The fixed class for which the frame performed only, denying access for other classes.
dataEditable (Constant) Data: editable Boolean Flag of allowing for the main data edition.
db (Constant) DB: Data base String Database of the classes and data in the view {Type}.{DB}.

4 Control panels and simple dialogs

Contains elements-frames of control panels and simple dialogues, that are difficult or unnecessary to be implemented as panels. These frames are intended to be placed in the respective panels directory of the project tree, built on the concept of the signal objects of the root page "RootPgSo". The frames are generally not intended to be used separately, as they often represent the specifics of the data to which their provide control elements or expanded information, and should therefore be used with them, except in the case of unification, generalization and extended control of the primitives!

These elements are mostly opened dynamically upon call from the primary view element-widget, performing in that the dynamic linking of links in the group "<page>" of the panel with the widget (often page) that called this panel. Further work, until closing, is done with the data of the calling widget.


4.1 Terminator panel (terminator)

1.1 GPLv2 * en, uk, ru Roman Savochenko

The panel element shown in Figure 4.1 serves to fill the panel container space when no active visual control element is selected in the main frame, since closing or clearing frames in the container area is not provided, only the replacement.

Fig.4.1. The panel element "Terminator panel".

Using — development
This element should be placed in the logical container of the project's tree.

Using — runtime
Calling the panel is made from the root page "RootPgSo" by changing the signal object or the type of view.


4.2 Element cadre (ElCadr)

1.4 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element shown in Figures 4.2 is in fact a universal panel of generic and extended control by different devices for all known and defined representative structures of the basic data of the control systems at the DAQ-templates:

In the primary function of the pannel — advanced and common control, this item is called from:

If this element using as a control panel is not required, it is firstly in the primary data representing widgets and by their specializing in particular types of data to what a separate panel can be created. Therefore, due to its high universality, due to the support of all known representative structures of DAQ-templates, it is obligatory to use in main frames, as is done in the frame "Contours group".

Fig.4.2a. The "Element cadre" widget in the development mode.

Using — development
The panel does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened in the control panels container of the root page.

The panel Identifier, when placed, should be saved and its line of call, upon receiving focus, in the events processing attribute "evProc" of the primary widget will look "ws_FocusIn::open:/pg_control/pg_ElCadr".

Using — runtime
Indications of the analog parameter — in this mode, there is no any control, and there are only units displaying, the value's histogram and the name of the parameter.

Manual input of the analog parameter — in addition to displaying indications of analog parameters the buttons to enter a new value are displayed. Enter of the value is displayed in the field at the top, in the backlight rectangle. To validate the input, press the left mouse button in the area of the backlight rectangle, without that the typed value will be reset after a few seconds.

PID-regulator's mode — to the value of a variable and its histogram are added values and histograms of set-point and out of the PID-regulator, the buttons to enter a new value of the set-point or out, as well as the mode adjustment buttons and the field to display the current mode. Also, for the user with appropriate privileges ("root:ITW"), it is available the button to go to a frame to set the coefficients of the PID-regulator. In the case of pulse PID instead of histogram of the analog output it is displayed the status of pulse output with the help of triangles "Up" and "Down" and the manual entry of output leads to direct formation of pulse, respectively down or up.

Mode of the discrete device — in this mode the name and the field of discrete assemble of the parameter are displayed. The field of the discrete assemble contains the current state of discrete device, on the left, and the buttons of commands, on the right. There are two states of the device: "Open", "Closed" and the three commands: "Open", "Close", "Stop". The names of the states and commands can be adjusted during set up. Changing the state of the discrete device is determined by pressing the corresponding command. In direct discrete mode, a combo box is formed with a list of elements from digComs, the current state from st_text and sending commands to com_text.

Every action on this panel (change of PID-regulator set-point, state of the discrete parameter, ...) is recorded in the actions log by the generation of appropriate messages according to the message structure of the operator actions.

For any displayed or controlled parameter the passport can be obtained by clicking the right mouse button on the contour field. The passport will present all the properties of the parameter.

At.png The frame supports now of working with very big "Periodic processing" value and that value is set now to inherit from parent page/session (the value -1). That is possible by a mechanism of the events early processing and the possibility of control the processing periodicity from the procedure.

Fig.4.2b. The "Element cadre" widget in the runtime mode.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
prmId Parameter: identifier String Input link <page>|SHIFR Identifier of the parameter, used only to detect the appropriate PID-control pages.
prmShifr Parameter: code String Input link <page>|NAME Short name of the parameter — code, to be placed below the frame and in actions of the user-operator.
prmDescr Parameter: description String Input link <page>|DESCR Description of the parameter to be placed in actions of the user-operator.
prmColor Parameter: border color String Input link <page>|color Sets the border color of the contour.
Properties of the Analog Devices
prmDemention Parameter: dimension String Input link <page>|ed
prmPrec Parameter: precision (signs) Integer Input link <page>|prec Number of digits after the dot in the parameter value and the step of changing the manual input of the value, as well as the set-point and output of the PID-regulator.
prmVar Parameter: variable Real Full link <page>|var Directly the value of the analog parameter.
max Parameter: maximum Real Input link <page>|max Maximum limit of the parameter value.
min Parameter: minimum Real Input link <page>|min Minimum limit of the parameter value.
prmAMax Parameter: border up alarm Real Input link <page>|aMax
prmAMin Parameter: border down alarm Real Input link <page>|aMin
prmWMax Parameter: border up warning Real Input link <page>|wMax
prmWMin Parameter: border down warning Real Input link <page>|wMin
Manual Analog Input
prmVarIn Parameter: variable input Real Full link <page>|varIn Output for manual input of analog parameter value. The presence of this parameter is an indication that the parameter is defined as "Manual Analog Input".
PID-regulator
prmAnalog Parameter: analog regulator Boolean Input link <page>|analog The indication of the analog regulator, in the absence of which the regulator is considered as impulse.
prmAuto Parameter: automate Boolean Full link <page>|auto The regulator mode "Automatic".
prmCasc Parameter: cascade Boolean Full link <page>|casc The regulator mode "Cascade".
prmSp Parameter: set-point Real Full link <page>|sp The PID-regulator set-point, which can be set by the user.
prmImpQdwnTm Parameter: imp. out down Boolean Input link <page>|impQdwn The output "Down" of the impulse (PWM) regulator.
prmImpQupTm Parameter: imp. out up Boolean Input link <page>|impQup The output "Up" of the impulse (PWM) regulator.
prmOut Parameter: output Real Full link <page>|out Output of the analog PID-regulator to display and manual input of the output value of PID in the manual mode.
prmManIn Parameter: manual input Real Full link <page>|manIn Manual input of the new output value of the PID-regulator in the manual mode.
Properties of the discrete devices
prmCom Parameter: command - "Open" Boolean Full link <page>|com
prmClose Parameter: command - "Close" Boolean Full link <page>|close
prmStop Parameter: command - "Stop" Boolean Full link <page>|stop
prmComText Parameter: text of command String Full link <page>|com_text The command text directly, taken from digComs at building the selection combobox.
digComs Parameter: discrete commands String Input link <page>|digComs Configuration of the parameter commands with the structure {openLabel}-{color};{closeLabel}-{color}, for the discrete block, and {com1Label}-{color};{com2Label}-{color};...;{comNLabel}-{color}, for the code status. Default colours for the discrete block are: "green", "red" and "yellow".
prmOpenSt Parameter: state - "Opened" Boolean Input link <page>|st_open
prmCloseSt Parameter: state - "Closed" Boolean Input link <page>|st_close
prmStText Parameter: status text String Input link <page>|st_text The status text directly.
digStts Parameter: discrete stats String Input link <page>|digStts Configuration of the parameter statuses with the structure {openedLabel}-{color};{closedLabel}-{color}, for the discrete block. Default colours are: "green" and "red".


4.3 Passport, extended (cntrPaspExt)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element shown in Figure 4.3 is an information-control dialog around the data source parameter — an expanded parameter passport. Unlike the simple passport, the expanded one, in addition to information, provides the ability to control the parameter attributes and display the history of the standard attributes in both a trend and a data table.

Information and control for parameter attributes remains the primary function provided in the "View" tab, where the attribute table is formed as their are, with the "Name" and "Value" columns. The table is active and if you select an entry of the accessible to write attribute and at corresponding permissions (root:op), a field for entering new values will be provided at the bottom.

The history is provided in the following two tabs "Trends" and "Data", which may not be available in the absence of the history-archives at standard attributes. The "Trends" tab contains a graphics area, of the primitive "Diagram", on most of the window, and a table at the bottom with the names, colours, and graph scales. The graphs are updated periodically and built with a period of 1 second and a fixed depth of 1 hour. The "Data" tab contains only the "Document" primitive field with a table with attribute values in columns that is updated with a period of 1 second for the history data period and to a depth of 100 records. The following items of the representative parameter structures are considered standard attributes with history:

  • Analog signal:
    • var — variable.
  • PID-regulator:
    • sp — setpoint;
    • out — output;
    • auto — mode: automate.
  • Discrete assembles:
    • com — command "Open";
    • close — command "Close";
    • stop — command "Stop";
    • st_open — state "Opened";
    • st_close — state "closed".

In the trends of the analog parameters building the attributes are separately processed for alarm [aMin...aMax] and warning scales [wMin...wMax], which are also displayed in the graph.

At.png This dialogue is currently the main one and has replaced the simple passport dialogue.

  • Sponsored by: PAC HARTRON
Fig.4.3. The "Passport, extended" dialogue in the runtime mode.

Using — development
The dialogue does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened as an external dialogue window.

The dialogue Identifier, when placed, should be changed to "cntrPasp" and its line of call, upon pressing right mouse button, in the events processing attribute "evProc" of the primary widget will look "key_mousePresRight::open:/pg_control/pg_cntrPasp".

Using — runtime
The dialogue provides the user in the tab "View" with information about the data source parameter in the list and the values of all the properties-attributes of the parameter in the table. Where writable attributes may be edited at the permissions "root:op" in the appeared at the bottom field for entering new values, at selecting the attribute.

For the history the user may observe the trends in the tab "Trends" and the data in the tab "Data". For the trends the user may also highlight some one, selecting it in the bottom table, and correct the scales if it is wrong.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
pName Parameter name Address Input link Parameter|NAME Address to the parameter's name to refer to the parameter entirely and get all of its properties.


4.4 Passport (cntrPasp)

1.0 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element shown in Figure 4.4 is an information dialog around the parameter of the data source — the parameter passport, accordingly it allows to receive such information as: cipher, name, description, unit of measure, emergency boundaries and other, corresponding to the parameter representative structure — parameter attributes. The dialogue is based on the primitive "Document", whose content is generated dynamically and updated periodically.

In building the passport the attributes are separately processed for alarm [aMin...aMax] and warning scales [wMin...wMax], which combined in a single entry, and can be hidden when turned off.

At.png Currently, this dialogue has actually been replaced by the more functional and expanded passport dialogue and is largely disabled in all template and demonstration projects, though no one interferes with its use if only information is required.

Fig.4.4. The "Passport" dialogue in the runtime mode.

Using — development
The dialogue does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened as an external dialogue window.

The dialogue Identifier, when placed, should be saved and its line of call, upon pressing right mouse button, in the events processing attribute "evProc" of the primary widget will look "key_mousePresRight::open:/pg_control/pg_cntrPasp".

Using — runtime
The dialogue only provides the user with information about the data source parameter in the list and the values of all the properties-attributes of the parameter in the table.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
pName Parameter name Address Input link Parameter|NAME Address to the parameter's name to refer to the parameter entirely and get all of its properties.


4.5 Panel of the graphs (grph_panel)

1.5 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element shown in Figure 4.5 is a specialized panel for dynamic control of basic user properties of the primitive "Diagram". So, the panel allows you to view graphs of the history for the required period of time and the desired resolution, supports: the scale, the selection of archiver for display and the graphs presentation in a spectrum of present frequencies or XY.

Fig.4.5. The panel of the graphs in the development and runtime modes (left to right).

Using — development
The panel does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened in the control panels container of the root page.

The panel Identifier, when placed, should be saved and its line of call, upon receiving focus, in the events processing attribute "evProc" of the primary widget will look "ws_FocusIn::open:/pg_control/pg_grph_panel".

Using — runtime
The panel allows the user to:

  • select the diagram graphics mode: "Graph", "Spectrum of frequencies", "XY";
  • select of the diagram formation time;
  • perform of navigation through the diagram for the half or five sizes of the graph area and setting of the diagram generation time to the current time or in the cursor time;
  • get information about the time or frequency in the current cursor's position;
  • select of the trend's formation size (depth) or set the begin time, also to the cursor time;
  • select of the archive, used for the trend building, at the access rule "root:ITW";
  • control the vertical and horizontal scale of the presentation: zoom in and out the scale, shift the scale up and down, the scale returns to its original value;
  • switch of the scale mode by the window drawn by the mouse.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
tSek Trend time DateTime Full link <page>|tSek
tSize Trend size Real Full link <page>|tSize Time size-interval of the graph in the history from the trend time.
trcPer Trace period Integer Full link <page>|trcPer Period of the trend updating-tracing.
type Type Integer Full link <page>|type Graph's type: "Trend", "Spectrum of frequencies", "XY".
valArch Archiver String Full link <page>|valArch
curSek Cursor DateTime Full link <page>|curSek Time of the cursor setting.
curUSek Cursor, microseconds Integer Full link <page>|curUSek Time of the cursor setting, microseconds.
sclVer Vertical scale Real Full link <page>|sclVerScl Percentage of the vertical scale.
sclVerOff Vertical scale offset Real Full link <page>|sclVerSclOff Percentage of the offset on the vertical scale.
sclHor Horizontal scale Real Full link <page>|sclHorScl Percentage of the horizontal scale.
sclHorOff Horizontal scale offset Real Full link <page>|sclHorSclOff Percentage of the offset on the horizontal scale.
sclWin Scale by window Boolean Full link <page>|sclWin Switching the window scaling mode.
sclWinCtx Scale: by window save context Object Input link <page>|sclWinCtx Context of storing of the original scale parameters for return.


4.6 Panel of documents (doc_panel)

1.2 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element shown in Figure 4.6 is a specialized panel for dynamic control of basic user properties of the primitive "Document". So, the panel allows you to manage documents and navigate through their histories; supported dynamic and archival documents.

Fig.4.6. The panel of the documents in the development and runtime (dynamic and archival) modes, left to right.

Using — development
The panel does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened in the control panels container of the root page.

The panel Identifier, when placed, should be saved and its line of call, upon receiving focus, in the events processing attribute "evProc" of the primary widget will look "ws_FocusIn::open:/pg_control/pg_doc_panel".

Using — runtime
The panel provides tools that are somewhat different for the dynamic and archival modes.

The dynamic document provides:

  • selection of the document formation time;
  • selection of the document formation size (depth) or the begin time;
  • navigation through the document for one or five sizes-depths of the document;
  • setting the generation time of the document to the current time.

The archival document provides only navigation through documents in the archive by listing them, and display current and overall documents.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
Dynamic documents
time Document time DateTime Full link <page>|time
bTime Document begin DateTime Full link <page>|bTime
doc Document String Full link <page>|doc
Archive documents
n Archive size Integer Input link <page>|n
vCur View cursor Integer Full link <page>|vCur
aCur Archive cursor Integer Input link <page>|aCur
aSize Archive size Integer Input link <page>|aSize


4.7 Accept (accept)

1.0 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element on Figure 4.7 implements a simple operations' acception dialog. The dialog contains a message with a question and two buttons "Apply" and "Cancel". The dialogue, for example, is used in the frame Users manager to accept the deleting operation.

Fig.4.7. The "Accept" dialog in the development and runtime mode.

Using — development
The dialogue does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened as an external dialogue window.

The dialogue Identifier, when placed, should be stored and its line of call, upon pressing the button "progDel", in the events processing attribute "evProc" of the primary widget will look "ws_BtPress:/progDel:open:/pg_control/pg_accept". The question message is taken from the "mess" attribute and the "dlg_Apply" signal is transmitted to the "event" at acception.

Using — runtime
Calling the dialogue is made from the frame-initiator, and closing is made by pressing any button of the dialog. If you click the "Apply" button the "dlg_Apply" signal will be sent to the frame-initiator, by which it can perform the desired actions.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
elEvent Element: event String Full link <page>|event It is used to send the "dlg_Apply" event if accepted.
elMess Element: message String Input link <page>|mess Source of the question message in the dialogue.


4.8 Select item into tree (treeSelect)

1.0 GPLv2 * en, uk, ru Roman Savochenko -1 ms (parent)

The element in Figure 4.8 implements a simple dialog for selecting an item in a tree. The dialog contains the tree itself and the two buttons "Accept" and "Cancel". This dialog, for example, was used and originally designed for it in the frame "Prescription: run (simple)" for hierarchical selection of an element in a tree.

Fig.4.8. The "Select item into tree" dialog in the development and runtime mode.

Using — development
The dialogue does not require any special configuration by the user, it should only be located in the panels folder of the project tree of the concept of the signal objects of the root page "RootPgSo", which will allow it to be dynamically invoked and opened as an external dialogue window.

The dialogue Identifier, when placed, should be stored and its line of call, upon pressing the button "lib", in the events processing attribute "evProc" of the primary widget will look "ws_BtPress:/lib:open:/pg_control/pg_treeSelect". The items list is taken from the "items" attribute, the selected value from "selValue" and the "dlg_Apply" signal is transmitted to the "event" at acception.

Using — runtime
Calling the dialogue is made from the frame-initiator, and closing is made by pressing any button of the dialog. If you click the "Apply" button the "dlg_Apply" signal will be sent to the frame-initiator, by which it will apply the selected item.

Linking and configuring the attributes

Identifier Name Type Configuration Configuration template Description
elEvent Element: event String Full link <page>|event It is used to send the "dlg_Apply" event if accepted.
elItems Element: items list Text Input link <page>|items Source of the items list in the dialogue.
selValue Element: selected value String Full link <page>|selValue Source of the selected item in the dialogue.