Mercurial > octave-nkf
annotate scripts/plot/appearance/__clabel__.m @ 17572:7bb76a22cde1
maint: Split scripts/plot directory into 4 pieces.
scripts/gui : user-interface functions
scripts/plot/appearance : functions controlling plot appearance
scripts/plot/draw : plotting functions which produce graphs
scripts/plot/util : low-level plotting functions and utilities.
* scripts/gui/guidata.m, scripts/gui/guihandles.m, scripts/gui/module.mk,
scripts/gui/private/__file_filter__.m,
scripts/gui/private/__fltk_file_filter__.m,
scripts/gui/private/__is_function__.m, scripts/gui/private/__uigetdir_fltk__.m,
scripts/gui/private/__uigetfile_fltk__.m,
scripts/gui/private/__uiobject_split_args__.m,
scripts/gui/private/__uiputfile_fltk__.m, scripts/gui/uicontextmenu.m,
scripts/gui/uicontrol.m, scripts/gui/uigetdir.m, scripts/gui/uigetfile.m,
scripts/gui/uimenu.m, scripts/gui/uipanel.m, scripts/gui/uipushtool.m,
scripts/gui/uiputfile.m, scripts/gui/uiresume.m, scripts/gui/uitoggletool.m,
scripts/gui/uitoolbar.m, scripts/gui/uiwait.m, scripts/gui/waitbar.m,
scripts/gui/waitforbuttonpress.m: Moved from scripts/plot to scripts/gui
* scripts/plot/appearance/__clabel__.m,
scripts/plot/appearance/__getlegenddata__.m, scripts/plot/appearance/axis.m,
scripts/plot/appearance/box.m, scripts/plot/appearance/caxis.m,
scripts/plot/appearance/clabel.m, scripts/plot/appearance/daspect.m,
scripts/plot/appearance/diffuse.m, scripts/plot/appearance/grid.m,
scripts/plot/appearance/gtext.m, scripts/plot/appearance/hidden.m,
scripts/plot/appearance/legend.m,
scripts/plot/appearance/orient.m, scripts/plot/appearance/pbaspect.m,
scripts/plot/appearance/private/__axis_label__.m,
scripts/plot/appearance/private/__axis_limits__.m,
scripts/plot/appearance/shading.m, scripts/plot/appearance/specular.m,
scripts/plot/appearance/text.m, scripts/plot/appearance/title.m,
scripts/plot/appearance/view.m, scripts/plot/appearance/whitebg.m,
scripts/plot/appearance/xlabel.m, scripts/plot/appearance/xlim.m,
scripts/plot/appearance/ylabel.m, scripts/plot/appearance/ylim.m,
scripts/plot/appearance/zlabel.m, scripts/plot/appearance/zlim.m:
Moved from scripts/plot to subdir appearance.
* scripts/plot/draw/area.m, scripts/plot/draw/bar.m, scripts/plot/draw/barh.m,
scripts/plot/draw/colorbar.m, scripts/plot/draw/comet.m,
scripts/plot/draw/comet3.m, scripts/plot/draw/compass.m,
scripts/plot/draw/contour.m, scripts/plot/draw/contour3.m,
scripts/plot/draw/contourc.m, scripts/plot/draw/contourf.m,
scripts/plot/draw/cylinder.m, scripts/plot/draw/ellipsoid.m,
scripts/plot/draw/errorbar.m, scripts/plot/draw/ezcontour.m,
scripts/plot/draw/ezcontourf.m, scripts/plot/draw/ezmesh.m,
scripts/plot/draw/ezmeshc.m, scripts/plot/draw/ezplot.m,
scripts/plot/draw/ezplot3.m, scripts/plot/draw/ezpolar.m,
scripts/plot/draw/ezsurf.m, scripts/plot/draw/ezsurfc.m,
scripts/plot/draw/feather.m, scripts/plot/draw/fill.m,
scripts/plot/draw/fplot.m, scripts/plot/draw/hist.m,
scripts/plot/draw/isocolors.m, scripts/plot/draw/isonormals.m,
scripts/plot/draw/isosurface.m, scripts/plot/draw/line.m,
scripts/plot/draw/loglog.m, scripts/plot/draw/loglogerr.m,
scripts/plot/draw/mesh.m, scripts/plot/draw/meshc.m, scripts/plot/draw/meshz.m,
scripts/plot/draw/pareto.m,
scripts/plot/draw/patch.m, scripts/plot/draw/pcolor.m,
scripts/plot/draw/peaks.m, scripts/plot/draw/pie.m, scripts/plot/draw/pie3.m,
scripts/plot/draw/plot.m, scripts/plot/draw/plot3.m,
scripts/plot/draw/plotmatrix.m, scripts/plot/draw/plotyy.m,
scripts/plot/draw/polar.m, scripts/plot/draw/private/__add_datasource__.m,
scripts/plot/draw/private/__bar__.m, scripts/plot/draw/private/__contour__.m,
scripts/plot/draw/private/__errcomm__.m,
scripts/plot/draw/private/__errplot__.m,
scripts/plot/draw/private/__ezplot__.m,
scripts/plot/draw/private/__interp_cube__.m,
scripts/plot/draw/private/__line__.m,
scripts/plot/draw/private/__marching_cube__.m,
scripts/plot/draw/private/__patch__.m, scripts/plot/draw/private/__pie__.m,
scripts/plot/draw/private/__plt__.m, scripts/plot/draw/private/__quiver__.m,
scripts/plot/draw/private/__scatter__.m, scripts/plot/draw/private/__stem__.m,
scripts/plot/draw/quiver.m, scripts/plot/draw/quiver3.m,
scripts/plot/draw/rectangle.m, scripts/plot/draw/ribbon.m,
scripts/plot/draw/rose.m, scripts/plot/draw/scatter.m,
scripts/plot/draw/scatter3.m, scripts/plot/draw/semilogx.m,
scripts/plot/draw/semilogxerr.m, scripts/plot/draw/semilogy.m,
scripts/plot/draw/semilogyerr.m, scripts/plot/draw/shrinkfaces.m,
scripts/plot/draw/slice.m, scripts/plot/draw/sombrero.m,
scripts/plot/draw/sphere.m, scripts/plot/draw/stairs.m,
scripts/plot/draw/stem.m, scripts/plot/draw/stem3.m,
scripts/plot/draw/stemleaf.m, scripts/plot/draw/surf.m,
scripts/plot/draw/surface.m, scripts/plot/draw/surfc.m,
scripts/plot/draw/surfl.m, scripts/plot/draw/surfnorm.m,
scripts/plot/draw/tetramesh.m, scripts/plot/draw/trimesh.m,
scripts/plot/draw/triplot.m, scripts/plot/draw/trisurf.m,
scripts/plot/draw/waterfall.m: Moved from plot/ to subdir draw.
* scripts/plot/util/__actual_axis_position__.m,
scripts/plot/util/__default_plot_options__.m,
scripts/plot/util/__gnuplot_drawnow__.m,
scripts/plot/util/__next_line_color__.m,
scripts/plot/util/__next_line_style__.m,
scripts/plot/util/__plt_get_axis_arg__.m, scripts/plot/util/__pltopt__.m,
scripts/plot/util/allchild.m, scripts/plot/util/ancestor.m,
scripts/plot/util/axes.m, scripts/plot/util/cla.m, scripts/plot/util/clf.m,
scripts/plot/util/close.m, scripts/plot/util/closereq.m,
scripts/plot/util/colstyle.m, scripts/plot/util/copyobj.m,
scripts/plot/util/figure.m, scripts/plot/util/findall.m,
scripts/plot/util/findfigs.m, scripts/plot/util/findobj.m,
scripts/plot/util/gca.m, scripts/plot/util/gcbf.m, scripts/plot/util/gcbo.m,
scripts/plot/util/gcf.m, scripts/plot/util/gco.m, scripts/plot/util/ginput.m,
scripts/plot/util/gnuplot_binary.in, scripts/plot/util/graphics_toolkit.m,
scripts/plot/util/hdl2struct.m, scripts/plot/util/hggroup.m,
scripts/plot/util/hold.m, scripts/plot/util/isaxes.m,
scripts/plot/util/isfigure.m, scripts/plot/util/ishghandle.m,
scripts/plot/util/ishold.m, scripts/plot/util/isprop.m,
scripts/plot/util/linkprop.m, scripts/plot/util/meshgrid.m,
scripts/plot/util/ndgrid.m,
scripts/plot/util/newplot.m, scripts/plot/util/print.m,
scripts/plot/util/printd.m, scripts/plot/util/private/__add_default_menu__.m,
scripts/plot/util/private/__fltk_ginput__.m,
scripts/plot/util/private/__fltk_print__.m,
scripts/plot/util/private/__ghostscript__.m,
scripts/plot/util/private/__gnuplot_get_var__.m,
scripts/plot/util/private/__gnuplot_ginput__.m,
scripts/plot/util/private/__gnuplot_has_feature__.m,
scripts/plot/util/private/__gnuplot_has_terminal__.m,
scripts/plot/util/private/__gnuplot_open_stream__.m,
scripts/plot/util/private/__gnuplot_print__.m,
scripts/plot/util/private/__gnuplot_version__.m,
scripts/plot/util/private/__go_draw_axes__.m,
scripts/plot/util/private/__go_draw_figure__.m,
scripts/plot/util/private/__print_parse_opts__.m,
scripts/plot/util/private/__tight_eps_bbox__.m, scripts/plot/util/refresh.m,
scripts/plot/util/refreshdata.m, scripts/plot/util/saveas.m,
scripts/plot/util/shg.m, scripts/plot/util/struct2hdl.m,
scripts/plot/util/subplot.m: Moved from plot to subdir util.
* etc/HACKING: Updated directory structure info.
* scripts/Makefile.am, scripts/plot/appearance/module.mk,
scripts/plot/draw/module.mk, scripts/plot/util/module.mk:
Added new directories to build system.
author | Rik <rik@octave.org> |
---|---|
date | Fri, 04 Oct 2013 17:09:08 -0700 |
parents | scripts/plot/private/__clabel__.m@576cf0589c6d |
children | d63878346099 |
rev | line source |
---|---|
14138
72c96de7a403
maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents:
11589
diff
changeset
|
1 ## Copyright (C) 2008-2012 David Bateman |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
2 ## |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
3 ## This file is part of Octave. |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
4 ## |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
5 ## Octave is free software; you can redistribute it and/or modify it |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
6 ## under the terms of the GNU General Public License as published by |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
7 ## the Free Software Foundation; either version 3 of the License, or (at |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
8 ## your option) any later version. |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
9 ## |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
10 ## Octave is distributed in the hope that it will be useful, but |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
11 ## WITHOUT ANY WARRANTY; without even the implied warranty of |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
12 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
13 ## General Public License for more details. |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
14 ## |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
15 ## You should have received a copy of the GNU General Public License |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
16 ## along with Octave; see the file COPYING. If not, see |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
17 ## <http://www.gnu.org/licenses/>. |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
18 |
8812
7d48766c21a5
use consistent format for doc strings of internal functions
John W. Eaton <jwe@octave.org>
parents:
8507
diff
changeset
|
19 ## -*- texinfo -*- |
7d48766c21a5
use consistent format for doc strings of internal functions
John W. Eaton <jwe@octave.org>
parents:
8507
diff
changeset
|
20 ## @deftypefn {Function File} {@var{h} =} __clabel__ (@var{c}, @var{v}, @var{hparent}, @var{label_spacing}, @var{z}, @var{varargin}) |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
21 ## Undocumented internal function. |
8812
7d48766c21a5
use consistent format for doc strings of internal functions
John W. Eaton <jwe@octave.org>
parents:
8507
diff
changeset
|
22 ## @end deftypefn |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
23 |
8507 | 24 function h = __clabel__ (c, v, hparent, label_spacing, z, varargin) |
17176
abf384f5d243
maint: Remove unneeded input validation from internal fcns in private/ directories.
Rik <rik@octave.org>
parents:
14868
diff
changeset
|
25 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
26 hax = ancestor (hparent, "axes"); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
27 units = get (hax, "units"); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
28 set (hax, "units", "points"); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
29 axpos = get (hax, "position"); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
30 set (hax, "units", units); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
31 lims = axis (); |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
32 xspacing = axpos(3) / (lims(2) - lims (1)); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
33 yspacing = axpos(4) / (lims(4) - lims (3)); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
34 |
14868
5d3a684236b0
maint: Use Octave coding conventions for cuddling parentheses in scripts directory
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
35 if (isscalar (hparent) && ishandle (hparent) |
11149
fe3c3dfc07eb
style fix: break lines before && and ||, not after
John W. Eaton <jwe@octave.org>
parents:
10549
diff
changeset
|
36 && strcmp (get (hparent, "type"), "hggroup")) |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
37 x = get (hparent, "xdata"); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
38 xmin = min (x(:)); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
39 xmax = max (x(:)); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
40 y = get (hparent, "ydata"); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
41 ymin = min (y(:)); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
42 ymax = max (y(:)); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
43 else |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
44 xmin = xmax = ymin = ymax = NaN; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
45 i = 1; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
46 while (i < length (c)) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
47 clen = c(2,i); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
48 data = c(:, i+(1:clen)); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
49 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
50 xmin = min ([xmin, data(1,:)]); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
51 xmax = max ([xmax, data(1,:)]); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
52 ymin = min ([ymin, data(2,:)]); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
53 ymax = max ([ymax, data(2,:)]); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
54 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
55 i += clen+1; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
56 endwhile |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
57 endif |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
58 |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
59 ## Decode contourc output format and place labels. |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
60 h = []; |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
61 i = 1; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
62 while (i < length (c)) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
63 clev = c(1,i); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
64 clen = c(2,i); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
65 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
66 if (! isempty (v) && ! any (v == clev)) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
67 i += clen+1; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
68 continue; |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
69 endif |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
70 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
71 p = bsxfun (@times, c(:, i+(1:clen)), [xspacing; yspacing]); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
72 d = sqrt (sumsq (diff (p, 1, 2))); |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
73 cumd = cumsum (d); |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
74 td = cumd(end); |
8507 | 75 ntag = ceil (td / label_spacing); |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
76 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
77 if (all (c(:,i+1) == c(:,i+clen))) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
78 ## Closed contour |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
79 ## FIXME: This spreads the tags uniformly around the contour which |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
80 ## looks nice, but it does not respect the label_spacing attribute. |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
81 ## Should we follow user input, which can result in two labels being |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
82 ## quite close to each other? |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
83 spacing = td / ntag; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
84 pos = spacing/2 + spacing*[0:ntag-1]; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
85 else |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
86 ## Open contour |
14868
5d3a684236b0
maint: Use Octave coding conventions for cuddling parentheses in scripts directory
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
87 pos = zeros (1, ntag); |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
88 pos(1) = (td - label_spacing*(ntag - 1)) / 2; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
89 pos(2:ntag) = pos(1) + label_spacing*[1:ntag-1]; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
90 endif |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
91 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
92 tlabel = sprintf ("%.5g", clev); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
93 |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
94 for tagpos = pos |
11587
c792872f8942
all script files: untabify and strip trailing whitespace
John W. Eaton <jwe@octave.org>
parents:
11523
diff
changeset
|
95 |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
96 j = find (cumd > tagpos, 1); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
97 if (isempty (j)) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
98 j = clen; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
99 endif |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
100 tpos = sum (c(:,i+j-1:i+j), 2) / 2; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
101 |
17176
abf384f5d243
maint: Remove unneeded input validation from internal fcns in private/ directories.
Rik <rik@octave.org>
parents:
14868
diff
changeset
|
102 if ( tpos(1) != xmin && tpos(1) != xmax |
abf384f5d243
maint: Remove unneeded input validation from internal fcns in private/ directories.
Rik <rik@octave.org>
parents:
14868
diff
changeset
|
103 && tpos(2) != ymin && tpos(2) != ymax) |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
104 trot = 180 / pi * atan2 (diff (c(2,i+j-1:i+j)), |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
105 diff (c(1,i+j-1:i+j))); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
106 if (abs (trot) > 90) |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
107 trot += 180; |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
108 endif |
10549 | 109 if (ischar (z)) |
11587
c792872f8942
all script files: untabify and strip trailing whitespace
John W. Eaton <jwe@octave.org>
parents:
11523
diff
changeset
|
110 ht = text (tpos(1), tpos(2), clev, tlabel, "rotation", trot, |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
111 "horizontalalignment", "center", "userdata", clev, |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
112 "parent", hparent, varargin{:}); |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
113 elseif (! isempty (z)) |
11587
c792872f8942
all script files: untabify and strip trailing whitespace
John W. Eaton <jwe@octave.org>
parents:
11523
diff
changeset
|
114 ht = text (tpos(1), tpos(2), z, tlabel, "rotation", trot, |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
115 "horizontalalignment", "center", "userdata", clev, |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
116 "parent", hparent, varargin{:}); |
10549 | 117 else |
118 ht = text (tpos(1), tpos(2), tlabel, "rotation", trot, | |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
119 "horizontalalignment", "center", "userdata", clev, |
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
120 "parent", hparent, varargin{:}); |
10549 | 121 endif |
122 h = [h; ht]; | |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
123 endif |
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
124 endfor |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
125 i += clen+1; |
8289
ac7f334d9652
Add contour group objects and the clabel function
David Bateman <dbateman@free.fr>
parents:
diff
changeset
|
126 endwhile |
17470
576cf0589c6d
Overhaul contour labeling functions.
Rik <rik@octave.org>
parents:
17338
diff
changeset
|
127 |
14868
5d3a684236b0
maint: Use Octave coding conventions for cuddling parentheses in scripts directory
Rik <octave@nomad.inbox5.com>
parents:
14138
diff
changeset
|
128 endfunction |
17338
1c89599167a6
maint: End m-files with 1 blank line.
Rik <rik@octave.org>
parents:
17176
diff
changeset
|
129 |