images.roi. Класс полигона

Пакет: images.roi

Многоугольная видимая область

Описание

Класс images.roi.Polygon задает многоугольную видимую область (ROI) по изображению. Вы вызываете метод draw объекта начать чертить ROI в интерактивном режиме при помощи вашей мыши.

Чтобы чертить ROI в интерактивном режиме, расположите указатель над осями, перетащите указатель, чтобы чертить ROI. Как вы разграничиваете, щелкните, чтобы создать вершину. Дважды кликните, чтобы закончить чертить и закрывать полигон. ROI поддерживает контекстное меню щелчка правой кнопкой, которое позволяет вам добавить вершину, удалить вершину или удалить целый ROI, в зависимости от того, где вы щелкаете правой кнопкой. Чтобы удалить ROI, расположите указатель на ROI, щелкните правой кнопкой и выберите Delete Polygon из контекстного меню. Для получения дополнительной информации об интерактивных поведениях включая горячие клавиши, смотрите Советы.

Класс images.roi.Polygon является классом handle.

Создание

Описание

пример

h = images.roi.Polygon создает экземпляр объекта images.roi.Polygon со свойствами по умолчанию.

h = images.roi.Polygon(ax) создает ROI в осях, заданных ax.

h = images.roi.Polygon(___,Name,Value) изменяет внешний вид и поведение ROI с помощью одной или нескольких пар "имя-значение", чтобы задать свойства. Можно установить свойства с помощью пар "имя-значение" с или не задавая ax.

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

развернуть все

Родительский элемент ROI, заданного как объект Axes.

Свойства

развернуть все

Общественные собственности

Цвет ROI, заданный как MATLAB® ColorSpec (Color Specification).

Пример: 'green'

Пример: 'g'

Пример: [0 1 0]

ROI может быть в интерактивном режиме удален через контекстное меню, заданное как true или false. Когда значением является true (значение по умолчанию), можно удалить ROI через контекстное меню. Чтобы отключить этот элемент контекстного меню, установите это свойство на false. Когда значение установлено к false, можно все еще удалить ROI путем вызывания функции delete определение указателя на ROI как вход.

Область осей, в которые можно в интерактивном режиме поместить ROI, заданный как одно из значений в этой таблице.

ЗначениеОписание
'auto'Областью рисунка являются пределы текущей системы координат (значение по умолчанию).
'unlimited'Область рисунка не имеет никакого контура, и КОРОЛИ могут чертиться или перетаскиваться, чтобы расширить вне пределов осей.
[x,y,w,h]Область рисунка ограничивается прямоугольной областью, начинающейся в (x, y), и расширяющей к ширине w и высота h.

Прозрачность поверхности ROI, заданной как значение числового скаляра в области значений [0 1]. Когда значением является 1, поверхность ROI полностью непрозрачна. Когда значением является 0, поверхность ROI абсолютно прозрачна.

Поверхность ROI может получить нажатия кнопки, заданные как true или false. Когда true (значение по умолчанию), поверхность ROI захватывает клики мыши. Когда false, поверхность ROI не захватывает клики мыши.

Видимость ROI обрабатывает в свойстве Children родительского элемента, заданного как одно из значений в этой таблице.

ЗначениеОписание
'on'Указатель на объект всегда видим (значение по умолчанию).
'off'Указатель на объект скрыт в любом случае.
'callback' Указатель на объект видим из коллбэков или функций, вызванных коллбэками, но не из функций, вызванных из командной строки.

Интерактивность ROI, заданного как одно из значений в этой таблице.

ЗначениеОписание
'all'ROI является полностью межигровым (значение по умолчанию).
'none'ROI не является межигровым, и никакие не перетаскивают точки, видимы.
'translate'ROI может быть переведен (перемещенный) в области рисунка, но не изменился. Это значение не доступно для использования с объектами images.roi.Point.
'reshape'ROI может быть изменен, но не переведен. Это значение не доступно для использования с объектами images.roi.Point или объектами images.roi.Rectangle.

Метка ROI, заданная как вектор символов или строка. По умолчанию ROI имеет, не маркируют ('').

Ширина ребра ROI, заданного в виде положительного числа в точках. Значение по умолчанию является три раза числом точек на экранный пиксель.

Родительский элемент ROI, заданный как объект Axes. UIAxes не может быть родительским элементом ROI.

Положение ROI, заданного как n-by-2 числовой массив формы [x1 y1; ...;xn yn], где каждая строка задает положение вершины полигона.

Состояние выбора ROI, заданного как логическое значение true или false. Можно также установить это свойство в интерактивном режиме. Например, нажатие на ROI выбирает ROI и устанавливает это свойство на true. Точно так же нажатие клавиши Ctrl и нажатие на ROI отменяют выбор ROI и устанавливают значение этого свойства к false.

Цвет ROI, когда выбрано, заданный как ColorSpec (Color Specification) MATLAB. Интенсивность должна быть в области значений [0,1]. Если 'SelectedColor' установлен в 'none', то значение Color задает цвет ROI для всех состояний, выбранных или нет.

Пример: 'green'

Пример: 'g'

Пример: [0 1 0]

Цвет дорожки ROI, заданной как значение ColorSpec (Color Specification) MATLAB. По умолчанию ребро ROI твердо окрашенный. Если вы задаете StripeColor, ребро ROI чередуется. Чередование состоит из комбинации значения, заданного 'Color' и этим значением.

Пример: 'green'

Пример: 'g'

Пример: [0 1 0]

Пометьте, чтобы сопоставить с ROI, заданным как вектор символов или строка. Используйте значение тега, чтобы найти объект ROI в иерархии объектов с помощью функции findobj.

Контекстное меню, заданное как объект ContextMenu. Используйте это свойство отобразить пользовательское контекстное меню, когда вы щелкнете правой кнопкой по ROI. Можно создать пользовательское контекстное меню при помощи функции uicontextmenu и затем конфигурирующий свойства контекстного меню.

Данные, чтобы сопоставить с ROI, заданным как любые данные MATLAB. Например, можно задать скаляр, вектор, матрицу, массив ячеек, строку, символьный массив, таблицу или структуру. MATLAB не использует эти данные.

Местоположения точек на ребре ROI, заданного как n-by-2 массив. Это свойство доступно только для чтения.

Видимость ROI, заданная как одно из значений в этой таблице.

ЗначениеОписание
'on'Отобразите ROI (значение по умолчанию).
'off'Скройте ROI, не удаляя его. Все еще можно получить доступ к свойствам невидимого ROI.

Методы

развернуть все

События

EventNameТриггерДанные о событияхАтрибуты события
DeletingROIROI собирается быть в интерактивном режиме удаленным.event.EventData

NotifyAccess: private

ListenAccess: public

DrawingStartedROI собирается в интерактивном режиме чертиться.event.EventData

NotifyAccess: private

ListenAccess: public

DrawingFinishedROI в интерактивном режиме чертился.event.EventData

NotifyAccess: private

ListenAccess: public

MovingROIФорма ROI или местоположение в интерактивном режиме изменяются.images.roi.ROIMovingEventData

NotifyAccess: private

ListenAccess: public

ROIMovedФорма ROI или местоположение были в интерактивном режиме изменены.images.roi.ROIMovingEventData

NotifyAccess: private

ListenAccess: public

ROIClickedПо ROI кликнули.images.roi.ROIClickedEventData

NotifyAccess: private

ListenAccess: public

AddingVertexВершина собирается быть в интерактивном режиме добавленной к ROI.event.EventData

NotifyAccess: private

ListenAccess: public

VertexAddedВершина была в интерактивном режиме добавлена к ROI.event.EventData

NotifyAccess: private

ListenAccess: public

DeletingVertexВершина собирается быть в интерактивном режиме удаленной из ROI.event.EventData

NotifyAccess: private

ListenAccess: public

VertexDeletedВершина была в интерактивном режиме удалена из ROI.event.EventData

NotifyAccess: private

ListenAccess: public

Примеры

свернуть все

Считайте изображение в рабочую область и отобразите ее.

I = imread('baby.jpg');
figure;
imshow(I)

Создайте многоугольный ROI на изображении, с помощью свойства Position задать вершины ROI. Обратите внимание на то, что необходимо задать оси, где вы хотите чертить ROI в качестве первого аргумента.

h = images.roi.Polygon(gca,'Position',[100 150; 200 250; 300 350; 150 450]);

Советы

  • ROI поддерживает следующую интерактивность, включая горячие клавиши.

    ПоведениеГорячая клавиша
    Заставьте проведенную линию огрызаться на 15 углов степени.Удержите клавишу Shift при рисовании.
    Закончите чертить (близко) ROI.

    Дважды кликните, который добавляет новую вершину в позиции указателя и чертит линию к первой вершине, чтобы закрыть полигон.

    Нажмите Enter, который добавляет новую вершину в позиции указателя и чертит линию к первой вершине, чтобы закрыть полигон.

    Щелкните правой кнопкой, который не добавляет новую вершину, но закрывает полигон от предыдущей вершины.

    Указатель положения по первой вершине и нажатию кнопки.

    Прекратите чертить ROI.Нажмите Esc. Функция возвращает допустимый объект ROI с пустым полем Position.
    Добавьте новую вершину к ROI.

    Расположите указатель над ребром ROI и дважды кликните.

    Расположите указатель над ребром ROI, щелкните правой кнопкой и выберите Add Vertex из контекстного меню.

    Удалите последний раз добавленную вершину, но продолжите чертить.Нажмите Backspace. Функция перерисовывает строку от предыдущей вершины до текущего положения указателя. Можно только отступить до первой вершины, которую вы чертили.
    Измените размер (изменяют) ROI

    Указатель положения по вершине и затем перетаскивает.

    Добавьте новую вершину к полигону и затем перетащите.

    Удалите вершину. ROI перерисовывает строку, соединяющую две соседних вершины.

    Переместите ROI.Расположите указатель над ROI. Наведите на ребро полигона (не на вершине). Указатель изменяется на форму fleur. Перетащите, чтобы переместить ROI.
  • Для получения информации об использовании ROI в приложении, созданном с App Designer, смотрите Используя КОРОЛЕЙ в Приложениях, Созданных с App Designer.

Введенный в R2018b