-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathplot_dot.m
executable file
·117 lines (103 loc) · 3.63 KB
/
plot_dot.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
function [pah,color_bar] = plot_dot(X,Y,C,C_lvl,dotsize,cmap,c_label,cborientation)
% plot_dot Plots colored dots based on Z value
%-------------------------------------------------------
% University of South Florida, Ocean Circulation Group
% Sage's Codar Processing Toolbox v1.0
%-------------------------------------------------------
% Usage:
% plot_dot(X,Y,C,C_lvl,dotsize,cmap,clabel,cborientation)
% Input:
% X,Y = Longitude/Latitude in decimal degrees
% Z = Depth
% C = Dot value
% C_lim = [Min Max] Limits for C
% c_label = Colorbar label (if left undefined
% colorbar is not generated)
% Output: None
% Updates:
% Written by Sage 6/25/2004
% Note:0 10 bins between the limits set in Z_lim are used
% to detemine color values for Z.
% C=C_lim(1) are ignored
% 2006-07-31 DG modified to plot 3-D data, Lon->X, Lat->Y
% 2006-09-18 DG added plotting data smaller than min and larger than max
% 2006-09-28 DG readopted for 2-D plotting
% 2007-12-19 DG minor change to plot label for colorbar & return plot axis
% 2008-02-28 DG fix colorbar plotting bug
% 2010-03-10 DG added cmap function
% 2011-10-09 DG added ability to choose custom colormap (2-D only, to be done for 3-D)
%-------------------------------------------------------
dbstop if error
if ~exist('dotsize')
dotsize = 10;
end %if
% Set up the colormap to use
if ~exist('cmap')
cmap = jet(256);
end %if
%cmap = hsv(256);
%cmap = cmap.^1.5;
hss = scatter([min(X(1)) min(X(end))],[min(Y(1)) min(Y(end))],1,[C_lvl(1) C_lvl(end)]);
colormap(cmap);
caxis([C_lvl(1) C_lvl(end)]);
pp = [];
k = 0;
delete(hss);
hs =[];
%% plot anything smaller than the specified range using the first color
minind = find(C<C_lvl(1));
if length(minind)>0
k = k+1;
pp(k)=plot(X(minind),Y(minind),'.','markersize',dotsize); hold on;
set(pp(k),'color',cmap(1,:));
end %if
%% plot data according to their indexed color
if length(C_lvl) == 2
ranges = [C_lvl(1) : (C_lvl(end)-C_lvl(1))/size(cmap,1) : C_lvl(end)];
else
ranges = C_lvl;
end %if
for ii=1:length(ranges)-1,
ind = find(C>ranges(ii) & C<=ranges(ii+1));
if length(ind)>0
k = k+1;
pp(k)=plot(X(ind),Y(ind),'.','markersize',dotsize); hold on;
set(pp(k),'color',cmap(ii,:));
end
end
%% plot anything larger than the specified range using the last color
maxind = find(C>C_lvl(end));
if length(maxind)>0
k = k+1;
pp(k)=plot(X(maxind),Y(maxind),'.','markersize',dotsize); hold on;
set(pp(k),'color',cmap(end,:));
end %if
pah = gca;
if exist('c_label')
% % Plot and Configure the Colorbar
% caxes=gca;
if exist('cborientation') ~= 1
color_bar=colorbar('horz');
set(color_bar,'fontsize',15,'fontweight','bold');
hx = xlabel(color_bar,c_label);
set(hx,'fontweight','bold','fontsize',16);
else
color_bar=colorbar('vert');
set(color_bar,'fontsize',15,'fontweight','bold');
hy = ylabel(color_bar,c_label);
set(hy,'fontweight','bold','fontsize',16,'rotation',270,'verticalalignment','baseline');
end %if
set(color_bar,'limits',[C_lvl(1) C_lvl(end)]);
% set(color_bar,'xlim',[1 64],'xtick',[1:63/10:64],'xticklabel',num2str([Z_lim(1):((Z_lim(2)-Z_lim(1))/10):Z_lim(2)]',precision));
% set(gcf,'currentaxes',color_bar);
% yla_cb = ylabel(c_label);
% set(yla_cb,'fontsize',10,'fontweight','bold');
% set(gca,'fontsize',10,'fontweight','bold');
% set(gcf,'currentaxes',caxes);
else
color_bar = [];
end % c_label
%caxis(C_lim)
caxis([C_lvl(1) C_lvl(end)]);
axes(pah);
%dbstop