Mercurial > octave
view scripts/plot/appearance/view.m @ 27898:4d6d21839dfd
remove Author: jwe and Adapted-by: jwe lines from source files
These lines have little meaning now in the age of modern version
control systems.
Files affected: url-transfer.cc, url-transfer.h, acot.m, acoth.m,
acsc.m, acsch.m, asec.m, asech.m, cot.m, coth.m, csc.m, csch.m, sec.m,
sech.m, cart2pol.m, cart2sph.m, deal.m, fliplr.m, flipud.m, int2str.m,
logspace.m, num2str.m, pol2cart.m, rot90.m, sortrows.m, sph2cart.m,
waitbar.m, doc.m, hsv2rgb.m, rgb2hsv.m, beep.m, isstr.m, setstr.m,
strmatch.m, cond.m, rank.m, trace.m, bug_report.m, cast.m, delete.m,
dir.m, list_primes.m, ls.m, ls_command.m, menu.m, pack.m, recycle.m,
substruct.m, version.m, glpk.m, axis.m, box.m, grid.m,
__axis_label__.m, text.m, title.m, view.m, xlabel.m, ylabel.m,
zlabel.m, bar.m, barh.m, comet3.m, hist.m, line.m, loglog.m, mesh.m,
patch.m, plot.m, polar.m, __bar__.m, __line__.m, __plt__.m,
__stem__.m, semilogx.m, semilogy.m, sombrero.m, stairs.m, stem.m,
surface.m, __default_plot_options__.m, __gnuplot_drawnow__.m,
__next_line_color__.m, __plt_get_axis_arg__.m, __pltopt__.m, clf.m,
closereq.m, gca.m, gnuplot_binary.in.m, isfigure.m, meshgrid.m,
__gnuplot_draw_axes__.m, __gnuplot_draw_figure__.m, shg.m, addpref.m,
getpref.m, ispref.m, loadprefs.m, prefsfile.m, saveprefs.m, rmpref.m,
setpref.m, ismember.m, setdiff.m, union.m, hankel.m, hilb.m, vander.m,
median.m, std.m, cstrcat.m, isletter.m, str2num.m, strcat.m,
oruntests.m, rundemos.m, asctime.m, clock.m, ctime.m, date.m, etime.m,
is_leap_year.m.
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Thu, 02 Jan 2020 15:43:01 -0500 |
parents | 00f796120a6d |
children | b442ec6dda5c |
line wrap: on
line source
## Copyright (C) 2007-2019 John W. Eaton ## ## This file is part of Octave. ## ## Octave is free software: you can redistribute it and/or modify it ## under the terms of the GNU General Public License as published by ## the Free Software Foundation, either version 3 of the License, or ## (at your option) any later version. ## ## Octave is distributed in the hope that it will be useful, but ## WITHOUT ANY WARRANTY; without even the implied warranty of ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ## GNU General Public License for more details. ## ## You should have received a copy of the GNU General Public License ## along with Octave; see the file COPYING. If not, see ## <https://www.gnu.org/licenses/>. ## -*- texinfo -*- ## @deftypefn {} {} view (@var{azimuth}, @var{elevation}) ## @deftypefnx {} {} view ([@var{azimuth} @var{elevation}]) ## @deftypefnx {} {} view ([@var{x} @var{y} @var{z}]) ## @deftypefnx {} {} view (2) ## @deftypefnx {} {} view (3) ## @deftypefnx {} {} view (@var{hax}, @dots{}) ## @deftypefnx {} {[@var{azimuth}, @var{elevation}] =} view () ## Query or set the viewpoint for the current axes. ## ## The parameters @var{azimuth} and @var{elevation} can be given as two ## arguments or as 2-element vector. The viewpoint can also be specified with ## Cartesian coordinates @var{x}, @var{y}, and @var{z}. ## ## The call @code{view (2)} sets the viewpoint to @w{@var{azimuth} = 0} ## and @w{@var{elevation} = 90}, which is the default for 2-D graphs. ## ## The call @code{view (3)} sets the viewpoint to @w{@var{azimuth} = -37.5} ## and @w{@var{elevation} = 30}, which is the default for 3-D graphs. ## ## If the first argument @var{hax} is an axes handle, then operate on ## this axes rather than the current axes returned by @code{gca}. ## ## If no inputs are given, return the current @var{azimuth} and ## @var{elevation}. ## @end deftypefn function [azimuth, elevation] = view (varargin) [hax, varargin, nargin] = __plt_get_axis_arg__ ("view", varargin{:}); if (isempty (hax)) hax = gca (); endif if (nargin > 3) print_usage (); endif if (nargin == 0) x = get (hax, "view"); az = x(1); el = x(2); elseif (length (varargin) == 1) x = varargin{1}; if (length (x) == 2) az = x(1); el = x(2); elseif (length (x) == 3) [az, el] = cart2sph (x(1), x(2), x(3)); az *= 180/pi; az += 90; el *= 180/pi; elseif (x == 2) az = 0; el = 90; elseif (x == 3) az = -37.5; el = 30; else print_usage (); endif elseif (length (varargin) == 2) az = varargin{1}; el = varargin{2}; endif if (nargin > 0) set (hax, "view", [az, el]); else if (nargout == 1) azimuth = [az, el]; elseif (nargout == 2) azimuth = az; elevation = el; endif endif endfunction %!test %! hf = figure ("visible", "off"); %! unwind_protect %! plot3 ([0,1], [0,1], [0,1]); %! [az, el] = view; %! assert ([az, el], [-37.5, 30], eps); %! view (2); %! [az, el] = view; %! assert ([az, el], [0, 90], eps); %! view ([1 1 0]); %! [az, el] = view; %! assert ([az, el], [135, 0], eps); %! unwind_protect_cleanup %! close (hf); %! end_unwind_protect %!test %! hf = figure ("visible", "off"); %! unwind_protect %! line; %! [az, el] = view; %! assert ([az, el], [0, 90], eps); %! view (3); %! [az, el] = view; %! assert ([az, el], [-37.5, 30], eps); %! unwind_protect_cleanup %! close (hf); %! end_unwind_protect