Скрипты позволяют программировать робота на выполнение определенных действий. Путь к папке со скриптами: /opt/promobot/share/promobot_scripts/scripts/3.1/ Скрипт представляет собой текстовый файл json формата, который может содержать в себе следующие модули: - arms
- neck
- torso
- drive
- eyes
- led
- play
- play_motion
- promo
- bash
Подсказка |
---|
Запуск модулей происходит параллельно. У каждой команды (command) должен быть уникальный id в рамках одного модуля |
Модуль arms: Предупреждение |
---|
Модуль arms не имеет встроенного ограничения. При выполнении скрипта робот может ударить сам себя. Для выполнения скриптов с использованием рук рекомендуется использовать сервис MSS |
Команда на движение руки представляет собой:
left5020306050000
}, {
Параметр | Описание | Значение |
---|
x0 | какая рука будет двигаться | left или right | x1 | скорость движения | int | x2 | направление движения руки вдоль туловища робота | int | x3 | направление движения руки от туловища робота | int | x4 | разворот руки в плече | int | x5 | сгибание локтя | int | x6 | разворот руки в локте | int | x7 | движение кисти | int | x8 | движение пальцев | int |
Модуль neck:Команда на движение головы представляет собой: Блок кода |
---|
"neck": [{"command": " | right5020 30 60 50 0 0 0 1
},{
Параметр | Описание | Значение |
---|
x0 | скорость движения | int | x1 | поворот головы вправо / влево | int | x2 | поворот головы вверх / вниз | int |
Модуль torso:Команда на движение торсом представляет собой: Блок кода |
---|
"torso": [{"command": " | sleep 2 2
},{
Параметр | Описание | Значение |
---|
x0 | скорость движения | int | x1 | наклон вперед / назад | int | x2 | наклон влево / вправо | int | x3 | движение вверх / вниз | int |
Модуль drive:Команда на езду представляет собой: Блок кода |
---|
"drive": [{"command": " | left 50 0 0 0 0 0 0 0 3
right50 100 50 0 50 70 0 0",
"id": 4
},{
Параметр | Описание | Значение |
---|
x0 | направление движения | forward , back , right , left
(left , right - поворот вокруг своей оси)
| x1 | скорость движения | int | x2 | время в секундах | int |
Предупреждение |
---|
Линейная скорость для команд forward и back задается в пределах: 0 - 1.0 (где 0.5 сопоставимо со скоростью с зажатой кнопкой B на джойстике, а 1.0 сопоставимо со скоростью с зажатой кнопкой A ). Угловая скорость для команд left и right задается в пределах: 0 - 5.0 (где 2.5 сопоставимо со скоростью с зажатой кнопкой B на джойстике, а 5.0 сопоставимо со скоростью с зажатой кнопкой A ). |
Модуль eyes:Команда на отправку эмоции представляет собой: Блок кода |
---|
"eyes": [{"command": " | sleep1 5
},{
Параметр | Значение |
---|
x0 | anger.gif | default.gif | heart.gif | laugh.gif | sad_wave.gif | scan.gif | smile.gif | sorrow.gif | surprise.gif | wink.gif |
Модуль led:Команда на изменение подсветки представляет собой: Блок кода |
---|
"led": [{"command": " | right50100503050700 0 6
},{
Параметр | Описание | Значение |
---|
x0 |
| sharp_blink – резкое мигание
sharp_on – резкое зажечь
sharp_off – резкое погасить
| smooth_blink – плавное мигание
smooth_on – плавно зажечь
smooth_off – плавно погасить
| x1 | время включения / отключения (не более 65 секунд) | int | x2 | кол-во циклов (для sharp_blink и smooth_blink ) | int | x3 | RGB цвет подсветки | в формате HEX, например, #FFFFFF | x4 | сектор (всего 9 секторов доступно) | int при передаче 0 горят все
| x5 | сохранять сектор подсвеченным в следующей итерации, или нет | boolean |
Модуль play:Команда на воспроизведение аудиофайла представляет собой: Блок кода |
---|
"play": [{"command": " | sleep1 7
right 50 100 50 -10 50 70 0 0 8
sleep 1 9
},{
Параметр | Описание | Значение |
---|
x0 | название аудиофайла с расширением | например, song.mp3 | x1 | время воспроизведения в секундах | int |
Предупреждение |
---|
Для корректного воспроизведения аудиофайла он должен находиться в /home/promobot/Music |
Модуль play_motion:Команда на запуск скрипта MSS: Блок кода |
---|
"play_motion": [{"command": " | right 50 100 50 30 50 70 0 0 10
1 11
},{
Параметр | Описание | Значение |
---|
x0 | название скрипта с расширением .yaml | например, script.yaml | x1 | время в секундах | int |
Команда на запуск промо-материала: Блок кода |
---|
"promo": [{"command": " | right 50 100 50 -10 50 70 0 0 12
1 13
},{
"command": "right 50 0 0 0 0 0 0 0",
"id": 12
},{
"command": "sleep 1",
"id": 13
},
Параметр | Описание | Значение |
---|
x0 | название изображения с расширением (image.jpg), либо ссылка на сайт (https://google.com) | например, image.jpg | x1 | время в секундах | int |
Предупреждение |
---|
Промо-материал отобразится, если робот будет запущен (нажата кнопка Play ). Файл с изображением должен находиться в /home/promobot/Pictures |
Модуль bash:Команда на запуск сторонних скриптов: Блок кода |
---|
"bash": [{"command": x0, "id": 0}] |
Параметр | Описание | Значение |
---|
x0 | путь к bash скрипту | например, "opt/promobot/share/promobot_scripts/scripts/3.1/UpVolume.sh" |
Предупреждение |
---|
Скрипт должен быть исполняемым |
Пример использования нескольких модулей в скрипте: Блок кода |
---|
| {
"parts": [{
"arms": [{
"command": " | left4030605014right4030605015216left80100-30508017right80100-30508018,{ "command": "sleep 2",
"id": 19
},#левая и правая руки примут заданное положение
# робот подождет 3 секунды, вернет руки в исходное положение
, {
"neck": [{
"command": " | left50 80 100 -30 50 80 020right 50 80 100 -30 0 80 0 021sleep 222,{ "command": "left 50 80 100 -30 0 80 0 0",
"id": 23
}, }
#робот наклонит голову вниз, подождет 3 секунды, вернет в исходное положение
, {
"torso": [{
"command": " | right5080 100 -30 50 80 24225left50 0 0 0 0100,{ "command": "right 50 0 0 0 0 0 0 0",
"id": 101
},#робот наклонится вперед, подождет 3 секунды, вернется в исходное положение
, {
"drive": [{
"command": " | left 50 20 30 60 50 0 0 0102right 50 20 30 60 50 0 0 0103sleep2104left50 0 0 0 0 0 0 0105,{ "command": "right 50 100 50 0 50 70 0 0",
"id": 106
},}
#робот поедет вперед в течение 1 секунды, в течение 1 секунды начнет крутиться против часовой стрелки
, {
"eyes": [{
"command": " | sleep1107right 50 100 50 30 50 70 0 0108,{ "command": "sleep 1",
"id": 109
},}
#на лице робота отобразятся сердечки
, {
"led": [{
"command": " | right5010050-105070 01101110,{ "command": "right 50 100 50 30 50 70 0 0",
"id": 111
},}
#уши робота загорятся красным цветом на 3 секунды
, {
"play": [{
"command": " | sleep1112right 50 100 50 -10 50 70 0 0113sleep 1114,{ "command": "right 50 0 0 0 0 0 0 0",
"id": 115
},}
#начнет воспроизводиться мелодия в течение 30 секунд
, {
"play_motion": [{
"command": " | sleep1116left 50 40 30 60 50 0 0 0117,{ "command": "right 50 40 30 60 50 0 0 0",
"id": 118
},#запустится скрипт MSS, который будет выполняться 60 секунд
, {
"promo": [{
"command": " | sleep2119left 50 80 0 -30 50 80 0 0120right 50 80 0 -30 50 80 0 0url https://google.com",
"id": | 1212122,{ "command": "left 50 80 100 -30 50 80 0 0",
"id": 123
}, }
#на экране отобразится картинка, через 5 секунд отобразится сайт
, {
"bash": [{
"command": " | right 50 80 100 -30 0 80 0 0/opt/promobot/share/promobot_scripts/scripts/3.1/UpVolume.sh",
"id": | 124,{ "command": "sleep 2",
"id": 125
},{
#выполнится скрипт UpVolume.sh
}]
} |
|