writeImage

Запишите изображение MATLAB в сообщение ROS изображений

Описание

пример

writeImage(msg,img) преобразует изображение MATLAB®, img, к объекту сообщения и хранилищам ROS совместимые данные изображения в объекте сообщения, msg. Сообщением должен быть 'sensor_msgs/Image' сообщение. 'sensor_msgs/CompressedImage' сообщения не поддержаны. Функция не выполняет преобразования цветового пространства, таким образом, img введите потребности иметь кодирование, которое вы задаете в свойстве Encoding сообщения.

writeImage(msg,img,alpha) преобразует изображение MATLAB, img, к объекту сообщения. Если кодирование изображений поддерживает альфа-канал (rgba или bgra семейство), задайте этот альфа-канал в alpha. В качестве альтернативы входное изображение может сохранить альфа-канал как свой четвертый канал.

Примеры

свернуть все

Считайте изображение.

image = imread('imageMap.png');

Создайте сообщение ROS изображений. Задайте кодировку по умолчанию для изображения. Запишите изображение в сообщение.

msg = rosmessage('sensor_msgs/Image');
msg.Encoding = 'rgb8';
writeImage(msg,image);

Входные параметры

свернуть все

'sensor_msgs/Image' Сообщение ROS изображений, заданное как Image указатель на объект. 'sensor_msgs/Image' сообщения изображений не поддержаны.

Отобразите, заданный как матрица, представляющая шкалу полутонов или изображение RGB или как m-by-n-by-3 массив, в зависимости от изображения датчика.

Альфа-канал, заданный как uint8 полутоновое изображение. Альфа должна быть одного размера и тип данных с img.

Советы

Необходимо задать правильное кодирование входного изображения в свойстве Encoding сообщения изображений. Если вы не задаете изображение, кодирующее прежде, чем вызвать функцию, кодировку по умолчанию, rgb8, используется (изображение RGB с 3 каналами с uint8 значениями). Функция не выполняет преобразования цветового пространства, таким образом, img введите потребности иметь кодирование, которое вы задаете в свойстве Encoding сообщения.

Все типы кодировки поддержаны для readImage также поддержаны в этой функции. Для получения дополнительной информации о поддерживаемых типах кодировки и их представительствах в MATLAB, смотрите readImage.

Закодированные Байером изображения (bayer_rggb8, bayer_bggr8, bayer_gbrg8, bayer_grbg8, и их 16-битные эквиваленты), должен быть дан как 8-битные или 16-битные одноканальные изображения, или они не кодируют.

Смотрите также

Введенный в R2019b