Mercurial > hg > octave-nkf
view scripts/plot/figure.m @ 6758:1894012e6b84
[project @ 2007-06-25 23:09:21 by jwe]
author | jwe |
---|---|
date | Mon, 25 Jun 2007 23:09:21 +0000 |
parents | b298a4c12fc3 |
children | 38bc358b6c9a |
line wrap: on
line source
## Copyright (C) 1996, 1997 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 2, 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, write to the Free ## Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA ## 02110-1301, USA. ## -*- texinfo -*- ## @deftypefn {Function File} {} figure (@var{n}, @var{p}, @var{v}, @dots{}) ## Set the current plot window to plot window @var{n}. If no arguments are ## specified, the next available window number is chosen. Parameters @var{p} ## and settings @var{v} can be given in pairs if @var{n} is specified. ## @end deftypefn ## Author: jwe, Bill Denney function h = figure (varargin) nargs = nargin; f = NaN; init_new_figure = false; if (mod (nargs, 2) == 1) tmp = varargin{1}; if (ishandle (tmp) && strcmp (get (tmp, "type"), "figure")) f = tmp; varargin(1) = []; nargs--; elseif (isnumeric (tmp) && tmp > 0 && round (tmp) == tmp) f = tmp; init_new_figure = true; varargin(1) = []; nargs--; else error ("figure: expecting figure handle or figure number"); endif endif ## Check to see if we already have a figure on the screen. If we do, ## then update it if it is different from the figure we are creating ## or switching to. cf = get (0, "currentfigure"); if (! isempty (cf) && cf != 0) if (isnan (f) || cf != f) drawnow (); endif endif if (rem (nargs, 2) == 0) if (isnan (f) || init_new_figure) f = __go_figure__ (f); endif if (nargs > 0) set (f, varargin{:}); endif set (0, "currentfigure", f); else print_usage (); endif if (nargout > 0) h = f; endif endfunction