Mercurial > hg > octave-nkf
view scripts/plot/cla.m @ 17126:26589abbc78d
Don't pass axis handle unnecessarily from high level to low level plot functions.
* scripts/plot/comet.m, scripts/plot/comet3.m, scripts/plot/compass.m,
scripts/plot/contour.m, scripts/plot/contourf.m, scripts/plot/cylinder.m,
scripts/plot/ellipsoid.m, scripts/plot/errorbar.m, scripts/plot/feather.m,
scripts/plot/mesh.m, scripts/plot/meshc.m, scripts/plot/meshz.m,
scripts/plot/pcolor.m, scripts/plot/plot3.m, scripts/plot/rectangle.m,
scripts/plot/rose.m, scripts/plot/scatter3.m, scripts/plot/semilogxerr.m,
scripts/plot/semilogy.m, scripts/plot/semilogyerr.m, scripts/plot/slice.m,
scripts/plot/sphere.m, scripts/plot/stairs.m, scripts/plot/surf.m,
scripts/plot/surfc.m, scripts/plot/surfnorm.m, scripts/plot/trimesh.m,
scripts/plot/trisurf.m: Don't pass hax to lower level functions after
newplot() has been called.
author | Rik <rik@octave.org> |
---|---|
date | Wed, 31 Jul 2013 18:42:17 -0700 |
parents | b5d6314314fc |
children | bc924baa2c4e |
line wrap: on
line source
## Copyright (C) 2008-2012 Ben Abbott ## ## 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 ## <http://www.gnu.org/licenses/>. ## -*- texinfo -*- ## @deftypefn {Command} {} cla ## @deftypefnx {Command} {} cla reset ## @deftypefnx {Function File} {} cla (@var{hax}) ## @deftypefnx {Function File} {} cla (@var{hax}, "reset") ## Clear the current axes. ## ## @code{cla} operates by deleting child graphic objects with visible ## handles (HandleVisibility = "on"). ## ## If the optional argument "reset" is specified, delete all child objects ## including those with hidden handles and reset all axis properties to ## their defaults. However, the following properties are not reset: ## Position, Units. ## ## If the first argument @var{hax} is an axes handle, then operate on ## this axis rather than the current axes returned by @code{gca}. ## @seealso{clf} ## @end deftypefn ## Author: Ben Abbott <bpabbott@mac.com> ## Created: 2008-10-03 function cla (varargin) if (nargin > 2) print_usage (); elseif (nargin == 0) hax = gca; do_reset = false; elseif (nargin == 1) if (isscalar (varargin{1}) && isaxes (varargin{1})) hax = varargin{1}; do_reset = false; elseif (ischar (varargin{1}) && strcmpi (varargin{1}, "reset")) hax = gca; do_reset = true; else print_usage (); endif else if (isscalar (varargin{1}) && isaxes (varargin{1}) && ischar (varargin{2}) && strcmpi (varargin{2}, "reset")) hax = varargin{1}; do_reset = true; else print_usage (); endif endif if (! do_reset) delete (get (hax, "children")); else __go_axes_init__ (hax, "replace"); __request_drawnow__ (); endif endfunction %!test %! hf = figure ("visible", "off"); %! unwind_protect %! plot (1:10); %! assert (! isempty (get (gca, "children"))); %! cla (); %! assert (isempty (get (gca, "children"))); %! unwind_protect_cleanup %! close (hf); %! end_unwind_protect %!test %! hf = figure ("visible", "off"); %! unwind_protect %! hax = gca; %! plot (hax, 1:10); %! set (hax, "interpreter", "tex"); %! cla (hax); %! kids = get (hax, "children"); %! assert (numel (kids), 0); %! assert (get (hax, "interpreter"), "tex"); %! plot (hax, 1:10); %! cla (hax, "reset"); %! kids = get (hax, "children"); %! assert (numel (kids), 0); %! assert (get (hax, "interpreter"), "none"); %! unwind_protect_cleanup %! close (hf); %! end_unwind_protect