Export translations
Views
Special page
From OpenSCADAWiki
Jump to:
navigation
,
search
Settings
Group
About
Documents
Documents/API
Documents/DAQ
Documents/FAQ
Documents/How to
Documents/How to/Build from source
Documents/How to/Crash report
Documents/How to/Create module
Documents/How to/Create multi language project
Documents/How to/Cyclic programming
Documents/How to/Debug
Documents/How to/Install
Documents/How to/Live disk
Documents/How to/Release
Documents/How to/Transferring project configuration
Documents/How to/Violations, alarms and notifications
Documents/Program manual
Documents/Quick start
Documents/Release 0.8.0
Documents/Release 0.8.0/Update10
Documents/Release 0.8.0/Update11
Documents/Release 0.8.0/Update12
Documents/Release 0.8.0/Update13
Documents/Release 0.8.0/Update14
Documents/Release 0.8.0/Update15
Documents/Release 0.8.0/Update16
Documents/Release 0.8.0/Update17
Documents/Release 0.8.0/Update18
Documents/Release 0.8.0/Update19
Documents/Release 0.8.0/Update20
Documents/Release 0.8.0/Update3
Documents/Release 0.8.0/Update4
Documents/Release 0.8.0/Update5
Documents/Release 0.8.0/Update6
Documents/Release 0.8.0/Update7
Documents/Release 0.8.0/Update8
Documents/Release 0.8.0/Update9
Documents/Release 0.9
Documents/Release 0.9/Update 7
Documents/Release 0.9/Update1
Documents/Release 0.9/Update2
Documents/Release 0.9/Update3
Documents/Release 0.9/Update4
Documents/Release 0.9/Update5
Documents/Release 0.9/Update6
Documents/Release 0.9/Updating 0.8.0 LTS
Documents/Terms
Documents/User API
Functions and demands
Home
Libs
Libs/Devices
Libs/Documents
Libs/Electrical elements
Libs/Generic list
Libs/LowLevelDevices
Libs/Main
Libs/Main graphical elements
Libs/Mnemo elements
Libs/Prescriptions
Libs/Regulation elements
Libs/Service procedures
Libs/Technological apparatuses
Modules
Modules/BFN
Modules/BlockCalc
Modules/Comedi
Modules/DAQGate
Modules/DBArch
Modules/DBF
Modules/DBGate
Modules/DCON
Modules/DiamondBoards
Modules/FireBird
Modules/FLibComplex1
Modules/FLibMath
Modules/FLibSYS
Modules/FSArch
Modules/GPIO
Modules/HTTP
Modules/ICP DAS
Modules/JavaLikeCalc
Modules/LDAP
Modules/LogicLev
Modules/ModBus
Modules/MySQL
Modules/OPC UA
Modules/PostgreSQL
Modules/QTCfg
Modules/QTStarter
Modules/SelfSystem
Modules/Serial
Modules/Siemens
Modules/SMH2Gi
Modules/SNMP
Modules/Sockets
Modules/SoundCard
Modules/SQLite
Modules/SSL
Modules/System
Modules/SystemTests
Modules/UserProtocol
Modules/VCAEngine
Modules/Vision
Modules/WebCfg
Modules/WebCfgD
Modules/WebUser
Modules/WebVision
Sub-projects
Sub-projects/Automatic Builder of OpenSCADA
Sub-projects/Automation Linux distributive
Sub-projects/Embedding and PLC
Sub-projects/Server
Sub-projects/VCA
User:RomanSavochenko
Using
Using/HouseSpirit
Using/Kramatorsk Ball Mills
Using/Kramatorsk Water
Using/Model AGLKS
Using/Model Boiler
Using/OpenWrt TELEOFIS RTU968
Using/Yaroslavskij broiler
Works
Works/Road map
Works/Technical Support
Works/Technical Support/Agreement
Works/To do
Language
aa - Afar
ab - Abkhazian
ace - Achinese
ady - Adyghe
ady-cyrl - адыгабзэ
aeb - Tunisian Arabic
aeb-arab - تونسي
aeb-latn - Tûnsî
af - Afrikaans
ak - Akan
aln - Gheg Albanian
am - Amharic
an - Aragonese
ang - Old English
anp - Angika
ar - Arabic
arc - Aramaic
arn - Mapuche
arq - Algerian Arabic
ary - Moroccan Arabic
arz - Egyptian Arabic
as - Assamese
ase - American Sign Language
ast - Asturian
av - Avaric
avk - Kotava
awa - Awadhi
ay - Aymara
az - Azerbaijani
azb - تۆرکجه
ba - Bashkir
bar - Bavarian
bbc - Batak Toba
bbc-latn - Batak Toba
bcc - Southern Balochi
bcl - Bikol Central
be - Belarusian
be-tarask - Belarusian (Taraškievica orthography)
bg - Bulgarian
bgn - Western Balochi
bho - Bhojpuri
bi - Bislama
bjn - Banjar
bm - Bambara
bn - Bengali
bo - Tibetan
bpy - Bishnupriya
bqi - Bakhtiari
br - Breton
brh - Brahui
bs - Bosnian
bto - Iriga Bicolano
bug - Buginese
bxr - буряад
ca - Catalan
cbk-zam - Chavacano de Zamboanga
cdo - Min Dong Chinese
ce - Chechen
ceb - Cebuano
ch - Chamorro
cho - Choctaw
chr - Cherokee
chy - Cheyenne
ckb - Central Kurdish
co - Corsican
cps - Capiznon
cr - Cree
crh - Crimean Turkish
crh-cyrl - Crimean Turkish (Cyrillic script)
crh-latn - Crimean Turkish (Latin script)
cs - Czech
csb - Kashubian
cu - Church Slavic
cv - Chuvash
cy - Welsh
da - Danish
de - German
de-at - Austrian German
de-ch - Swiss High German
de-formal - German (formal address)
diq - Zazaki
dsb - Lower Sorbian
dtp - Central Dusun
dty - डोटेली
dv - Divehi
dz - Dzongkha
ee - Ewe
egl - Emilian
el - Greek
eml - Emiliano-Romagnolo
en - English
en-ca - Canadian English
en-gb - British English
eo - Esperanto
es - Spanish
et - Estonian
eu - Basque
ext - Extremaduran
fa - Persian
ff - Fulah
fi - Finnish
fit - Tornedalen Finnish
fj - Fijian
fo - Faroese
fr - French
frc - Cajun French
frp - Arpitan
frr - Northern Frisian
fur - Friulian
fy - Western Frisian
ga - Irish
gag - Gagauz
gan - Gan Chinese
gan-hans - Simplified Gan script
gan-hant - Traditional Gan script
gd - Scottish Gaelic
gl - Galician
glk - Gilaki
gn - Guarani
gom - Goan Konkani
gom-deva - Goan Konkani (Devanagari script)
gom-latn - Goan Konkani (Latin script)
got - Gothic
grc - Ancient Greek
gsw - Swiss German
gu - Gujarati
gv - Manx
ha - Hausa
hak - Hakka Chinese
haw - Hawaiian
he - Hebrew
hi - Hindi
hif - Fiji Hindi
hif-latn - Fiji Hindi (Latin script)
hil - Hiligaynon
ho - Hiri Motu
hr - Croatian
hrx - Hunsrik
hsb - Upper Sorbian
ht - Haitian Creole
hu - Hungarian
hy - Armenian
hz - Herero
ia - Interlingua
id - Indonesian
ie - Interlingue
ig - Igbo
ii - Sichuan Yi
ik - Inupiaq
ike-cans - Eastern Canadian (Aboriginal syllabics)
ike-latn - Eastern Canadian (Latin script)
ilo - Iloko
inh - Ingush
io - Ido
is - Icelandic
it - Italian
iu - Inuktitut
ja - Japanese
jam - Jamaican Creole English
jbo - Lojban
jut - Jutish
jv - Javanese
ka - Georgian
kaa - Kara-Kalpak
kab - Kabyle
kbd - Kabardian
kbd-cyrl - Адыгэбзэ
kg - Kongo
khw - Khowar
ki - Kikuyu
kiu - Kirmanjki
kj - Kuanyama
kk - Kazakh
kk-arab - Kazakh (Arabic script)
kk-cn - Kazakh (China)
kk-cyrl - Kazakh (Cyrillic script)
kk-kz - Kazakh (Kazakhstan)
kk-latn - Kazakh (Latin script)
kk-tr - Kazakh (Turkey)
kl - Kalaallisut
km - Khmer
kn - Kannada
ko - Korean
ko-kp - 한국어 (조선)
koi - Komi-Permyak
kr - Kanuri
krc - Karachay-Balkar
kri - Krio
krj - Kinaray-a
ks - Kashmiri
ks-arab - Kashmiri (Arabic script)
ks-deva - Kashmiri (Devanagari script)
ksh - Colognian
ku - Kurdish
ku-arab - كوردي (عەرەبی)
ku-latn - Kurdish (Latin script)
kv - Komi
kw - Cornish
ky - Kyrgyz
la - Latin
lad - Ladino
lb - Luxembourgish
lbe - лакку
lez - Lezghian
lfn - Lingua Franca Nova
lg - Ganda
li - Limburgish
lij - Ligurian
liv - Livonian
lmo - Lombard
ln - Lingala
lo - Lao
loz - Lozi
lrc - Northern Luri
lt - Lithuanian
ltg - Latgalian
lus - Mizo
luz - Southern Luri
lv - Latvian
lzh - Literary Chinese
lzz - Laz
mai - Maithili
map-bms - Basa Banyumasan
mdf - Moksha
mg - Malagasy
mh - Marshallese
mhr - Eastern Mari
mi - Maori
min - Minangkabau
mk - Macedonian
ml - Malayalam
mn - Mongolian
mo - молдовеняскэ
mr - Marathi
mrj - Western Mari
ms - Malay
mt - Maltese
mus - Creek
mwl - Mirandese
my - Burmese
myv - Erzya
mzn - Mazanderani
na - Nauru
nah - Nāhuatl
nan - Min Nan Chinese
nap - Neapolitan
nb - Norwegian Bokmål
nds - Low German
nds-nl - Low Saxon
ne - Nepali
new - Newari
ng - Ndonga
niu - Niuean
nl - Dutch
nl-informal - Nederlands (informeel)
nn - Norwegian Nynorsk
nov - Novial
nrm - Nouormand
nso - Northern Sotho
nv - Navajo
ny - Nyanja
oc - Occitan
olo - Livvi-Karelian
om - Oromo
or - Oriya
os - Ossetic
pa - Punjabi
pag - Pangasinan
pam - Pampanga
pap - Papiamento
pcd - Picard
pdc - Pennsylvania German
pdt - Plautdietsch
pfl - Palatine German
pi - Pali
pih - Norfuk / Pitkern
pl - Polish
pms - Piedmontese
pnb - Western Punjabi
pnt - Pontic
prg - Prussian
ps - Pashto
pt - Portuguese
pt-br - Brazilian Portuguese
qu - Quechua
qug - Chimborazo Highland Quichua
rgn - Romagnol
rif - Riffian
rm - Romansh
rmy - Romani
rn - Rundi
ro - Romanian
roa-tara - tarandíne
ru - Russian
rue - Rusyn
rup - Aromanian
ruq - Megleno-Romanian
ruq-cyrl - Megleno-Romanian (Cyrillic script)
ruq-latn - Megleno-Romanian (Latin script)
rw - Kinyarwanda
sa - Sanskrit
sah - Sakha
sat - Santali
sc - Sardinian
scn - Sicilian
sco - Scots
sd - Sindhi
sdc - Sassarese Sardinian
sdh - Southern Kurdish
se - Northern Sami
sei - Seri
ses - Koyraboro Senni
sg - Sango
sgs - Samogitian
sh - Serbo-Croatian
shi - Tachelhit
shi-latn - Tašlḥiyt
shi-tfng - ⵜⴰⵛⵍⵃⵉⵜ
si - Sinhala
sk - Slovak
sl - Slovenian
sli - Lower Silesian
sm - Samoan
sma - Southern Sami
sn - Shona
so - Somali
sq - Albanian
sr - Serbian
sr-ec - Serbian (Cyrillic script)
sr-el - Serbian (Latin script)
srn - Sranan Tongo
ss - Swati
st - Southern Sotho
stq - Saterland Frisian
su - Sundanese
sv - Swedish
sw - Swahili
szl - Silesian
ta - Tamil
tcy - Tulu
te - Telugu
tet - Tetum
tg - Tajik
tg-cyrl - Tajik (Cyrillic script)
tg-latn - Tajik (Latin script)
th - Thai
ti - Tigrinya
tk - Turkmen
tl - Tagalog
tly - Talysh
tn - Tswana
to - Tongan
tokipona - Toki Pona
tpi - Tok Pisin
tr - Turkish
tru - Turoyo
ts - Tsonga
tt - Tatar
tt-cyrl - Tatar (Cyrillic script)
tt-latn - Tatar (Latin script)
tum - Tumbuka
tw - Twi
ty - Tahitian
tyv - Tuvinian
tzm - Central Atlas Tamazight
udm - Udmurt
ug - Uyghur
ug-arab - Uyghur (Arabic script)
ug-latn - Uyghur (Latin script)
uk - Ukrainian
ur - Urdu
uz - Uzbek
uz-cyrl - ўзбекча
uz-latn - oʻzbekcha
ve - Venda
vec - Venetian
vep - Veps
vi - Vietnamese
vls - West Flemish
vmf - Main-Franconian
vo - Volapük
vot - Votic
vro - Võro
wa - Walloon
war - Waray
wo - Wolof
wuu - Wu Chinese
xal - Kalmyk
xh - Xhosa
xmf - Mingrelian
yi - Yiddish
yo - Yoruba
yue - Cantonese
za - Zhuang
zea - Zeelandic
zh - Chinese
zh-cn - Chinese (China)
zh-hans - Simplified Chinese
zh-hant - Traditional Chinese
zh-hk - Chinese (Hong Kong)
zh-mo - 中文(澳門)
zh-my - 中文(马来西亚)
zh-sg - Chinese (Singapore)
zh-tw - Chinese (Taiwan)
zu - Zulu
qqq - Message documentation
Format
Export for off-line translation
Export in native format
{{DISPLAYTITLE:Бібліотеки/Рецепти}}<languages/> {| class="wikitable" |- ! Назва !! Версія !! Ліцензія !! Джерело !! Мови !! Автор !! Іконка !! Опис |- <section begin=info /> | [[Special:MyLanguage/Libs/Prescriptions|Рецепти]] | 1.1, 1.1 || GPLv2 || OscadaLibs.db ([http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/OscadaLibs.sql SQL], [[:File:OscadaLibs.db.gz|GZip]]) > DAQ.tmplb_PrescrTempl<br/> vcaBase.db ([http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/vcaBase.sql SQL], [[:File:vcaBase.db.gz|GZip]]) > VCA.wlb_prescr | en, uk, ru <section end=info /> | [[User:RomanSavochenko|Роман Савоченко]] || [[file:LibPrescriptions.png]] | Бібліотека елементів сценаріїв технологічних процесів — рецептів. * '''Засновано:''' Вересень 2011 * '''Спонсоровано:''' Василь Григор'єв, [http://e-beam.ru Лабораторія Вакуумних Технологій] * '''Спонсоровано, щодо шаблонізації контролеру:''' Магомед, [https://www.savtech.ru SAVTECH] * '''Початково створено, для кадрів:''' у [http://wiki.oscada.org/HomePageEn/Using/GraphicElementsLibraries/MainElements старій Wiki] * '''Використано:''' [[Special:MyLanguage/Using/Vacuum_processing_unit|Автоматизована система управління вакуумною технологічною установкою]] * '''[[Special:MyLanguage/Works/To_do|Завдання (To Do)]]:''' <section begin=ToDo /> :- перевести елементи [[#GraphPart|графічної частини]] на повну роботу через [[#manager|менеджер рецептів]], для можливості віддаленого рознесення частин. <section end=ToDo /> |} Бібліотека створюється для надання середовища виконання сценаріїв технологічних процесів — рецептів, та кадрів користувацького інтерфейсу довкола нього, включно з [[#prescrEdit|кадром створення/редагування рецептів]] та двома кадрами контролю виконання та звітності — "[[#prescrRun|Рецепт — виконання]]" та "[[#prescrRunSimple|Рецепт — виконання, простий]]". Будується бібліотека на основі [[Special:MyLanguage/Modules/VCAEngine#WidgetPrimitives|примітивів віджетів]] та мови внутрішнього програмування [[Special:MyLanguage/Modules/JavaLikeCalc|JavaLikeCalc]], включно для шаблонів та команд. Назви елементів та їх параметрів доступні на мовах: Англійська, Українська та mRussian. Їх вихідний код написано у мово(людська)-незалежному режимі з викликом функції перекладу ''tr()'' та переклад цих повідомлень також доступний Англійською, Українською та mRussian. == {{Anch|Conception|Концепція}} == Сценарій технологічних операцій — рецепт, представляє собою послідовний виклик блоку функцій — команди, які приймають до п'яти аргументів та повертають рядок результату із кодом завершення на початку: "Робота (0)", "Завершено (>0)" та "Помилка (<0)". Виклик команди кроку здійснюється циклічно, доки повертається результат "Робота (0)". Перехід до наступного кроку здійснюється у випадку результату "Завершено (>0)" та команди "Пропуск (2)". У випадку помилки, результат "Помилка (<0)", виконання рецепту переривається. Послідовність команд, користувачем кінцевого інтерфейсу, формуються на [[#prescrEdit|кадрі створення/редагування]] та здійснюється контроль їх виконання на кадрі "[[#prescrRun|Рецепт — виконання]]" та "[[#prescrRunSimple|Рецепт — виконання, простий]]", при цьому, дані рецептів зберігаються у таблиці БД рецептів-програм. Таблиця програм-рецептів поміщається в одну з БД, доступних у конкретній конфігурації OpenSCADA, наприклад, на даний час така таблиця поміщається у БД цієї бібліотеки як "'''PrescrProgs = (<u>name</u>, prgTxt)'''", де: * ''name'' — назва рецепту-програми; * ''prgTxt'' — текст програми у вигляді XML-дерева. XML-дерево рецепту-програми починається із тегу-контейнеру "prg", який містить кінцеві теги команд "com" із атрибутами: * ''id'' — ідентифікатор-ім'я-тип команди у основі кроку; * ''name'' — особиста назва кроку, може бути відсутнє; * ''descr'' — особистий опис кроку, береться із відповідного поля команди та може бути відсутнє; * ''backgrnd'' — ознака виконання кроку у фоні, або послідовною групою кроків із цією ознакою; * ''arg{N}'' — визначені користувачем значення аргументів від 1 до 5. Наприклад, для рецепту із чотирма кроками матимемо: <syntaxhighlight lang="XML" style="margin-left: 20pt;"> <prg> <com arg1="10" id="Таймер" /> <com arg1="10" id="Вакуум" /> <com arg1="20" id="Таймер" /> <com arg1="34" id="Ввімкнути котушки" /> </prg></syntaxhighlight> Обчислення рецепту здійснюється через параметр [[#manager|менеджеру рецептів]], який підтримує два способи виконання команд рецепту: * '''команда-параметр''' — розташовані у вигляді параметрів контролеру [[Special:MyLanguage/Documents/DAQ#LogicLev|логічного рівня]] та з урахуванням їх контексту, якщо у менеджері рецептів вказано логічний контролер; * '''команда-макрос''' — безпосередньо у об'єкті менеджеру рецептів за командами, що зберігаються у таблиці "PrescrComs". {{CntHdr|Режим виконання "команда-параметр"}} Команди-параметри логічного рівня формуються програмістом SCADA-системи під прикладну область у вигляді [[Special:MyLanguage/Documents/Program_manual#DAQTmpl|шаблонів параметрів підсистеми "Збір даних"]], які надалі використовуються у логічному контролері рецептів, із низкою обов'язкових, службових та внутрішніх атрибутів: * ''rez'' — команда: результат виконання; команда має повертати рядок виду "'''{rezCode}:{TextMess}'''", де ''rezCode'' має стан: ** '''<0''' — помилка; ** '''=0''' — виконання; ** '''>0''' — виконання завершено; ** '''=10''' — виконання у фоні з вказівкою оновлювати статус виконання. * ''run'' — команда: виконання; * ''pause'' — команда: пауза, може бути призупинена від себе встановленням цього атрибуту у TRUE; * ''start'' — рецепт: запуск; * ''stop'' — рецепт: коректне завершення; * ''error'' — рецепт: завершення за помилкою; * ''abort'' — рецепт: переривання виконання оператором; * ''arg{1...5}'' — аргументи 1...5, у назві аргументу можливе визначення мінімальної та максимальної границі числового значення аргументу у вигляді "'''{назва}|{мін}|{макс}'''". Особливістю використання команд-параметрів є незалежне їх виконання та можливість залишити виконання низки команд у фоні, наприклад, регулятори. Ці команди, також, можна прямо підключати до джерела даних за допомогою зв'язків, або навіть реалізовувати їх обох у одному шаблоні-параметрі. [[file:at.png]] Цей режим наразі є основним та на основі нього було реалізовано багато механізмів взаємодії із кадрами візуалізації та контролю, які можуть не працювати, або працювати помилково зі старим "команда-макрос" режимом! {{CntHdr|Режим виконання "команда-макрос" (старий)}} Команди-макроси, які користувач може обирати при формуванні рецепту-програми, формуються програмістом SCADA-системи під прикладну область що реалізується, шляхом редагування таблиці команд у OpenSCADA. Таблиця команд поміщається в одній із БД, доступних у конкретній конфігурації OpenSCADA, наприклад, наразі така таблиця поміщається у БД даної бібліотеки як "'''PrescrComs = (<u>name</u>, proc, arg1, arg2, arg3, arg4, arg5)'''", де: * ''name'' — ім'я команди; * ''proc'' — текст процедури команди, у першому рядку містить назву мови програми, наразі це "JavaLikeCalc.JavaScript", та текст програми безпосередньо за мовою; у процедурі команди доступно наступні контекстні параметри: ** ''rez'' — результат виконання команди, по замовченню повертає "Робота" ("0:Очікування зараз ..."); ** ''f_start'' — ознака першого запуску процедури; ** ''f_frq'' — частота періодичних викликів процедури; ** ''arg{1...5}'' — значення аргументу 1...5; ** ''tmp{1...10}'' — значення тимчасового параметру (контекст обчислення) 1...10; ::Приклад тексту програми для команди "Таймер", який не залежить від прикладної області: <syntaxhighlight lang="JavaScript" style="margin-left: 40pt;"> JavaLikeCalc.JavaScript if(f_start) tmp1 = arg1; var curTm = tmp1.toReal(); if(curTm <= 0) { rez = "1:Час вичерпано для "+arg1+"с"; return; } curTm -= 1/f_frq; tmp1 = max(0, curTm); rez = "0:Очікування зараз "+curTm+"с";</syntaxhighlight> * ''arg{1...5}'' — мітка аргументу 1...5, лише аргументи із міткою буде відображено при редагуванні кроку рецепту; у мітці можливе визначення мінімальної та максимальної границі числового значення аргументу у вигляді "'''{назва}|{мін}|{макс}'''". Для спеціальних цілей зарезервовано декілька назв команд: * "Error" — викликається після виникнення помилки протягом виконання кроку рецепту; * "Stop" — викликається при зупинці рецепту, за нормального завершення рецепту та примусової зупинки користувачем. == Частина опрацювання та виконання == Розділ містить [[Special:MyLanguage/Documents/Program_manual#DAQTmpl|DAQ-шаблони менеджеру рецептів]] та команд режиму "команда-шаблон", які призначено до підключення у контролері логічного рівня, через створення відповідно параметрів менеджеру рецептів та команд, доступних до обрання користувачем, які і здійснюватимуть там всю роботу із рецептами-програмами щодо їх опрацювання та виконання. Для підключення частини бібліотеки до проекту станції OpenSCADA ви можете отримати файл БД як: * такий що постачається з готовим та відповідним пакетом дистрибутиву Linux на кшталт "openscada-libdb-main", "openscada-LibDB.Main"; * найбільш актуальний та безпосередньо отриманий з [http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/OscadaLibs.sql репозиторію subversion], перетворений у файл БД SQLite шляхом: <syntaxhighlight lang="BASH" style="margin-left: 15px"> wget http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/OscadaLibs.sql sqlite3 -init OscadaLibs.sql OscadaLibs.db .exit </syntaxhighlight> * завантаження [[:File:OscadaLibs.db.gz|прикріпленого тут]]. Цей завантажений файл Ви надалі можете розмістити у теці проекту станції та створити об'єкт бази даних модуля БД "SQLite", зареєструвавши файл бази даних у конфігурації. {| class="wikitable" <section begin=manager /> | {{Anch|manager|<h3>Менеджер рецептів ([[Special:MyLanguage/Libs/Prescriptions#manager|manager]])</h3>}} | 2.2 || GPLv2 || * || en, uk, ru <section end=manager /> | [[User:RomanSavochenko|Роман Савоченко]] |} [[File:LibsPrescriptionsManagerOp_uk.png|right|Результат та оперативні налаштування.]] Основний, представницький та уніфікований шаблон менеджеру та контролеру рецептів, їх опрацювання та прямого виконання у режимі "команда-макрос". Шаблон формує структуру параметру менеджеру рецептів, який може бути легко підключений до всіх кадрів цієї бібліотеки. Представницькою структурою менеджеру рецептів є: * "БД: Ім'я БД з таблицями ('''dbDB''')" — БД, на кшталт "SQLite.vcaBase", де зберігаються або мають зберігатися таблиці рецептів-програм. * "БД: Таблиця з програмами ('''dbProgs''')" — назва таблиці рецептів-програм, типово "PrescrProgs". * "Перелік команд ('''comLs''')" — перелік команд доступних до використання. * "Ім'я обраної програми ('''prog''')" — стан та встановлення назви обраної програми у обробці менеджером. * "Режим ('''mode''')", "Поточний режим ('''curMode''')" — встановлення та поточний режим менеджеру, виконання обраного рецепту-програми: Завершення(-2); Помилка(-1); Стоп(0); Виконання(1); Пауза(2); Пропустити команду(3). * "Час запуску ('''startTm''')" — час запуску у секундах. * "Поточна команда-крок ('''curCom''')" — поточна опрацьовувана команда. * "Робоча програма ('''work''')" — актуальна та опрацьовувана наразі програма у об'єкті. {{CntHdr|Функції}} * Формує "Перелік команд ('''comLs''')", доступних до використання у користувацьких рецептах-програмах. * Опрацьовує "Ім'я обраної програми ('''prog''')", зміна якої призводить до завантаження її послідовності команд до "Робоча програма ('''work''')" або створення нової програми. * Виконує програму у "Ім'я обраної програми ('''prog''')" після отримання команди "Виконання(1)" у "Режим ('''mode''')" та відзначає цей процес у: "Поточний режим ('''curMode''')", "Час запуску ('''startTm''')", "Поточна команда-крок ('''curCom''')" та "Робоча програма ('''work''')". * Генерує повідомлення дій протягом виконання рецепту щодо: : КАТЕГОРІЯ: визначає ідентифікатор користувацького рецепту-програми ''ProgNM'' у форматі "'''uprg{ProgNM}'''", де: :* "uprg*" — типовий шаблон-ознака користувацького рецепту-програми, який може бути безпосередньо використано у фільтрі категорії для визначення у повідомленнях суто користувацьких рецептів-програм; :* ''ProgNM'' — ім'я рецепту-програми. : ТЕКСТ: опис дії у форматі "'''{ActDescr} "{ProgNM}" : {StartTm} : {ActTm}'''", де: :* ''ActDescr'' — опис дії: ::* "Поточний вузол відсутній"; ::* "Перерваний користувачем сеанс програми"; ::* "Перерваний помилкою сеанс програми"; ::* "Вдалий сеанс програми". :* ''ProgNM'' — ім'я рецепту-програми; :* ''StartTm'' — час запуску рецепту-програми, у форматі "2020-03-14 16:05:01"; :* ''ActTm'' — час дії рецепту-програми, у форматі "2020-03-14 16:05:52". {{CntHdr|ВВ шаблону}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Режим !! Атрибут !! Конфігурація !! Значення |- | dbDB || БД: Ім'я БД з таблицями || Рядок || Вхід || Тільки читання || Константа || |- | dbComs || БД: Таблиця з командами || Рядок || Вхід || Не атрибут || Константа || PrescrComs |- | dbProgs || БД: Таблиця з програмами || Рядок || Вхід || Тільки читання || Константа || PrescrProgs |- | comsCntr || Контролер команд, <порожньо> - для команд у таблиці,<br/> '*' - цей параметр контролеру | Рядок || Вхід || Не атрибут || Константа || * |- | mode || Режим || Вибір цілих чисел || Вхід || Повний доступ || Змінна || -2 -2;-1;0;1;2;3 Завершення;Помилка;Стоп;Виконання;Пауза;Пропустити команду |- | curMode || Поточний режим || Вибір цілих чисел || Вхід || Тільки читання || Змінна || -2 -2;-1;0;1;2;3 Завершення;Помилка;Стоп;Виконання;Пауза;Пропустити команду |- | prog || Ім'я обраної програми || Рядок || Вхід || Повний доступ || Змінна || |- | startTm || Час запуску, секунди || Цілий || Вхід || Тільки читання || Змінна || |- | curCom || Поточна команда-крок || Рядок || Вхід || Тільки читання || Змінна || |- | work || Робоча програма || Об'єкт || Вхід || Тільки читання || Змінна || |- | comLs || Перелік команд || Об'єкт || Вхід || Тільки читання || Змінна || |- | clcCnt || Лічильник циклів || Цілий || Вхід || Не атрибут || Змінна || |- | this || Об'єкт || Об'єкт || Вхід || Не атрибут || Змінна || |- | f_err || Помилка функції || Рядок || Вхід || Не атрибут || Змінна || 0 |- | f_frq || Частота обчислення функції, Гц || Реальний || Вхід || Не атрибут || Змінна || 1000 |- | f_start || Прапорець запуску функції || Логічний || Вхід || Не атрибут || Змінна || 0 |- | f_stop || Прапорець зупинки функції || Логічний || Вхід || Не атрибут || Змінна || 0 |} [[File:LibsPrescriptionsManagerCfg_uk.png|right|Конфігурація.]] {{CntHdr|Конфігурація та використання}} :1. Створити та запустити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного контролеру]] з потрібними властивостями планування. :*['''JavaLikeCalc'''] або безпосередньо об'єкт [[Special:MyLanguage/Modules/JavaLikeCalc|JavaLikeCalc контролеру]]. :2. Створити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного параметру]] та обрати цей шаблон для нього. Ввімкнути параметр. :*['''JavaLikeCalc'''] або обрати цей шаблон для [[Special:MyLanguage/Modules/JavaLikeCalc|JavaLikeCalc контролеру]]; ввімкнути контролер; створити параметр "manager" віддзеркалення репрезентативних атрибутів: <pre style="white-space: pre-wrap; margin-left: 40pt;"> dbDB dbProgs comLs prog mode curMode startTm curCom work </pre> :3. У вкладці "Конфігурація шаблону" об'єкту логічного параметру, або контролеру для [JavaLikeCalc], ви маєте встановити: ::* ''БД: Ім'я БД з таблицями'' — у БД, на кшталт "SQLite.vcaBase", де зберігаються або мають зберігатися таблиці рецептів-програм. Порожнє значення не дозволене та викличе помилку! ::* ''БД: Таблиця з програмами'' — у назву таблиці рецептів-програм, по замовченню це "PrescrProgs". ::* ''Контролер команд'' — залишити у значенні по замовченню "*" для використання контролеру параметрів також для команд. Ви маєте змінити це поле у випадку виконання об'єкту контролера менеджеру у окремому від команд логічному контролері! :* ['''JavaLikeCalc'''] або та додатково: ::* ''Контролер команд'' — змінити це поле у окремий логічний контролер для команд! :* ['''Команда-макрос'''] або та додатково: ::* ''БД: Таблиця з командами'' — у назву таблиці команд, по замовченню це "PrescrComs". ::* ''Контролер команд'' — встановити '''<порожньо>'''. :4. Розташувати потрібні [[#LogicLevCommands|параметри команд]] разом із параметром менеджеру. :* ['''Команда-макрос'''] або підготувати потрібні команди у "БД: Таблиця з командами" згідно до [[#Conception|концепції]]; порожню таблицю команд має бути створено автоматично після запуску об'єкту параметру, або контролеру для [JavaLikeCalc]! :5. РЕЗУЛЬТАТ: Запустивши об'єкт контролеру (де створено цей параметр) маємо отримати оперативні дані у вкладці "Атрибути", для: перелік доступних команд, поточний режим, робоча програма, поточна команда-крок та час запуску. :* ['''JavaLikeCalc'''] або безпосередньо об'єкт контролеру [[Special:MyLanguage/Modules/JavaLikeCalc|JavaLikeCalc]]. :6. У процесі роботи, через вкладку оперативних даних "Атрибути", окрім отримання результату, можна здійснювати оперативне налаштування та контроль щодо: :* ''Ім'я обраної програми'' — встановлення назви обраної програми у обробці менеджером; :* ''Режим'' — встановлення режиму менеджеру, виконання обраного рецепту-програми: Завершення(-2); Помилка(-1); Стоп(0); Виконання(1); Пауза(2); Пропустити команду(3). === {{Anch|LogicLevCommands|Шаблони команд}} === {| class="wikitable" <section begin=timer /> | {{Anch|timer|<h4>Команда — Таймер ([[Special:MyLanguage/Libs/Prescriptions#timer|timer]])</h4>}} || 2.0 || GPLv2 || * || en, uk, ru <section end=timer /> | [[User:RomanSavochenko|Роман Савоченко]] |} [[File:LibsPrescriptionsTimer_uk.png|right|Результат та оперативні налаштування.]] Шаблон команди типового таймеру рецепту. Таймер розроблено лише для витримки часу між іншими дієвими кроками та для прикладу, відтак він містить лише один атрибут, це "Час" у секундах. {{CntHdr|ВВ шаблону}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Режим !! Атрибут !! Конфігурація !! Значення |- | start || Рецепт: старт || Логічний || Вхід || Повний доступ || Змінна || 0 |- | stop || Рецепт: стоп || Логічний || Вхід || Повний доступ || Змінна || 0 |- | error || Рецепт: помилка || Логічний || Вхід || Повний доступ || Змінна || 0 |- | abort || Рецепт: перервано || Логічний || Вхід || Повний доступ || Змінна || 0 |- | run || Команда: виконання || Логічний || Вхід || Повний доступ || Змінна || 0 |- | pause || Команда: пауза || Логічний || Вхід || Повний доступ || Змінна || 0 |- | rez || Команда: результат || Рядок || Вхід || Повний доступ || Змінна || 1 |- | arg1 || Час, секунд || Реальний || Вхід || Повний доступ || Змінна || |- | tmp1 || Тимчасово 1 || Реальний || Вихід || Не атрибут || Змінна || 0 |- | f_stop || Прапорець зупинки функції || Логічний || Вхід || Не атрибут || Змінна || 0 |- | f_frq || Частота обчислення функції, Гц || Реальний || Вхід || Не атрибут || Змінна || 1000 |- | f_err || Помилка функції || Рядок || Вхід || Не атрибут || Змінна || 0 |- | f_start || Прапорець запуску функції || Логічний || Вхід || Не атрибут || Змінна || 0 |} {{CntHdr|Конфігурація та використання}} :1. Створити та запустити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного контролеру]] з потрібними властивостями планування, або використати створений для [[#manager|менеджера рецепту]]. :2. Створити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного параметру]] та обрати цей шаблон для нього. Ввімкнути параметр. :3. РЕЗУЛЬТАТ: Запустивши маємо отримати оперативні дані у вкладці "Атрибути" для результату команди. :4. У процесі роботи, через вкладку оперативних даних "Атрибути", окрім отримання результату, можна здійснювати оперативне налаштування та контроль щодо [[#Conception|репрезентативних атрибутів команд рецепту]] та додаткових: :* ''Час'' — встановлення часу таймеру, у секундах. {| class="wikitable" <section begin=timer /> | {{Anch|timer|<h4>Команда — Фоновий таймер ([[Special:MyLanguage/Libs/Prescriptions#timer|timer]])</h4>}} || 2.0 || GPLv2 || * || en, uk, ru <section end=timer /> | [[User:RomanSavochenko|Роман Савоченко]] |} [[File:LibsPrescriptionsBackTimer_uk.png|right|Результат та оперативні налаштування.]] Шаблон команди фонового таймеру рецепту. Таймер розроблено лише для витримки часу у фоні для прикладу, відтак він містить лише один атрибут, це "Час" у секундах. {{CntHdr|ВВ шаблону}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Режим !! Атрибут !! Конфігурація !! Значення |- | start || Рецепт: старт || Логічний || Вхід || Повний доступ || Змінна || 0 |- | stop || Рецепт: стоп || Логічний || Вхід || Повний доступ || Змінна || 0 |- | error || Рецепт: помилка || Логічний || Вхід || Повний доступ || Змінна || 0 |- | abort || Рецепт: перервано || Логічний || Вхід || Повний доступ || Змінна || 0 |- | run || Команда: виконання || Логічний || Вхід || Повний доступ || Змінна || 0 |- | pause || Команда: пауза || Логічний || Вхід || Повний доступ || Змінна || 0 |- | rez || Команда: результат || Рядок || Вхід || Повний доступ || Змінна || 1 |- | arg1 || Час, секунд || Реальний || Вхід || Повний доступ || Змінна || |- | tmp1 || Тимчасово 1 || Реальний || Вихід || Не атрибут || Змінна || 0 |- | f_stop || Прапорець зупинки функції || Логічний || Вхід || Не атрибут || Змінна || 0 |- | f_frq || Частота обчислення функції, Гц || Реальний || Вхід || Не атрибут || Змінна || 1000 |- | f_err || Помилка функції || Рядок || Вхід || Не атрибут || Змінна || 0 |- | f_start || Прапорець запуску функції || Логічний || Вхід || Не атрибут || Змінна || 0 |} {{CntHdr|Конфігурація та використання}} :1. Створити та запустити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного контролеру]] з потрібними властивостями планування, або використати створений для [[#manager|менеджера рецепту]]. :2. Створити об'єкт [[Special:MyLanguage/Modules/LogicLev|логічного параметру]] та обрати цей шаблон для нього. Ввімкнути параметр. :3. РЕЗУЛЬТАТ: Запустивши маємо отримати оперативні дані у вкладці "Атрибути" для результату команди. :4. У процесі роботи, через вкладку оперативних даних "Атрибути", окрім отримання результату, можна здійснювати оперативне налаштування та контроль щодо [[#Conception|репрезентативних атрибутів команд рецепту]] та додаткових: :* ''Час'' — встановлення часу таймеру, у секундах. == {{Anch|GraphPart|Графічна частина}} == Містить елементи-кадри рецептів кінцевого типу та елементи-віджети, що призначені для розташування у розділі мнемосхем (вид відображення) дерева сторінок проекту, побудованого за [[Special:MyLanguage/Libs/Main_graphical_elements#RootPgSo|концепцією об'єктів сигналізації кореневої сторінки "RootPgSo"]] та для розташування на інших комплексних кадрах. Однак, елементи-кадри можуть бути розташовані як окремі сутності або у складі власної концепції керування сторінками, але тут треба враховувати, що кадри часто посилаються та викликають [[Special:MyLanguage/Libs/Main_graphical_elements#doc_panel|панель документів]]! Для підключення частини бібліотеки до проекту станції OpenSCADA ви можете отримати файл БД як: * такий що постачається з готовим та відповідним пакетом дистрибутиву Linux на кшталт "openscada-libdb-vca", "openscada-LibDB.VCA"; * найбільш актуальний та безпосередньо отриманий з [http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/vcaBase.sql репозиторію subversion], перетворений у файл БД SQLite шляхом: <syntaxhighlight lang="BASH" style="margin-left: 15px"> wget http://oscada.org/svn/trunk/OpenSCADA/data/LibsDB/vcaBase.sql sqlite3 -init vcaBase.sql vcaBase.db .exit </syntaxhighlight> * завантаження [[:File:vcaBase.db.gz|прикріпленого тут]]. Цей отриманий файл Ви надалі можете розмістити у теці проекту станції та створити об'єкт бази даних модуля БД "SQLite", зареєструвавши файл бази даних у конфігурації. {| class="wikitable" <section begin=prescrEdit /> | {{Anch|prescrEdit|<h3>Рецепт — редагування ([[Special:MyLanguage/Libs/Prescriptions#prescrEdit|prescrEdit]])</h3>}} | 1.3 || GPLv2 || * || en, uk, ru <section end=prescrEdit /> | [[User:RomanSavochenko|Роман Савоченко]] |} Кадр, представлений на рисунку 3.1, є одним із групи кадрів роботи із рецептами, який слугує для користувацького редагування рецептів-програм. Кадр загалом використовує та представляє представницьку структуру [[#manager|менеджеру рецептів]]. Кадр містить, зліва праворуч: * "Бібліотека" — бібліотека із переліком програм та елементами управління бібліотекою. * "Програма" — перелік кроків-команд обраного у бібліотеці рецепту-програми з елементами управління. * "Команда" — поле редагування обраного кроку рецепту у складі вибору команди та встановлення ім'я, опису, прапорця фонового виконання та значень доступних атрибутів, а також кнопки збереження змін. [[file:LibsPrescriptions_prescrEditD_uk.png|center|frame|Рис.3.1a. Кадр "Рецепт — редагування" у режимі розробки.]] {{CntHdr|Використання — розробка}} Кадр призначено для виконання ролі сторінки, а, відповідно, він має безпосередньо розташовуватися у дерево проекту. До кадру може бути підключено один параметр [[#manager|менеджеру рецептів]], шляхом встановлення зв'язків. {{CntHdr|Використання — виконання}} У режимі виконання користувач може додавати нові рецепти-програми, видаляти, копіювати та експортувати існуючі, а також імпортувати рецепти інших станцій OpenSCADA. У обраному рецепті-програмі користувач може виконати: додання або вставку нового кроку, видалення або зміну положення обраного кроку. Для обраного кроку рецепту-програми користувач може встановити команду та ввести ім'я, опис, прапорець фонового виконання та значення доступних аргументів обраної команди, після чого зберегти зміну кроку. Операції видалення супроводжуються появою [[Special:MyLanguage/Libs/Main_graphical_elements#accept|діалогу-вікна підтвердження]]. [[file:LibsPrescriptions_prescrEditR_uk.png|center|frame|Рис.3.1b. Кадр "Рецепт — редагування" у режимі виконання.]] {{CntHdr|Властивості зв'язування та конфігурації}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Конфігурація !! Конфігураційний шаблон |- | dbDB || БД: База даних || Рядок || Вхідний зв'язок || Controller|dbDB |- | dbProgs || БД: Таблиця програм || Рядок || Вхідний зв'язок || Controller|dbProgs |- | prExtComLs || Перелік доступних команд рецепту || Об'єкт || Вхідний зв'язок || Controller|comLs |} {| class="wikitable" <section begin=prescrRun /> | {{Anch|prescrRun|<h3>Рецепт — виконання ([[Special:MyLanguage/Libs/Prescriptions#prescrRun|prescrRun]])</h3>}} | 1.3 || GPLv2 || * || en, uk, ru <section end=prescrRun /> | [[User:RomanSavochenko|Роман Савоченко]] |} Кадр, представлений на рисунку 3.2, є одним із групи кадрів роботи із рецептами, який слугує для контролю та спостереження за виконанням програм-рецептів, раніш сформованих у кадрі "[[#prescrEdit|Рецепт — редагування]]". Кадр загалом використовує та представляє представницьку структуру [[#manager|менеджеру рецептів]]. Додатково до цього повноформатного кадру виконання рецептів, передбачено спрощений — "[[#prescrRunSimple|Рецепт — виконання, простий]]", який дозволяє компактно керувати та відстежувати виконання рецептів у складі інших кадрів технологічного процесу. Кадр містить, зліва праворуч: * "Запуск/зупинка/пропуск" — дві кнопки запуску та зупинки обраної програми, а також кнопка пропуску виконання поточного кроку. * "Бібліотека" — бібліотека із переліком програм. * "Програма" — документ переліку кроків-команд, обраного у бібліотеці рецепту-програми. При виконання у цьому полі відстежується поточний стан виконання шляхом відповідного підсвітлення кроків. [[file:LibsPrescriptions_prescrRunD_uk.png|center|frame|Рис.3.2a. Кадр "Рецепт — виконання" у режимі розробки.]] {{CntHdr|Використання — розробка}} Кадр призначено для виконання ролі сторінки, а, відповідно, він має безпосередньо розташовуватися у дерево проекту. До кадру може бути підключено один параметр [[#manager|менеджеру рецептів]], шляхом встановлення зв'язків. [[file:at.png]] Для можливості архівування завершених сеансів, доки оператор перемикається між іншим кадрам, необхідно, для цього повноформатного кадру у дереві проекту, встановити параметр "Стор.: обробляти не відкритою". За завершенням рецепту-програми відбувається генерація [[#manager|менеджером рецептів]] повідомлень із параметрами сеансу, а також архівування документу сеанса. Повідомлення із параметрами сеансу можуть бути використані або просто для перегляду історії сеансів, або-ж для формування переліку сеансів, наприклад, у [[Special:MyLanguage/Libs/Main_graphical_elements#grpGraph|групі графіків]] для переходу до історії на час сеансу. По замовченню [[Special:MyLanguage/Sub-projects/VCA#Document|архів звітів]] налаштовано на глубину 10 документів, що ви можете змінити встановлення атрибуту "Розмір архіву (n)" віджету документа. {{CntHdr|Використання — виконання}} У режимі виконання користувач може обрати потрібний рецепт-програму та запустити його на виконання, після чого відстежувати процес виконання або перейти до інших кадрів. Виконувану програму користувач може призупинити шляхом натиску кнопки "Пауза" у місці кнопки "Запуск" або перервати шляхом натиску кнопки "Зупинка". Крім цього, користувач може пропустити виконання поточного кроку, натиснувши кнопку "Пропустити". Також користувач може переглянути або роздрукувати звіти раніш виконуваних рецептів цього повноформатного кадру, для чого потрібно натиснути лівою клавишею миші на полі документу та погортати по архіву виконуваних рецептів, на [[Special:MyLanguage/Libs/Main_graphical_elements#doc_panel|панелі навігації]], що виникла праворуч. [[file:LibsPrescriptions_prescrRunR_uk.png|center|frame|Рис.3.2b. Кадр "Рецепт — виконання" у режимі виконання.]] {{CntHdr|Властивості зв'язування та конфігурації}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Конфігурація !! Конфігураційний шаблон |- | dbDB || БД: База даних || Рядок || Вхідний зв'язок || Controller|dbDB |- | dbProgs || БД: Таблиця програм || Рядок || Вхідний зв'язок || Controller|dbProgs |- | prExtCurCom || Контролер: поточна команда || Рядок || Вхідний зв'язок || Controller|curCom |- | prExtMode || Контролер: режим || Цілий || Повний зв'язок || Controller|mode |- | prExtProg || Контролер: програма || Рядок || Повний зв'язок || Controller|prog |- | prExtStartTm || Контролер: час запуску || Цілий || Вхідний зв'язок || Controller|startTm |- | prExtWork || Контролер: робочий || Об'єкт || Вхідний зв'язок || Controller|work |} {| class="wikitable" <section begin=prescrRunSimple /> | {{Anch|prescrRunSimple|<h3>Рецепт — виконання, простий ([[Special:MyLanguage/Libs/Prescriptions#prescrRunSimple|prescrRunSimple]])</h3>}} | 1.3 || GPLv2 || * || en, uk, ru <section end=prescrRunSimple /> | [[User:RomanSavochenko|Роман Савоченко]] |} Віджет, представлений на рисунку 3.3, це спрощений варіант кадру "[[#prescrRun|Рецепт — виконання]]", який розроблено для розташування як віджет мнемосхем та він переважно і працює доповненням кадру "[[#prescrRun|Рецепт — виконання]]". Кадр загалом використовує та представляє представницьку структуру [[#manager|менеджеру рецептів]]. Віджет містить, зліва праворуч та додолу: * "Запуск/зупинка/пропуск" — дві кнопки запуску та зупинки обраної програми, а також кнопка пропуску виконання поточного кроку. * "Бібліотека" — кнопка відображення поточного рецепту-програми та виклику [[Special:MyLanguage/Libs/Main_graphical_elements#treeSelect|діалогу обрання програми у дереві]]. * "Програма" — документ із рядками активних наразі команд. [[file:LibsPrescriptions_prescrRunSimple_uk.png|center|frame|Рис.3.3. Кадр "Рецепт — виконання, простий" у режимі розробки та виконання.]] {{CntHdr|Використання — виконання}} Цей віджет може бути використано розробником при створені мнемосхем з відображенням активності виконання рецептів та швидкого контролю ними. Для використання потрібно додати цей віджет на мнемосхему, підлаштувати горизонтальний, вертикальний розмір масштабом та підключити один параметр [[#manager|менеджеру рецептів]], шляхом встановлення зв'язків. {{CntHdr|Використання — виконання}} У режимі виконання користувач може обрати потрібний рецепт-програму, у [[Special:MyLanguage/Libs/Main_graphical_elements#treeSelect|діалозі обрання програми у дереві]] що з'являється за натиском кнопки рецепту, та запустити його на виконання, після чого відстежувати процес виконання або перейти до інших кадрів. Виконувану програму користувач може призупинити шляхом натиску кнопки "Пауза" у місці кнопки "Запуск" або перервати шляхом натиску кнопки "Зупинка". Крім цього, користувач може пропустити виконання поточного кроку, натиснувши кнопку "Пропустити". {{CntHdr|Властивості зв'язування та конфігурації}} {| class="wikitable" |- ! Ідентифікатор !! Ім'я !! Тип !! Конфігурація !! Конфігураційний шаблон |- | dbDB || БД: База даних || Рядок || Вхідний зв'язок || Controller|dbDB |- | dbProgs || БД: Таблиця програм || Рядок || Вхідний зв'язок || Controller|dbProgs |- | prExtCurCom || Контролер: поточна команда || Рядок || Вхідний зв'язок || Controller|curCom |- | prExtMode || Контролер: режим || Цілий || Повний зв'язок || Controller|mode |- | prExtProg || Контролер: програма || Рядок || Повний зв'язок || Controller|prog |- | prExtStartTm || Контролер: час запуску || Цілий || Вхідний зв'язок || Controller|startTm |- | prExtWork || Контролер: робочий || Об'єкт || Вхідний зв'язок || Controller|work |}
Navigation menu
OpenSCADA
Site
Download
Old Wiki
OpenSCADA Wiki
Home
About OpenSCADA
Functions and demands
Tasks
Using
Fund
Recent changes
Random page
Search
Tools
Special pages
Printable version
MediaWiki
Help
Personal tools
English
Log in