Перейти к содержанию

Навигация

SVG-Dashboards/en: различия между версиями

Нет описания правки
(Новая страница: «=== Read === Display values from the source in a text field.»)
 
(не показано 5 промежуточных версий этого же участника)
Строка 21: Строка 21:
Full-screen mode allows you to switch between panels through the side menu, and in HMI mode, you need to implement the switch yourself: add a button (object) with a URL to the desired panel in the SVG image.
Full-screen mode allows you to switch between panels through the side menu, and in HMI mode, you need to implement the switch yourself: add a button (object) with a URL to the desired panel in the SVG image.


<gallery mode="packed" heights="150px" caption="Режимы панелей">
<gallery mode="packed" heights="150px" caption="Panel modes">
Image: WebUI SVG.png | Standard view
Image: WebUI SVG.png | Standard view
Image: WebUI SVG fullscreen.png | Fullscreen
Image: WebUI SVG fullscreen.png | Fullscreen
Строка 247: Строка 247:
Please note that the names of the MQTT topics on both controllers must match. If this is not the case, svg elements will need to be attached to new MQTT topics.
Please note that the names of the MQTT topics on both controllers must match. If this is not the case, svg elements will need to be attached to new MQTT topics.


<div lang="ru" dir="ltr" class="mw-content-ltr">
=== Saving ===
=== Сохранение ===
Save the svg file and link description:
Сохраните svg-файл и описание связей:
# Download the file from the controller to your computer. To do this, click on the button with the image of a down arrow.
# Скачайте файл с контроллера на компьютер. Для этого нажмите на кнопку с изображением стрелки вниз.
# In the editor of the svg-panel, click the button '''As JSON''', copy and save the lines to a file.
# В редакторе svg-панели нажмите кнопку '''В виде JSON''', скопируйте и сохраните строки в файл.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
=== Loading ===
=== Загрузка ===
# Create a new SVG panel following the instructions in the [[#Creating an SVG panel| Creating an SVG panel]].
# Создайте новую SVG-панель по инструкции в разделе [[#Создание SVG-панели| Создание SVG-панели]].
# In the svg panel editor, click the '''As JSON''' button, copy the link description from the saved file and paste the text into the field
# В редакторе svg-панели нажмите кнопку '''В виде JSON''', скопируйте из сохраненного файла описание связей и вставьте текст в поле
# Click the '''Save'' button '' at the bottom of the page.
# Нажмите кнопку '''Сохранить''' внизу страницы.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
==Animation of SVG panel elements==
==Анимация элементов SVG-панели==
[[File:animation-svg.gif|598x|thumb|right| SVG panel element animation example]]
[[Файл:animation-svg.gif|598x|thumb|right| Пример анимации элемента SVG-панели]]
SVG panel elements can be animated using CSS.
Элементы SVG-панели можно анимировать с помощью CSS.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
To do this:
Для этого нужно:
#Draw an SVG panel in a vector editor like Inkscape.
#Нарисовать SVG-панель в векторном редакторе, например, Inkscape.
#Open the SVG file in a text editor and add a style block wrapped in tags<style></style> .
#Открыть файл SVG в текстовом редакторе и добавить блок стилей, заключенный в теги <code><style></style></code>.
#Add the '''@keyframes''' rule in the style block.
#В блоке стилей добавить правило '''@keyframes'''.
#Save the file and load it into the controller.
#Сохранить файл и загрузить его в контроллер.
#Go to the SVG panel editor in the controller's web interface.
#Перейти в редактор SVG-панели в веб-интерфейсе контроллера.
#Activate the '''Style''' parameter and set the property '''animation''' in the '''Value''' field. You also need to set the condition under which the animation will work.
#Активировать параметр '''Style''' и задать в поле '''Value''' свойство '''animation'''. Также нужно задать условие при котором анимация будет срабатывать.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
Rendering in CSS is done using the '''animation''' property and the '''@keyframes''' rule.  
Визуализация в CSS осуществляется с помощью свойства '''animation''' и правила '''@keyframes'''.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
'''@keyframes''', or keyframes, contain information about how the element should look at each point in time.
'''@keyframes''', или ключевые кадры, содержат информацию о том как должен выглядеть элемент в каждый из моментов времени.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
A rule containing two keyframes would look like this:
Правило содержащее два ключевых кадра будет выглядеть так:
<syntaxhighlight lang="css">  
<syntaxhighlight lang="css">
@keyframes <keyframe name> {
@keyframes <имя кейфрейма> {
from: { description of the initial state of the element }
from: { описание начального состояния элемента }
to: { description of the final state of the element }
to: { описание конечного состояния элемента }
}
}
</syntaxhighlight>
</syntaxhighlight>  
Здесь '''from''' и '''to''' ключевые слова обозначающие начальную и конечную точки анимации. Вместо них можно использовать 0% и 100%, а также добавить промежуточные значения.
Here '''from''' and '''to''' keywords denote the start and end points of the animation. Instead, you can use 0% and 100%, as well as add intermediate values.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
The keyframe name is an identifier by which the rule will be called from the style description.
Имя кейфрейма — идентификатор, по которому правило будет вызываться из описания стилей.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
In order for the animation to work, you need to set the element style to the '''animation''' property.
Чтобы анимация заработала нужно задать стилю элемента свойство '''animation'''.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
The '''animation''' property sets the animation action parameters (animation duration, repetition, direction, movement type, steps), and the '''@keyframes''' block sets the animation itself in steps (changes in appearance and position).
Свойство '''animation''' задаёт параметры действия для анимации (длительность анимации, повторение, направление, тип движения, шаги), а в блоке '''@keyframes''' задаётся сама анимация по шагам (изменения вида и положения).
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
Let's use an example to create an animation to change the text color from red to green and vice versa. Since text is filled in SVG, you will need to change the '''fill''' property.
Покажем на примере создание анимации для изменения цвета текста с красного на зеленый и обратно. Так как в SVG текст выполняется заливкой, то потребуется изменять свойство '''fill'''.
[[Image: animation-style.png |350px|thumb|right| The '''animation''' property is set in the '''Value''' field of the '''Style''' parameter ]]
[[Image: animation-style.png |350px|thumb|right| Свойство '''animation''' задается в поле '''Value''' параметра '''Style''' ]]
#Let's create a new SVG document in the Inlscape editor and add the Text element to it.  
#Создадим новый SVG-документ в редакторе Inlskape и добавим в него элемент Текст.  
#Let's save the file and open it in a text editor.
#Сохраним файл и откроем его в текстовом редакторе.
#Add a style block like this:
#Добавим блок style следующего вида:
#:<syntaxhighlight lang="html">  
#:<syntaxhighlight lang="html">
<style>
  <style>
@keyframes changecolor {
@keyframes changecolor {
   0% {fill:red}
   0% {fill:red}
Строка 322: Строка 301:
   }
   }
   </style>
   </style>
</syntaxhighlight>
</syntaxhighlight>  
#Сохраним SVG-файл и загрузим его в контроллер.
#Save the SVG file and load it into the controller.
#В редакторе дашбордов выберем созданным тестовый элемент и зададим ему свойство animation в следующем виде:
#In the dashboard editor, select the created test element and set its animation property in the following form:
#:<syntaxhighlight lang="javascript">
#:<syntaxhighlight lang="javascript">  
(val > 20) ? 'animation: changecolor 3s infinite linear;' : ' '
(val > 20) ? 'animation: changecolor 3s infinite linear;' : ' '
</syntaxhighlight>
</syntaxhighlight>  
#:Так как изменение стиля элемента может происходить только по условию, в котором участвует значение из MQTT топика, то мы выбрали топик '''CPU Temperature''' и задали условие '''>20'''. Это значит, что анимация будет работать, только когда значение топика '''CPU Temperature''' больше 20.  
#:Since the element style can only be changed by a condition involving a value from the MQTT topic, we chose the '''CPU Temperature''' topic and set the condition '''>20'''. This means that the animation will only work when the value of the '''CPU Temperature''' topic is greater than 20.  
#Сохраним дашборд и перейдем в просмотр.
#Save the dashboard and go to the view.
== Добавление внешних ссылок ==
== Add external links ==
[[Image: svg-hyperlink.png |300px|thumb|right| Создание ссылки в Inkscape ]]
[[Image : svg-hyperlink.png |300px|thumb|right| Creating a link in Inkscape ]]
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
The transition to external links is set at the stage of creating a picture in the Inkscape editor.
Переход по внешним ссылкам задаётся на этапе создания картинки в редакторе Inkscape.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
Create hyperlinks like this:
Создавать гиперссылки так:
# Select an element that will serve as a link, then in the context menu Create a link (hyperlink).
# Выбрать элемент, который будет служить ссылкой, далее в контекстном меню Создать ссылку (hyperlink).
# Insert a link into the opened field.
# Вставить в открывшееся поле ссылку.
# Save.
# Сохранить.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
Now it remains to load the image into the controller and check.
Теперь остаётся загрузить рисунок в контроллер и проверить.
</div>


<div lang="ru" dir="ltr" class="mw-content-ltr">
== Useful Links & Materials ==
== Полезные ссылки и материалы ==
* [[Media:Examples SVG-Dashboards.zip|SVG Dashboard Example Archive]]
* [[Media:Examples SVG-Dashboards.zip|Архив с примерами SVG-панелей]]
* [https://github.com/wirenboard/wb-dashboards- demo Sample panels in the wb-dashboards-demo repository]
* [https://github.com/wirenboard/wb-dashboards-demo Примеры панелей в репозитории wb-dashboards-demo]
* [https://support.wirenboard.com/t/vyvod-dannyh-v-vide-grafika-v-realnom-vremeni/13623/5 How to add to SVG panel link to a graph or another page]
* [https://support.wirenboard.com/t/vyvod-dannyh-v-vide-grafika-v-realnom-vremeni/13623/5 Как добавить в SVG-панель ссылку на график или другую страницу]
* [https://wirenboard.com/en/pages/wb-software/ Wiren Board Web Interface article]
* [https://wirenboard.com/ru/pages/wb-software/ Статья о веб-интерфейсе контроллера Wiren Board]
* [[Wiren Board Web Interface | Description of the controller web interface on the wiki]]
* [[Wiren Board Web Interface | Описание веб-интерфейса контроллера на вики]]
* [https://inkscape.org/en/ Free Inkscape SVG editor]
* [https://inkscape.org/ru/ Свободный SVG-редактор Inkscape]
</div>