yline

Горизонтальная линия с постоянным y-значением

Описание

пример

yline(y) создает горизонтальную линию в одной или нескольких y-координатах в текущей системе координат. Например, yline(2) создает линию в y=2.

пример

yline(y,LineSpec) задает стиль линии, цвет линии или обоих. Например, xline([12 20 33],'--b') создает три пунктирных синих линии.

пример

yline(y,LineSpec,labels) добавляют метки к линиям.

пример

yline(___,Name,Value) задает постоянные свойства линии с помощью одного или нескольких аргументов пары "имя-значение". Для списка свойств смотрите ConstantLine Properties. Задайте пары "имя-значение" после всех других входных параметров.

пример

yline(ax,___) создает линию в заданных осях вместо текущей системы координат. Определить использование текущей системы координат gca.

пример

yl = yline(___) возвращает ConstantLine возразите или массив ConstantLine объекты. Используйте yl изменить или запросить свойства линии после того, как это создается.

Примеры

свернуть все

Создайте горизонтальную линию в y = 2.5.

yline(2.5);

Figure contains an axes. The axes contains an object of type constantline.

Чтобы создать линию с меткой, необходимо также задать стиль линии. Стиль линии по умолчанию является сплошной линией, '-'.

fplot(@(x) log(x));
xlim([0 15]);
ylim([0 4]);
yline(3,'-','Threshold');

Figure contains an axes. The axes contains 2 objects of type functionline, constantline.

Задайте набор x и y векторы и строят их. Затем заполните ось Y дополнительным пространством выше и ниже максимальных и минимальных нанесенных на график значений.

x = 0:0.1:60;
y = 4.*cos(x)./(x+2);
plot(x,y)
ylim padded

Figure contains an axes. The axes contains an object of type line.

Найдите максимальные и минимальные значения y. Создайте горизонтальные линии в тех местоположениях с, маркирует 'Max' и 'Min'.

ymax = max(y);
ymin = min(y);
yline([ymax ymin],'--',{'Max','Min'})

Figure contains an axes. The axes contains 3 objects of type line, constantline.

Создайте синюю штрихпунктирную линию в y = 4.

yline(4,'-.b');

Figure contains an axes. The axes contains an object of type constantline.

Создайте горизонтальную пунктирную линию с меткой и заданной шириной линии.

x = -2:0.25:2;
[X,Y] = meshgrid(x);
Z = X.*exp(-X.^2-Y.^2);
contour(X,Y,Z,30)

yl = yline(0,'--','y = 0','LineWidth',3);

Figure contains an axes. The axes contains 2 objects of type contour, constantline.

Измените выравнивание по горизонтали метки и цвет линии.

yl.LabelHorizontalAlignment = 'center';
yl.Color = [.80 0 .40];

Figure contains an axes. The axes contains 2 objects of type contour, constantline.

Вызовите tiledlayout функция, чтобы создать 1 2 мозаичное размещение графика. Вызовите nexttile функция, чтобы создать объекты осей ax1 и ax2. Затем постройте в каждую из осей. Добавьте горизонтальную линию на первый график путем передачи ax1 к yline функция.

tiledlayout(1,2)
ax1 = nexttile;
x = -pi/2:pi/60:pi/2;
y1 = tan(sin(x)) + cos(sin(x)); 
plot(ax1,x,y1)

ax2 = nexttile;
x = -pi/2:pi/60:pi/2;
y2 = tan(cos(x)) + exp(x);
plot(ax2,x,y2)

yline(ax1,1.0);

Figure contains 2 axes. Axes 1 contains 2 objects of type line, constantline. Axes 2 contains an object of type line.

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

свернуть все

y- в виде скаляра или вектора, содержащего числовой, категориальный, datetime или значения длительности. Тип данных y должен совпадать с типом данных оси Y.

Пример: yline(10) отображает линию в y=10.

Пример: yline([13 20 33]) линии отображений в y=13, y=20, и y=33.

Типы данных: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | categorical | datetime | duration

Стиль линии, цвет и маркер задается как символ или строка символов. Символы могут появиться в любом порядке. Вы не должны задавать все три характеристики (стиль линии, маркер и цвет). Например, если вы не используете стиль линии и задаете маркер, затем график показывает только маркер и никакую линию.

Пример: '--or' красная пунктирная линия с круговыми маркерами

Стиль линииОписание
-Сплошная линия
--Пунктирная линия
:Пунктирная линия
-.Штрихпунктирная линия
МаркерОписание
'o'Круг
'+'Знак «плюс»
'*'Звездочка
'.'Точка
'x'Крест
'_'Горизонтальная линия
'|'Вертикальная линия
's'Квадрат
'd'Ромб
'^'Треугольник, направленный вверх
'v'Нисходящий треугольник
'>'Треугольник, указывающий вправо
'<'Треугольник, указывающий влево
'p'Пентаграмма
'h'Гексаграмма
ЦветОписание

y

желтый

m

пурпурный

c

голубой

r

красный

g

зеленый

b

синий

w

белый

k

черный

Целевые оси в виде Axes объект. Используйте этот аргумент, если вы хотите yline построить в осях кроме текущей системы координат.

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

Создайте метку для одной линии

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

ПредставлениеКак задать labelsПример
Одна линия текстаЗадайте вектор символов или строковый скаляр.

yline(12,'-','Sample')

A horizontal line in an axes with a label.

Многострочный текстЗадайте массив ячеек из символьных векторов или массив строк. Каждым элементом в массиве является различная линия текста.
yline(12,'-',{'Sample','x=12'})

A horizontal line in an axes with a label that has two lines of text.

Создайте метки для нескольких линий

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

ПредставлениеКак задать labelsПример
Одна разделяемая текстовая меткаЗадайте вектор символов или строковый скаляр.

yline([13 20 33],'-','Sample')

Three horizontal lines in an axes with matching labels.

Различные метки для каждой линииЗадайте массив ячеек из символьных векторов или массив строк. Каждым элементом в массиве является метка для различной линии. Число элементов в labels массив должен совпадать с длиной x.
label = {'Sample 1','Sample 2','Sample 3'};
yline([13 20 33],'-',label)

Three horizontal lines in an axes with different labels.

Различные метки с некоторыми многострочными меткамиСоздайте массив ячеек из символьных векторов или массив строк. Используйте sprintf функционируйте, чтобы вставить символы новой строки ('\n') в тексте.
label = {'Sample 1',sprintf('Sample 2\nx=20'),'Sample 3'};
yline([13 20 33],'-',label)

Three horizontal lines in an axes with different labels. The label for the second line has two lines of text.

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

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

Пример: yline(3,':','Median Price','LabelHorizontalAlignment','center') задает выравнивание по горизонтали метки как 'center'.

Примечание

Перечисленные здесь свойства являются только подмножеством. Для полного списка смотрите ConstantLine Properties.

Цвет линии в виде триплета RGB, шестнадцатеричного цветового кода, названия цвета или краткого названия.

Для пользовательского цвета задайте триплет RGB или шестнадцатеричный цветовой код.

  • Триплет RGB представляет собой трехэлементный вектор-строку, элементы которого определяют интенсивность красных, зеленых и синих компонентов цвета. Интенсивность должна быть в области значений [0,1]; например, [0.4 0.6 0.7].

  • Шестнадцатеричный цветовой код является вектором символов или строковым скаляром, который запускается с символа хеша (#) сопровождаемый тремя или шестью шестнадцатеричными цифрами, которые могут лежать в диапазоне от 0 к F. Значения не являются чувствительными к регистру. Таким образом, цветовые коды '#FF8800', '#ff8800', '#F80', и '#f80' эквивалентны.

Кроме того, вы можете задать имена некоторых простых цветов. Эта таблица приводит опции именованного цвета, эквивалентные триплеты RGB и шестнадцатеричные цветовые коды.

Название цветаКраткое названиеТриплет RGBШестнадцатеричный цветовой кодВнешний вид
'red''r'[1 0 0]'#FF0000'

'green''g'[0 1 0]'#00FF00'

'blue''b'[0 0 1]'#0000FF'

'cyan' 'c'[0 1 1]'#00FFFF'

'magenta''m'[1 0 1]'#FF00FF'

'yellow''y'[1 1 0]'#FFFF00'

'black''k'[0 0 0]'#000000'

'white''w'[1 1 1]'#FFFFFF'

'none'Не применяетсяНе применяетсяНе применяетсяНет цвета

Вот являются триплеты RGB и шестнадцатеричные цветовые коды для цветов по умолчанию использованием MATLAB® во многих типах графиков.

Триплет RGBШестнадцатеричный цветовой кодВнешний вид
[0 0.4470 0.7410]'#0072BD'

[0.8500 0.3250 0.0980]'#D95319'

[0.9290 0.6940 0.1250]'#EDB120'

[0.4940 0.1840 0.5560]'#7E2F8E'

[0.4660 0.6740 0.1880]'#77AC30'

[0.3010 0.7450 0.9330]'#4DBEEE'

[0.6350 0.0780 0.1840]'#A2142F'

Пример: 'g'

Пример: [0.6 0.2 0.5]

Пример: '#D2F9A7'

Ширина линии, заданная в виде положительного значения в точках.

Метка Legend в виде вектора символов или строкового скаляра. Легенда не отображается, пока вы не вызываете legend команда. Если вы не задаете текст, то legend устанавливает метку с помощью формы 'dataN'.

Выравнивание по горизонтали метки относительно линии в виде одной из опций в таблице.

ОпцияОписаниеПример
'right'Правая сторона линии

'left'Левая сторона линии

'center'Центр линии

Выравнивание по вертикали метки относительно линии в виде одной из опций в таблице.

ОпцияОписаниеПример
'top'Верхняя часть линии.

'middle'Середина линии. Метка сегментирует линию.

'bottom'Нижняя часть линии.

Пометьте ориентацию в виде 'aligned' или 'horizontal'. Примеры показывают в таблице.

ОриентацияОписаниеПример
'aligned'Метка имеет ту же ориентацию как заданная линия.

'horizontal'Метка является горизонталью, независимо от ориентации линии.

Алгоритмы

В 3-D представлении осей постоянная линия появляется в x-y плоскости в средней точке пределов оси z. Если оси вращаются, то постоянная линия вращается соответственно.

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

Функции

Свойства

Введенный в R2018b
Для просмотра документации необходимо авторизоваться на сайте