рисование прямоугольника

Создайте настраиваемый прямоугольный ROI

Синтаксис

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

Описание

пример

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

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

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

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

Примеры

свернуть все

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

imshow(imread('baby.jpg'))

Чертите красный прямоугольный ROI с меткой 'OuterRectangle'.

r1 = drawrectangle('Label','OuterRectangle','Color',[1 0 0]);

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

r2 = drawrectangle('Label','InnerRectangle','DrawingArea',r1.Position);

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

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

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

h = drawrectangle('Position',[500,500,1000,1000],'StripeColor','r');

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

свернуть все

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

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

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

Пример: h1 = drawrectangle('LineWidth',5);

Соотношение сторон прямоугольника, заданного как пара, разделенная запятой, состоящая из 'AspectRatio' и неотрицательного числового скаляра, вычисленного как height/width. Это значение изменяется автоматически, когда вы чертите или изменяете размер ROI.

Цвет 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 не может получить нажатия кнопки.

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

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

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

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

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

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

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

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

Положение ROI, заданного как пара, разделенная запятой, состоящая из 'Position' и массив 1 на 4 формы [xmin, ymin, width, height]. xmin и ymin задают местоположение левого верхнего угла прямоугольника. width и height задают расширение к прямоугольнику в двух измерениях. Это значение изменяется автоматически, когда вы чертите или перемещаете ROI.

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

Угол вокруг центра прямоугольника, заданного как пара, разделенная запятой, состоящая из 'RotationAngle' и неотрицательного числового скаляра. Угол измеряется в градусах в направлении по часовой стрелке. Значение этого свойства изменяется автоматически, когда вы чертите или перемещаете ROI. Значение RotationAngle не влияет на значения в Position. Свойство Position представляет прямоугольник до любого вращения. Когда прямоугольник будет вращаться, используйте свойство Vertices определить местоположение вращаемого прямоугольника.

Состояние выбора 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, заданной как пара, разделенная запятой, состоящая из '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, возвращенного как пара, разделенная запятой, состоящая из 'Vertices' и n-by-2 массив.

Это свойство доступно только для чтения.

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

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

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

свернуть все

Прямоугольный ROI, возвращенный как объект images.roi.Rectangle.

Советы

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

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

    Указатель положения по вершине и затем перетаскивает. Прямоугольник имеет вершины в каждом углу и в средней точке каждой стороны. Чтобы сохранить соотношение сторон при изменении размеров, нажмите клавишу Shift. Чтобы заблокировать соотношение сторон, используйте Fix Aspect Ratio в контекстном меню щелчка правой кнопкой.

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

Введенный в R2018b