Color coded 3D scatterplot
A 3D scatter plot of a Cartesian data set is drawn. The data points are sorted by color and plot3 is called once for each group of points that map to the same color. This reduces execution time significantly for large data sets. By default the points are colored according to their distance from the XY plane. This can changed with the 'ColorData' property. Additionally the upper and lower limits of the color range can be specified. This is useful for creating a series of plots with the same coloring. 
The example plot is produced by the following code.
   figure('color','white');
   [x,y,z] = peaks(101);
   c = gradient(z);
   k = hypot(x,y)<3;
   plot3k({x(k) y(k) z(k)},                                      ...
      'Plottype','stem','FontSize',12,                           ...
      'ColorData',c(k),'ColorRange',[-0.5 0.5],'Marker',{'o',2}, ...
      'Labels',{'Peaks','Radius','','Intensity','Lux'});
Plot3k is based on plot3c by Uli Theune.
Cite As
Ken Garrard (2025). Color coded 3D scatterplot (https://in.mathworks.com/matlabcentral/fileexchange/9519-color-coded-3d-scatterplot), MATLAB Central File Exchange. Retrieved .
MATLAB Release Compatibility
Platform Compatibility
Windows macOS LinuxCategories
Tags
Acknowledgements
Inspired by: plot3c
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!Discover Live Editor
Create scripts with code, output, and formatted text in a single executable document.
| Version | Published | Release Notes | |
|---|---|---|---|
| 1.8.0.0 | Added a stem3 style with colored lines from the xy plane
 | ||
| 1.7.0.0 | This update excludes points with NaN color values from the plot. | ||
| 1.6.0.0 | Updated treatment of NextPlot property as suggested by Val. | ||
| 1.4.0.0 | Bug fix for 'ColorData', 'ColorRange' properties. | ||
| 1.3.0.0 | Optional arguments are property,value pairs. Input data can be a cell array, vector or matrix. | ||
| 1.1.0.0 | The color range and markersize arguments have been added. The figure handle is not returned unless an output argument is given. | ||
| 1.0.0.0 | 
