Примитивная объемная поверхностная диаграмма
surface(
создает примитив, трехмерную объемную поверхностную диаграмму. А графики функций значения в матрице X
,Y
,Z
)Z
как высоты над сеткой в плоскости x - y заданные X
и Y
. Цвет поверхности изменяется в зависимости от высот, заданных Z
.
В отличие от surf
function, примитив surface
функция не вызывает newplot
перед построением графика и не уважает значение NextPlot
свойство для рисунка или осей. Вместо этого он добавляет объемную поверхностную диаграмму к текущим системам координат, не удаляя другие графические объекты и не сбрасывая свойства осей.
surface(
создает примитивную объемную поверхностную диаграмму и использует индексы столбцов и строк элементов в Z
)Z
как x - и y - координаты.
surface(
графики в осях заданные ax
,___)ax
вместо текущей системы координат. Задайте оси в качестве первого входного параметра.
surface(___,
задает свойства поверхности, используя один или несколько аргументы пары "имя-значение". Для примера, Name,Value
)'FaceAlpha',0.5
создает полупрозрачную поверхность.
s = surface(___)
возвращает примитивный поверхностный объект графика. Использование s
для изменения поверхности после ее создания. Список свойств см. в разделе «Свойства поверхности».
Создайте три матрицы одинакового размера. Затем постройте график как поверхность. Поверхность использует Z
для высоты и цвета.
[X,Y] = meshgrid(1:0.5:10,1:20); Z = sin(X) + cos(Y); surface(X,Y,Z)
По умолчанию поверхность отображается в осях с помощью двумерного вида. Измените оси на трехмерный вид.
view(3)
Задайте цвета для объемной поверхностной диаграммы, включив четвертый матричный вход, C
. В сетчатый график используются Z
для высоты и C
для цвета. Задайте цвета с помощью палитры, которая использует одинарные числа для подставки цветов на спектре. Когда вы используете палитру, C
- тот же размер, что и Z
. Добавьте цветовую панель к графику, чтобы показать, как значения данных в C
соответствуют цветам в палитре и устанавливают вид графика на трехмерный вид по умолчанию.
[X,Y] = meshgrid(1:0.5:10,1:20); Z = sin(X) + cos(Y); C = X.*Y; surface(X,Y,Z,C) colorbar view(3)
Создайте полупрозрачную поверхность путем определения FaceAlpha
Пара "имя-значение" с 0.5
как значение. Чтобы разрешить дальнейшие изменения, присвойте объект поверхности переменной s
.
[X,Y] = meshgrid(-5:.5:5);
Z = Y.*sin(X) - X.*cos(Y);
s = surface(X,Y,Z,'FaceAlpha',0.5);
view(3)
Использование s
для доступа и изменения свойств объекта поверхности после создания. Например, скрыть ребра можно путем установки EdgeColor
свойство.
s.EdgeColor = 'none';
Создайте поверхность и отобразите изображение вдоль нее.
Создайте три матрицы одинакового размера.
[pX,pY,pZ] = peaks(25);
Загрузка набора данных, содержащего изображение Земли. Данные об изображении появляются в переменной рабочей области X
, и связанная палитра появляется в map
.
load earth
who
Your variables are: X map pX pY pZ
Создать объемную поверхностную диаграмму и отобразить изображение вдоль поверхности. Поскольку данные о поверхности pZ
и данные о цвете X имеют различные размеры, установите поверхность FaceColor
на 'texturemap'
. Установите вид графика на трехмерном виде по умолчанию.
surface(pX,pY,pZ,X,'FaceColor','texturemap', ... 'EdgeColor','none','CDataMapping','direct') colormap(map) view(3)
X
- x -координатыx -cordinates, заданная в виде матрицы того же размера, что и Z
, или как вектор с длиной n
, где [m,n] = size(Z)
. Если вы не задаете значения для X
и Y
, surface
использует векторы (1:n)
и (1:m)
.
Вы можете использовать meshgrid
функция для создания X
и Y
матрицы.
The XData
свойство Surface
объект сохраняет x -cordinates.
Пример: X = 1:10
Пример: X = [1 2 3; 1 2 3; 1 2 3]
Пример: [X,Y] = meshgrid(-5:0.5:5)
Типы данных: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
Y
- y -координатыy -cordinates, заданная в виде матрицы того же размера, что и Z
или как вектор с длиной m
, где [m,n] = size(Z)
. Если вы не задаете значения для X
и Y
, surface
использует векторы (1:n)
и (1:m)
.
Вы можете использовать meshgrid
функция для создания X
и Y
матрицы.
The YData
свойство объекта surface сохраняет y -cordinates .
Пример: Y = 1:10
Пример: Y = [1 1 1; 2 2 2; 3 3 3]
Пример: [X,Y] = meshgrid(-5:0.5:5)
Типы данных: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
Z
- z -координатыz -координаты, заданные как матрица. Z
должно иметь не менее двух строк и двух столбцов.
Z
задает высоту объемной поверхностной диаграммы в каждом x - y координате. Если вы не задаете цвета, то Z
также задает цвета поверхности.
The ZData
свойство объекта surface сохраняет z -cordinates .
Пример: Z = [1 2 3; 4 5 6]
Пример: Z = sin(x) + cos(y)
Типы данных: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
C
- Цветовой массивm
-by- n
-by- 3
массив триплетов RGBЦветовой массив, заданный как m
-by- n
матрица индексов палитры или как m
-by- n
-by- 3
массив триплетов RGB, где Z
является m
-by- n
.
Чтобы использовать цвета палитры, задайте C
как матрица. Для каждой точки сетки на поверхности, C
указывает цвет в палитре. The CDataMapping
свойство объекта поверхности управляет тем, как значения в C
соответствуют цветам в палитре.
Чтобы использовать цвета truecolor, задайте C
как массив триплетов RGB.
Для получения дополнительной информации смотрите Различия между Палитрами и Труеколором.
The CData
свойство объекта surface сохраняет цветовой массив. Для дополнительного контроля окрашивания поверхности используйте FaceColor
и EdgeColor
свойства.
ax
- Ось для построения графикаГрафическое изображение осей, заданное как axes
объект. Если вы не задаете оси, то surface
графики в текущей системе координат.
Задайте необязательные разделенные разделенными запятой парами Name,Value
аргументы. Name
- имя аргумента и Value
- соответствующее значение. Name
должны находиться внутри кавычек. Можно задать несколько аргументов в виде пар имен и значений в любом порядке Name1,Value1,...,NameN,ValueN
.
surface(X,Y,Z,'FaceAlpha',0.5,'EdgeColor','none')
создает полупрозрачную поверхность без нарисованных ребер.Примечание
Перечисленные здесь свойства являются только подмножеством. Полный список см. в разделе Свойств поверхности».
'EdgeColor'
- Цвет краевой линии[0 0 0]
(по умолчанию) | 'none'
| 'flat'
| 'interp'
| триплет RGB | шестнадцатеричный цветовой код | 'r'
| 'g'
| 'b'
| ...Цвет ребра, заданный как одно из значений, перечисленных здесь. Цвет по умолчанию [0 0 0]
соответствует чёрным ребрам.
Значение | Описание |
---|---|
'none' | Не рисуйте ребер. |
'flat' | Используйте другой цвет для каждого ребра на основе значений в |
'interp' |
Используйте интерполированную раскраску для каждого ребра на основе значений в
|
Триплет 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' |
Вот триплеты 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' |
'LineStyle'
- Стиль линии'-'
(по умолчанию) | '--'
| ':'
| '-.'
| 'none'
Стиль линии, заданный как одно из опций, перечисленных в этой таблице.
Стиль линии | Описание | Результирующая линия |
---|---|---|
'-' | Сплошная линия |
|
'--' | Штриховая линия |
|
':' | Пунктирная линия |
|
'-.' | Штрих-пунктирная линия |
|
'none' | Нет линии | Нет линии |
'FaceColor'
- Цвет лица'flat'
(по умолчанию) | 'interp'
| 'none'
| 'texturemap'
| триплет RGB | шестнадцатеричный цветовой код | 'r'
| 'g'
| 'b'
| ...Цвет грани, заданный как одно из значений в этой таблице.
Значение | Описание |
---|---|
'flat' | Используйте другой цвет для каждой грани на основе значений в |
'interp' |
Используйте интерполированную раскраску для каждой грани на основе значений в
|
Триплет RGB, шестнадцатеричный цветовой код или название цвета |
Используйте указанный цвет для всех граней. Эта опция не использует значения цветов в
|
'texturemap' | Преобразуйте данные о цвете в CData так, чтобы он соответствовал поверхности. |
'none' | Не рисуйте грани. |
Триплеты 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' |
Вот триплеты 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' |
'FaceAlpha'
- Прозрачность лица[0,1]
| 'flat'
| 'interp'
| 'texturemap'
Прозрачность лица, заданная в качестве одного из следующих значений:
Скаляр в области значений [0,1]
- Используйте равномерную прозрачность по всем граням. Значение 1
полностью непрозрачен и 0
полностью прозрачен. Значения между 0
и 1
являются полупрозрачными. Эта опция не использует значения прозрачности в AlphaData
свойство.
'flat'
- Используйте разную прозрачность для каждой грани на основе значений в AlphaData
свойство. Значение прозрачности в первой вершине определяет прозрачность для всей грани. Сначала необходимо задать AlphaData
свойство как матрица того же размера, что и ZData
свойство. The FaceColor
свойство также должно быть установлено в 'flat'
.
'interp'
- Используйте интерполированную прозрачность для каждой грани на основе значений в AlphaData
свойство. Прозрачность изменяется между каждой гранью путем интерполяции значений в вершинах. Сначала необходимо задать AlphaData
свойство как матрица того же размера, что и ZData
свойство. The FaceColor
свойство также должно быть установлено в 'interp'
.
'texturemap'
- Преобразуйте данные в AlphaData
так, чтобы он соответствовал поверхности.
'FaceLighting'
- Эффект световых объектов на гранях'flat'
(по умолчанию) | 'gouraud'
| 'none'
Эффект световых объектов на гранях, заданный как одно из следующих значений:
'flat'
- Нанесите свет равномерно на каждую грань. Используйте это значение для просмотра граненых объектов.
'gouraud'
- Варьируйте свет по граням. Вычислите свет в вершинах и затем линейно интерполируйте свет через грани. Используйте это значение для просмотра изогнутых поверхностей.
'none'
- Не наносить на грани свет от световых объектов.
Чтобы добавить светлый объект к осям, используйте light
функция.
Примечание
The 'phong'
значение удалено. Использование 'gouraud'
вместо этого.
У вас есть измененная версия этого примера. Вы хотите открыть этот пример с вашими правками?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.