Evgenii Legotckoi
Evgenii Legotckoi07 квітня 2016 р. 12:07

Керування PTZ-камерою. Протокол Pelco-D

Pelco-D – це протокол управління PTZ-камерами, розроблений однойменною компанією Pelco. Як правило, використовується поверх інтерфейсу RS482/485 для зв'язку з відеокамерами, обладнаними сервоприводами.

Протокол Pelco-D має в арсеналі набір стандартних команд управління та розширений комплект команд. У статті розберемося, як працювати зі стандартним комплектом команд. Протокол Pelco-D розберемо з прикладу абстрактного джерела команд і абстрактного SDK, яке приймає повідомлення подальшої передачі їх у інтерфейс RS485. Це застереження зроблено навмисне, оскільки саме таке завдання нещодавно постало переді мною.

Таким чином є протокол, через який передаються дані, дані розбираються і далі передаються SDK, який вже відсилає повідомлення в тракт передачі RS485. Нижче наведено малюнок, на якому є жовтий квадрат. Саме в цій функції буде формуватися необхідне нам повідомлення, яке потрібно буде передати в SDK.


Структура повідомлення

Повідомлення протоколу Pelco-D складається з 7 байт. Розберемо значення кожного байта:

  1. Байт синхронізації - завжди має значення #FF у шістнадцятковому вигляді;
  2. Адреса - байт адреси PTZ-камери або іншого пристрою на лінії RS485/482;
  3. Команда 1 – перший байт стандартних команд Pelco-D;
  4. Команда 2 – другий байт стандартних команд Pelco-D;
  5. Дані 1 - байт швидкості повороту камери вправо/ліворуч, набуває значення від #00 до #3F;
  6. Дані 2 - байт швидкості нахилу камери вгору/вниз, набуває значення від #00 до #3F;
  7. Контрольна сума – є 8-бітною сумою байтів від 2-го до 6-го.

Стандартний комплект команд

Для передачі повідомлення необхідно сформувати обидві команди. Якщо дані не будуть передаватися, тоді необхідно буде встановити нульові значення бітів, відповідальних за той чи інший функціонал.

Розглянемо структуру команд.

Sense біт відповідає за смислове навантаження бітів 3 і 4. Якщо даний біт піднятий, то встановлені біти 3 і 4 відповідають за включення камери та автосканування відповідно, інакше підняті біти 3 і 4 відповідають за відключення. Біти 5 і 6 є зарезервованими і повинні бути встановлені в 0. Подальші налаштування відповідають за Діафрагму (Iris), Фокус (Focus), Зум (Zoom), Нахил (Tilt), Поворот (PAN). Для активації даних параметрів необхідно виставити відповідні біти в одиницю.

Приклади команд

Поворот ліворуч: FF 01 00 04 00 00 05
Поворот праворуч: FF 01 00 02 00 00 03
Нахил нагору: FF 01 00 08 00 00 09
Нахил вниз: FF 01 00 10 00 00 11
Зум +: FF 01 00 20 00 00 21
Зум -: FF 01 00 40 00 00 41

Приклад коду

У нашому абстрактному коді у вакуумі створилася така ситуація, що у функцію потрапляють такі значення:

  • адреса - адреса;
  • PanSpeed - швидкість з напрямком повороту, від - 100 до +100;
  • TiltSpeed - швидкість із напрямком нахилу, від -100 до +100;
  • ZoomSpeed - швидкість із напрямком Зуму, від -100 до +100. Навіщо так подавалися дані для Зума – це для мене питання, враховуючи, що у Pelco немає установки швидкості, але що є, тобто.

А ось SDK вже приймає сформовану команду у вигляді покажчика на масив даних та вказівкою довжини цього масиву. В результаті вийшов наступний код.

void ptzCmd(int addressPTZ, int panSpeed, int tiltSpeed, int zoomSpeed)
{
    unsigned char *dataPelco;
    unsigned char address, command1, command2, data1, data2, checkSum;
    address = command1 = command2 = data1 = data2 = checkSum = 0x00;

    dataPelco = (unsigned char*) malloc(7);
    memset(dataPelco,0,7);

    address = (unsigned char)addressPTZ;
    if(panSpeed < 0) {
        command2 |= 0x04;
        panSpeed *= (-1);
    } else if(panSpeed > 0) {
        command2 |= 0x02;
    }
    data1 = (unsigned char)panSpeed*63/100;

    if(tiltSpeed < 0) {
        command2 |= 0x10;
        tiltSpeed *= (-1);
    } else if(tiltSpeed > 0) {
        command2 |= 0x08;
    }
    data2 = (unsigned char)tiltSpeed*63/100;

    if(zoomSpeed < 0) {
        command2 |= 0x40;
    } else if(zoomSpeed > 0) {
        command2 |= 0x20;
    }
    checkSum = address + command1 + command2 + data1 + data2;
    checkSum %= 100;

    dataPelco[0] = 0xFF;
    dataPelco[1] = address;
    dataPelco[2] = command1;
    dataPelco[3] = command2;
    dataPelco[4] = data1;
    dataPelco[5] = data2;
    dataPelco[6] = checkSum;

    sdk_write_pelco_cmd(7, dataPelco); // 7 - это длина сообщения
    free(dataPelco);
}
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:84бали,
  • Рейтинг балів4
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:42бали,
  • Рейтинг балів-8
ОК

Qt - Тест 001. Сигналы и слоты

  • Результат:47бали,
  • Рейтинг балів-6
Останні коментарі
ИМ
Игорь Максимов22 листопада 2024 р. 11:51
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 жовтня 2024 р. 08:19
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов05 жовтня 2024 р. 07:51
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas505 липня 2024 р. 11:02
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Дмитрий
Дмитрий03 лютого 2025 р. 06:24
Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
NW
Nayo Wai30 січня 2025 р. 09:22
не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
n
nkly03 січня 2025 р. 02:52
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
Marsel16 серпня 2023 р. 14:26
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii Legotckoi24 червня 2024 р. 15:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.

Слідкуйте за нами в соціальних мережах