drawfreehand

Создайте настраиваемый ROI от руки

Синтаксис

h = drawfreehand
h = drawfreehand(ax)
h = drawfreehand(___,Name,Value)

Описание

пример

h = drawfreehand начинает интерактивное размещение видимой области (ROI) от руки на текущей системе координат. Функция возвращает указатель на объект images.roi.Freehand. Можно изменить ROI в интерактивном режиме с помощью мыши. Объект ROI также поддерживает контекстное меню, которое управляет аспектами его внешнего вида и поведения.

h = drawfreehand(ax) начинает интерактивное размещение ROI в осях, заданных ax.

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

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

Примеры

свернуть все

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

imshow(imread('yellowlily.jpg'))

Чертите ROI от руки.

h = drawfreehand;

Заполните перед лицом ROI от руки и отключите способность выбрать ROI. ROI не перемещается, когда вы перетаскиваете мышь.

h.FaceAlpha = 1;
h.FaceSelectable = false;

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

свернуть все

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

Аргументы в виде пар имя-значение

Укажите необязательные аргументы в виде пар ""имя, значение"", разделенных запятыми. Имя (Name) — это имя аргумента, а значение (Value) — соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: h = drawfreehand('LineWidth',5);

Закройте ROI от руки, заданный как пара, разделенная запятой, состоящая из 'Closed' и логического значения true или false. Если true (значение по умолчанию), drawfreehand закрывает ROI путем соединения последнего waypoint, чертившего к первому чертившему waypoint.

Цвет ROI, заданный как пара, разделенная запятой, состоящая из 'Color' и значения MATLAB® ColorSpec (Color Specification).

Пример: 'green'

Пример: 'g'

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

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

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

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

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

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

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

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

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

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

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

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

Управляйте стилем рисунка от руки во время интерактивного размещения, заданного как пара, разделенная запятой, состоящая из 'Multiclick' и логического скалярного true или false. То, когда значением является false (значение по умолчанию), нажатие кнопки, и перетащите жест, завершает от руки. Когда true, несколько жестов перетаскивания могут быть объединены с прямыми ребрами, чтобы сделать более комплексную форму от руки.

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

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

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

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

Пример: 'green'

Пример: 'g'

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

Сглаживайте ребро ROI от руки с помощью стандартного отклонения Гауссова ядра сглаживания, заданного как пара, разделенная запятой, состоящая из 'Smoothing' и неотрицательного скаляра. Функция использует это значение 'Smoothing', чтобы отфильтровать x и координаты y ROI от руки. Функция задает размер фильтра как 2*ceil(2*Smoothing) + 1.

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

Пример: 'green'

Пример: 'g'

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

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

Контекстное меню, заданное как пара, разделенная запятой, состоящая из 'UIContextMenu' и объекта uicontextmenu. Задайте эту пару "имя-значение", чтобы отобразить пользовательское контекстное меню, когда вы щелкнете правой кнопкой по ROI. Можно создать пользовательское контекстное меню при помощи функции uicontextmenu и затем конфигурирующий свойства контекстного меню.

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

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

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

Контрольные точки, чтобы изменить ROI, заданный как пара, разделенная запятой, состоящая из 'Waypoints' и n-by-1 логический вектор, та же длина как Position. Каждый элемент вектора Waypoints указывает, является ли соответствующая точка в массиве Position waypoint. Положения, которые являются waypoints, установлены в true в Waypoints. Перетаскивание waypoint изменяет ROI между заданным waypoint и его мгновенным соседним waypoints. Если пустой, drawfreehand автоматически генерирует Waypoints в местоположениях увеличенного искривления.

Выходные аргументы

свернуть все

ROI от руки, возвращенный как объект images.roi.Freehand.

Советы

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

    ПоведениеГорячая клавиша
    Закончите чертить (близко) ROI.

    Щелкнуть правой кнопкой.

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

    Нажмите Enter.

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

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

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

    Удалите вершину (waypoint) из ROI.

    Расположите указатель на вершину, щелкните правой кнопкой, выберите Remove Waypoint из контекстного меню.

    Измените размер (изменяют) ROI.

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

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

    Переместите ROI.Расположите указатель на ROI. Указатель изменяется на форму fleur. Перетащите ROI.

Введенный в R2018b