scatter3
3-D scatter plot
Syntax
Description
Vector and Matrix Data
scatter3(___,
fills in the circles, using any of the input argument combinations in the previous syntaxes.'filled'
)
scatter3(___,
specifies the marker type.markertype
)
Table Data
scatter3(
plots the variablestbl
,xvar
,yvar
,zvar
)xvar
,yvar
, andzvar
from the tabletbl
。To plot one data set, specify one variable each forxvar
,yvar
, andzvar
。To plot multiple data sets, specify multiple variables for at least one of those arguments. The arguments that specify multiple variables must specify the same number of variables.(Since R2021b)
Additional Options
scatter3(
plots into the axes specified byax
,___)ax
instead of into the current axes (gca
). Theax
option can precede any of the input argument combinations in the previous syntaxes.
scatter3(___,
modifies the scatter plot using one or more name-value arguments to set properties. For example:Name,Value
)
scatter3(x,y,z,'LineWidth',2)
creates a scatter plot with 2-point marker outlines.scatter3(tbl,'MyX','MyY','MyZ','ColorVariable','MyColors')
creates a scatter plot from data in a table, and customizes the marker colors using data from the table.
For a full list of properties, seeScatter Properties。
Examples
Create 3-D Scatter Plot
Create a 3-D scatter plot. Usesphere
to define vectorsx
,y
, andz
。
figure [X,Y,Z] = sphere(16); x = [0.5*X(:); 0.75*X(:); X(:)]; y = [0.5*Y(:); 0.75*Y(:); Y(:)]; z = [0.5*Z(:); 0.75*Z(:); Z(:)]; scatter3(x,y,z)
Vary Marker Size
Usesphere
to define vectorsx
,y
, andz
。
[X,Y,Z] = sphere(16); x = [0.5*X(:); 0.75*X(:); X(:)]; y = [0.5*Y(:); 0.75*Y(:); Y(:)]; z = [0.5*Z(:); 0.75*Z(:); Z(:)];
Define vectors
to specify the marker sizes.
S = repmat([100,50,5],numel(X),1); s = S(:);
Create a 3-D scatter plot and useview
to change the angle of the axes in the figure.
figure scatter3(x,y,z,s) view(40,35)
Corresponding entries inx
,y
,z
, ands
determine the location and size of each marker.
Vary Marker Color
Usesphere
to define vectorsx
,y
, andz
。
[X,Y,Z] = sphere(16); x = [0.5*X(:); 0.75*X(:); X(:)]; y = [0.5*Y(:); 0.75*Y(:); Y(:)]; z = [0.5*Z(:); 0.75*Z(:); Z(:)];
Define vectorss
andc
to specify the size and color of each marker.
S = repmat([50,25,10],numel(X),1); C = repmat([1,2,3],numel(X),1); s = S(:); c = C(:);
Create a 3-D scatter plot and useview
to change the angle of the axes in the figure.
figure scatter3(x,y,z,s,c) view(40,35)
Corresponding entries inx
,y
,z
, andc
determine the location and color of each marker.
Fill in Markers
Create vectorsx
andy
as cosine and sine values with random noise.
z = linspace(0,4*pi,250); x = 2*cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);
Create a 3-D scatter plot and fill in the markers. Useview
to change the angle of the axes in the figure.
scatter3(x,y,z,'filled') view(-30,10)
Set Marker Type
Initialize the random-number generator to make the output ofrand
repeatable. Define vectorsx
andy
as cosine and sine values with random noise.
rngdefaultz = linspace(0,4*pi,250); x = 2*cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);
Create a 3-D scatter plot and set the marker type. Useview
to change the angle of the axes in the figure.
figure scatter3(x,y,z,'*') view(-30,10)
Set Marker Properties
Initialize the random-number generator to make the output ofrand
repeatable. Define vectorsx
andy
as cosine and sine values with random noise.
rngdefaultz = linspace(0,4*pi,250); x = 2*cos(z) + rand(1,250); y = 2*sin(z) + rand(1,250);
Create a 3-D scatter plot and set the marker edge color and the marker face color. Useview
to change the angle of the axes in the figure.
figure scatter3(x,y,z,。..'MarkerEdgeColor','k',。..'MarkerFaceColor',[0 .75 .75]) view(-30,10)
Plot Data from a Table
Since R2021b
A convenient way to plot data from a table is to pass the table to thescatter3
function and specify the variables you want to plot. For example, readpatients.xls
as a tabletbl
。Plot the relationship between theSystolic
,Diastolic
, andWeight
variables by passingtbl
as the first argument to thescatter3
function followed by the variable names. By default, the axis labels match the variable names.
tbl = readtable('patients.xls');scatter3(tbl,'Systolic','Diastolic','Weight');
You can also plot multiple variables at the same time. For example, plot both blood pressure variables on thex-axis by specifying thexvar
argument as the cell array{'Systolic','Diastolic'}
。Then add a legend. The legend labels match the variable names.
scatter3(tbl,{'Systolic','Diastolic'},'Age','Weight');传说
Plot Table Data with Custom Marker Sizes and Colors
Since R2021b
One way to plot data from a table and customize the colors and marker sizes is to set theColorVariable
andSizeData
properties. You can set these properties as name-value arguments when you call thescatter3
function, or you can set them on theScatter
object later.
例如,readpatients.xls
as a tabletbl
。Plot the relationship between theSystolic
,Diastolic
, andWeight
variables with filled markers. Vary the marker colors by specifying theColorVariable
name-value argument. Return theScatter
object ass
, so you can set other properties later.
tbl = readtable('patients.xls');s = scatter3(tbl,'Systolic','Diastolic','Weight','filled',。..'ColorVariable','Diastolic');
Change the marker sizes to 100 points by setting theSizeData
财产。Then add a colorbar.
s.SizeData = 100; colorbar
Specify Axes for 3-D Scatter Plot
Starting in R2019b, you can display a tiling of plots using thetiledlayout
andnexttile
functions.
Load theseamount
data set to get vectorsx
,y
, andz
。Call thetiledlayout
function to create a 2-by-1 tiled chart layout. Call thenexttile
function to create the axes objectsax1
andax2
。Then create separate scatter plots in the axes by specifying the axes object as the first argument toscatter3
。
loadseamounttiledlayout(2,1) ax1 = nexttile; ax2 = nexttile; scatter3(ax1,x,y,z,'MarkerFaceColor',[0 .75 .75]) scatter3(ax2,x,y,z,'*')
Set Scatter Series Properties Using Handle
Use thesphere
function to create vectorsx
,y
, andz
。
[X,Y,Z] = sphere(16); x = [0.5*X(:); 0.75*X(:); X(:)]; y = [0.5*Y(:); 0.75*Y(:); Y(:)]; z = [0.5*Z(:); 0.75*Z(:); Z(:)];
Create vectorss
andc
to specify the size and color for each marker.
S = repmat([70,50,20],numel(X),1); C = repmat([1,2,3],numel(X),1); s = S(:); c = C(:);
Create a 3-D scatter plot and return the scatter series object.
h = scatter3(x,y,z,s,c);
Use an RGB triplet color value to set the marker face color. Use dot notation to set properties.
h.MarkerFaceColor = [0 0.5 0.5];
Input Arguments
X
- - - - - -x-coordinates
scalar|vector|matrix
x-coordinates, specified as a scalar, vector, or matrix. The size and shape ofX
depends on the shape of your data. This table describes the most common situations.
Type of Plot | How to Specify Coordinates |
---|---|
Single point | Specify scatter3(1,2,3) |
One set of points | Specify X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z) |
Multiple sets of points that are different colors | If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the samex-coordinates. X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z) scatter3 plots a separate set of points for each column in the matrices.Alternatively, specify X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z) |
Data Types:单
|double
|int8
|int16
|int32
|int64
|uint8
|uint16
|uint32
|uint64
|categorical
|datetime
|duration
Y
- - - - - -y-coordinates
scalar|vector|matrix
y-coordinates, specified as a scalar, vector, or matrix. The size and shape ofy
depends on the shape of your data. This table describes the most common situations.
Type of Plot | How to Specify Coordinates |
---|---|
Single point | Specify scatter3(1,2,3) |
One set of points | Specify X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z) |
Multiple sets of points that are different colors | If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the samex-coordinates. X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z) scatter3 plots a separate set of points for each column in the matrices.Alternatively, specify X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z) |
Data Types:单
|double
|int8
|int16
|int32
|int64
|uint8
|uint16
|uint32
|uint64
|categorical
|datetime
|duration
Z
- - - - - -z-coordinates
scalar|vector|matrix
z-coordinates, specified as a scalar, vector, or matrix. The size and shape ofZ
depends on the shape of your data. This table describes the most common situations.
Type of Plot | How to Specify Coordinates |
---|---|
Single point | Specify scatter3(1,2,3) |
One set of points | Specify X = [1 2 3 4]; Y = [5; 6; 7; 8]; Z = [9 10 11 12]; scatter3(X,Y,Z) |
Multiple sets of points that are different colors | If all the data sets share coordinates in one or more dimensions, specify the shared coordinates as a vector and the other coordinates as matrices. The length of the vector must match one of the dimensions of the matrices. For example, plot two data sets that share the samex-coordinates. X = [1 2 3 4]; Y = [4 5 6 7; 8 9 10 11]; Z = [10 11 12 13; 14 15 16 17]; scatter3(X,Y,Z) scatter3 plots a separate set of points for each column in the matrices.Alternatively, specify X = [1 3 5 6; 2 4 6 8]; Y = [10 25 45 61; 20 40 60 70]; Z = [12 5 6 8; 9 13 2 7]; scatter3(X,Y,Z) |
Data Types:单
|double
|int8
|int16
|int32
|int64
|uint8
|uint16
|uint32
|uint64
|categorical
|datetime
|duration
S
- - - - - -Marker size
36(default) |numeric scalar|row or column vector|matrix|[]
Marker size, specified as a numeric scalar, vector, matrix, or empty array ([]
). The size controls the area of each marker in points squared. An empty array specifies the default size of 36 points. The way you specify the size depends on how you specifyX
,Y
, andZ
and how you want the plot to look. This table describes the most common situations.
Marker Size | X ,Y , andZ |
S |
Example |
---|---|---|---|
Same size for all points |
Any valid combination of vectors or matrices described for |
Scalar |
Specify X = [1 2 3 4]; Y = [5 6 7 8; 9 10 11 12]; Z = [13 14 15 16; 17 18 19 20]; scatter3(X,Y,Z,100) |
Different size for each point |
Vectors of the same length |
|
Specify X = [1 2 3 4]; Y = [4 5 6 7]; Z = [8 9 10 11]; S = [80 150 700 50]; scatter3(X,Y,Z,S) Specify X = [1 2 3 4]; Y = [5 6 7 8]; Z = [9 10 11 12]; S = [80 30; 150 900; 50 500; 200 350]; scatter3(X,Y,Z,S) |
Different size for each point |
At least one of |
|
Specify X = [1 2 3 4]; Y = [1 6; 3 8; 2 7; 4 9]; Z = [2 8; 3 10; 4 7; 4 12]; S = [80 150 200 350]; scatter3(X,Y,Z,S) Specify X = [1 2 3 4]; Y = [1 6; 3 8; 2 7; 4 9]; Z = [10 11; 12 13; 14 15; 16 17]; S = [80 30; 150 900; 50 2000; 200 350]; scatter3(X,Y,Z,S) |
Data Types:单
|double
|int8
|int16
|int32
|int64
|uint8
|uint16
|uint32
|uint64
C
- - - - - -Marker color
color name|RGB triplet|matrix of RGB triplets|vector of colormap indices
标志的颜色,颜色名称,指定RGB triplet, matrix of RGB triplets, or a vector of colormap indices.
Color name — A color name such as
"red"
, or a short name such as"r"
。RGB triplet — A three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
; for example,[0.4 0.6 0.7]
。RGB triplets are useful for creating custom colors.Matrix of RGB triplets — A three-column matrix in which each row is an RGB triplet.
Vector of colormap indices — A vector of numeric values that is the same length as the
X
,Y
, andZ
vectors.
The way you specify the color depends on your preferred color scheme and whether you are plotting one set of coordinates or multiple sets of coordinates. This table describes the most common situations.
Color Scheme | How to Specify the Color | Example |
---|---|---|
Use one color for all the points. |
Specify a color name or a short name from the table below, or specify one RGB triplet. |
Plot one set of points, and specify the color as X = [1 2 3 4]; Y = [2 5 3 6]; Z = [10 6 4 7]; S = 50; scatter3(X,Y,Z,S,"red")
Plot two sets of points, and specify the color as red using the RGB triplet X = [1 2 3 4]; Y = [2 5 3 6]; Z = [2 5; 1 2; 8 4; 7 9]; S = 50; scatter3(X,Y,Z,S,[1 0 0]) |
Assign different colors to each point using a colormap. |
Specify a row or column vector of numbers. The numbers map into the current colormap array. The smallest value maps to the first row in the colormap, and the largest value maps to the last row. The intermediate values map linearly to the intermediate rows. If your plot has three points, specify a column vector to ensure the values are interpreted as colormap indices. You can use this method only when |
Create a vector C = [1 2 3 4]; X = [1 2 3 4]; Y = [1 0 6 2]; Z = [2 5 3 7]; S = 50; scatter3(X,Y,Z,S,C) colormap(gca,"winter")
|
fo创建一个自定义颜色r each point. |
Specify an m-by-3 matrix of RGB triplets, where m is the number of points in the plot. You can use this method only when |
Create a matrix C = [0 1 0; 1 0 0; 0.5 0.5 0.5; 0.6 0 1]; X = [1 2 3 4]; Y = [2 5 3 6]; Z = [10 6 4 7]; S = 50; scatter3(X,Y,Z,S,C) |
Create a different color for each data set. |
Specify an n-by-3 matrix of RGB triplets, where n is the number of data sets. You can use this method only when at least one of |
Create a matrix C = [1 0 0; 0.6 0 1]; X = [1 2 3 4]; Y = [5 6 7 8]; Z = [2 5; 1 2; 8 4; 11 9]; S = 50; scatter3(X,Y,Z,S,C) |
Color Names and RGB Triplets for Common Colors
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
'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' |
|
“白色” |
'w' |
(1 1 1) |
'#FFFFFF' |
|
Here are the RGB triplets and hexadecimal color codes for the default colors MATLAB®uses in many types of plots.
RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|
[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' |
|
markertype
- - - - - -Marker
'o'
(default) |'+'
|'*'
|'.'
|'x'
| ...
Marker, specified as one of the markers in this table.
Marker | Description | Resulting Marker |
---|---|---|
'o' |
Circle |
|
'+' |
Plus sign |
|
'*' |
Asterisk |
|
'.' |
Point |
|
'x' |
Cross |
|
'_' |
Horizontal line |
|
'|' |
Vertical line |
|
's' |
Square |
|
'd' |
Diamond |
|
'^' |
Upward-pointing triangle |
|
'v' |
Downward-pointing triangle |
|
'>' |
Right-pointing triangle |
|
'<' |
Left-pointing triangle |
|
'p' |
Pentagram |
|
'h' |
Hexagram |
|
'none' |
No markers | Not applicable |
'filled'
- - - - - -Option to fill interior of markers
'filled'
Option to fill the interior of the markers, specified as'filled'
。Use this option with markers that have a face, for example,'o'
or'square'
。Markers that do not have a face and contain only edges do not draw ('+'
,'*'
,'.'
, and'x'
).
The'filled'
option sets theMarkerFaceColor
property of theScatter
object to'flat'
and theMarkerEdgeColor
property to'none'
, so the marker faces draw, but the edges do not.
tbl
- - - - - -Source table
table|timetable
Source table containing the data to plot, specified as a table or a timetable.
xvar
- - - - - -Table variables containingx-coordinates
one or more table variable indices
Table variables containing thex-coordinates, specified as one or more table variable indices.
Specifying Table Indices
Use any of the following indexing schemes to specify the desired variable or variables.
索引Scheme | Examples |
---|---|
Variable names:
|
|
Variable index:
|
|
Variable type:
|
|
Plotting Your Data
The table variables you specify can contain numeric, categorical, datetime, or duration values.
To plot one data set, specify one variable forxvar
, one variable foryvar
, and one variable forzvar
。例如,readPatients.xls
into the tabletbl
。Plot theHeight
,Weight
, andDiastolic
variables.
tbl = readtable('Patients.xls');scatter3(tbl,'Height','Weight','Diastolic')
To plot multiple data sets together, specify multiple variables for at least one ofxvar
,yvar
, orzvar
。If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.
例如,plot theWeight
variable on thex-axis, theSystolic
andDiastolic
variables on they-axis, and theAge
variable on thez-axis.
scatter3(tbl,'Weight',{'Systolic','Diastolic'},'Age')
You can also use different indexing schemes forxvar
,yvar
, andzvar
。例如,specifyxvar
as a variable name,yvar
as an index number, andzvar
as a logical vector.
scatter3(tbl,'Height',6,[false false true])
yvar
- - - - - -Table variables containingy-coordinates
one or more table variable indices
Table variables containing they-coordinates, specified as one or more table variable indices.
Specifying Table Indices
Use any of the following indexing schemes to specify the desired variable or variables.
索引Scheme | Examples |
---|---|
Variable names:
|
|
Variable index:
|
|
Variable type:
|
|
Plotting Your Data
The table variables you specify can contain numeric, categorical, datetime, or duration values.
To plot one data set, specify one variable forxvar
, one variable foryvar
, and one variable forzvar
。例如,readPatients.xls
into the tabletbl
。Plot theHeight
,Weight
, andDiastolic
variables.
tbl = readtable('Patients.xls');scatter3(tbl,'Height','Weight','Diastolic')
To plot multiple data sets together, specify multiple variables for at least one ofxvar
,yvar
, orzvar
。If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.
例如,plot theWeight
variable on thex-axis, theSystolic
andDiastolic
variables on they-axis, and theAge
variable on thez-axis.
scatter3(tbl,'Weight',{'Systolic','Diastolic'},'Age')
You can also use different indexing schemes forxvar
,yvar
, andzvar
。例如,specifyxvar
as a variable name,yvar
as an index number, andzvar
as a logical vector.
scatter3(tbl,'Height',6,[false false true])
zvar
- - - - - -Table variables containingz-coordinates
one or more table variable indices
Table variables containing thez-coordinates, specified as one or more table variable indices.
Specifying Table Indices
Use any of the following indexing schemes to specify the desired variable or variables.
索引Scheme | Examples |
---|---|
Variable names:
|
|
Variable index:
|
|
Variable type:
|
|
Plotting Your Data
The table variables you specify can contain numeric, categorical, datetime, or duration values.
To plot one data set, specify one variable forxvar
, one variable foryvar
, and one variable forzvar
。例如,readPatients.xls
into the tabletbl
。Plot theHeight
,Weight
, andDiastolic
variables.
tbl = readtable('Patients.xls');scatter3(tbl,'Height','Weight','Diastolic')
To plot multiple data sets together, specify multiple variables for at least one ofxvar
,yvar
, orzvar
。If you specify multiple variables for more than one argument, the number of variables must be the same for each of those arguments.
例如,plot theWeight
variable on thex-axis, theSystolic
andDiastolic
variables on they-axis, and theAge
variable on thez-axis.
scatter3(tbl,'Weight',{'Systolic','Diastolic'},'Age')
You can also use different indexing schemes forxvar
,yvar
, andzvar
。例如,specifyxvar
as a variable name,yvar
as an index number, andzvar
as a logical vector.
scatter3(tbl,'Height',6,[false false true])
ax
- - - - - -Axes object
axes object
Axes object. If you do not specify an axes, thenscatter3
plots into the current axes.
Name-Value Arguments
Specify optional pairs of arguments asName1=Value1,...,NameN=ValueN
, whereName
is the argument name andValue
is the corresponding value. Name-value arguments must appear after other arguments, but the order of the pairs does not matter.
Before R2021a, use commas to separate each name and value, and encloseName
in quotes.
Example:'MarkerFaceColor','red'
sets the marker face color to red.
The properties listed here are only a subset. For a complete list, seeScatter Properties。
LineWidth
- - - - - -Width of marker edge
0.5
(default) |positive value
Width of marker edge, specified as a positive value in point units.
Example:0.75
MarkerEdgeColor
- - - - - -Marker outline color
'flat'
(default) |RGB triplet|hexadecimal color code|'r'
|'g'
|'b'
| ...
Marker outline color, specified'flat'
, an RGB triplet, a hexadecimal color code, a color name, or a short name. The default value of'flat'
uses colors from theCData
财产。
For a custom color, specify an RGB triplet or a hexadecimal color code.
An RGB triplet is a three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
; for example,[0.4 0.6 0.7]
。A hexadecimal color code is a character vector or a string scalar that starts with a hash symbol (
#
) followed by three or six hexadecimal digits, which can range from0
toF
。The values are not case sensitive. Thus, the color codes'#FF8800'
,'#ff8800'
,'#F80'
, and'#f80'
are equivalent.
Alternatively, you can specify some common colors by name. This table lists the named color options, the equivalent RGB triplets, and hexadecimal color codes.
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
'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' |
|
“白色” |
'w' |
(1 1 1) |
'#FFFFFF' |
|
'none' |
Not applicable | Not applicable | Not applicable | No color |
Here are the RGB triplets and hexadecimal color codes for the default colors MATLAB uses in many types of plots.
RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|
[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' |
|
Example:[0.5 0.5 0.5]
Example:'blue'
Example:'#D2F9A7'
MarkerFaceColor
- - - - - -Marker fill color
'none'
(default) |'flat'
|'auto'
|RGB triplet|hexadecimal color code|'r'
|'g'
|'b'
| ...
Marker fill color, specified as'flat'
,'auto'
, an RGB triplet, a hexadecimal color code, a color name, or a short name. The'flat'
option uses theCData
values. The'auto'
option uses the same color as theColor
property for the axes.
For a custom color, specify an RGB triplet or a hexadecimal color code.
An RGB triplet is a three-element row vector whose elements specify the intensities of the red, green, and blue components of the color. The intensities must be in the range
[0,1]
; for example,[0.4 0.6 0.7]
。A hexadecimal color code is a character vector or a string scalar that starts with a hash symbol (
#
) followed by three or six hexadecimal digits, which can range from0
toF
。The values are not case sensitive. Thus, the color codes'#FF8800'
,'#ff8800'
,'#F80'
, and'#f80'
are equivalent.
Alternatively, you can specify some common colors by name. This table lists the named color options, the equivalent RGB triplets, and hexadecimal color codes.
Color Name | Short Name | RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|---|---|
'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' |
|
“白色” |
'w' |
(1 1 1) |
'#FFFFFF' |
|
'none' |
Not applicable | Not applicable | Not applicable | No color |
Here are the RGB triplets and hexadecimal color codes for the default colors MATLAB uses in many types of plots.
RGB Triplet | Hexadecimal Color Code | Appearance |
---|---|---|
[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' |
|
Example:[0.3 0.2 0.1]
Example:'green'
Example:'#D2F9A7'
ColorVariable
- - - - - -Table variable containing color data
table variable index
Table variable containing the color data, specified as a variable index into the source table.
Specifying the Table Index
Use any of the following indexing schemes to specify the desired variable.
索引Scheme | Examples |
---|---|
Variable name:
|
|
Variable index:
|
|
Variable type:
|
|
Specifying Color Data
Specifying theColorVariable
property controls the colors of the markers. The data in the variable controls the marker fill color when theMarkerFaceColor
property is set to'flat'
。The data can also control the marker outline color, when theMarkerEdgeColor
is set to'flat'
。
The table variable you specify can contain values of any numeric type. The values can be in either of the following forms:
A column of numbers that linearly map into the current colormap.
A three-column array of RGB triplets. RGB triplets are three-element vectors whose values specify the intensities of the red, green, and blue components of specific colors. The intensities must be in the range
[0,1]
。例如,[0.5 0.7 1]
specifies a shade of light blue.
When you set theColorVariable
property, MATLAB updates theCData
财产。
Output Arguments
h
- - - - - -Scatter
object
Scatter
object
Scatter
object. This is a unique identifier, which you can use to query and modify the properties of theScatter
object after it is created.
Extended Capabilities
GPU Arrays
Accelerate code by running on a graphics processing unit (GPU) using Parallel Computing Toolbox™.
Usage notes and limitations:
This function accepts GPU arrays, but does not run on a GPU.
For more information, seeRun MATLAB Functions on a GPU(Parallel Computing Toolbox)。
Distributed Arrays
Partition large arrays across the combined memory of your cluster using Parallel Computing Toolbox™.
Usage notes and limitations:
This function operates on distributed arrays, but executes in the client MATLAB.
For more information, seeRun MATLAB Functions with Distributed Arrays(Parallel Computing Toolbox)。
Version History
Introduced before R2006aR2022a: Plot multiple data sets at once using matrices
Thescatter3
function now accepts combinations of vectors and matrices for the coordinates. As a result, you can visualize multiple data sets at once rather than using thehold
function between plotting commands.
R2021b:通过直接表scatter3
Create plots by passing a table to thescatter3
function followed by the variables you want to plot. When you specify your data as a table, the axis labels and the legend (if present) are automatically labeled using the table variable names.
See Also
Functions
Properties
Open Example
You have a modified version of this example. Do you want to open this example with your edits?
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Select a Web Site
Choose a web site to get translated content where available and see local events and offers. Based on your location, we recommend that you select:。
You can also select a web site from the following list:
How to Get Best Site Performance
Select the China site (in Chinese or English) for best site performance. Other MathWorks country sites are not optimized for visits from your location.
Americas
- América Latina(Español)
- Canada(English)
- United States(English)
Europe
- Belgium(English)
- Denmark(English)
- Deutschland(Deutsch)
- España(Español)
- Finland(English)
- France(Français)
- Ireland(English)
- Italia(Italiano)
- Luxembourg(English)
- Netherlands(English)
- Norway(English)
- Österreich(Deutsch)
- Portugal(English)
- Sweden(English)
- Switzerland
- United Kingdom(English)