Mercurial > hg > octave-lyh
annotate scripts/plot/figure.m @ 17475:fd01c78caa0b
Added tag ss-3-7-7 for changeset cc13924a4266
author | John W. Eaton <jwe@octave.org> |
---|---|
date | Mon, 23 Sep 2013 13:31:11 -0400 |
parents | 603ce503babd |
children |
rev | line source |
---|---|
14138
72c96de7a403
maint: update copyright notices for 2012
John W. Eaton <jwe@octave.org>
parents:
13325
diff
changeset
|
1 ## Copyright (C) 1996-2012 John W. Eaton |
2313 | 2 ## |
3 ## This file is part of Octave. | |
4 ## | |
5 ## Octave is free software; you can redistribute it and/or modify it | |
6 ## under the terms of the GNU General Public License as published by | |
7016 | 7 ## the Free Software Foundation; either version 3 of the License, or (at |
8 ## your option) any later version. | |
2313 | 9 ## |
10 ## Octave is distributed in the hope that it will be useful, but | |
11 ## WITHOUT ANY WARRANTY; without even the implied warranty of | |
12 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
13 ## General Public License for more details. | |
14 ## | |
15 ## You should have received a copy of the GNU General Public License | |
7016 | 16 ## along with Octave; see the file COPYING. If not, see |
17 ## <http://www.gnu.org/licenses/>. | |
2290 | 18 |
3368 | 19 ## -*- texinfo -*- |
14366
b76f0740940e
doc: Periodic grammar check of documentation.
Rik <octave@nomad.inbox5.com>
parents:
14363
diff
changeset
|
20 ## @deftypefn {Command} {} figure |
b76f0740940e
doc: Periodic grammar check of documentation.
Rik <octave@nomad.inbox5.com>
parents:
14363
diff
changeset
|
21 ## @deftypefnx {Command} {} figure @var{n} |
14276
6b4bd6a86bdd
figure.m: Extend to accepting command form "figure N"
Rik <octave@nomad.inbox5.com>
parents:
14226
diff
changeset
|
22 ## @deftypefnx {Function File} {} figure (@var{n}) |
17126
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
23 ## @deftypefnx {Function File} {} figure (@dots{}, "@var{property}", @var{value}, @dots{}) |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
24 ## @deftypefnx {Function File} {@var{h} =} figure (@var{dots}) |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
25 ## Create a new figure window for plotting. |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
26 ## |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
27 ## If no arguments are specified, a new figure with the next available number |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
28 ## is created. |
6895 | 29 ## |
17126
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
30 ## If called with an integer @var{n}, and no such numbered figure exists, then |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
31 ## a new figure with the specified number is created. If the figure already |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
32 ## exists then it is made visible and becomes the current figure for plotting. |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
33 ## |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
34 ## Multiple property-value pairs may be specified for the figure object, but |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
35 ## they must appear in pairs. |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
36 ## |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
37 ## The optional return value @var{h} is a graphics handle to the created figure |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
38 ## object. |
eaab03308c0b
doc: Rewrite docstrings for most plot functions.
Rik <rik@octave.org>
parents:
14846
diff
changeset
|
39 ## @seealso{axes, gcf, clf, close} |
3368 | 40 ## @end deftypefn |
2290 | 41 |
6257 | 42 ## Author: jwe, Bill Denney |
2314 | 43 |
6257 | 44 function h = figure (varargin) |
3263 | 45 |
6257 | 46 nargs = nargin; |
5406 | 47 |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
48 if (mod (nargs, 2) == 0) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
49 f = NaN; |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
50 init_new_figure = true; |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
51 else |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
52 arg = varargin{1}; |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
53 if (ischar (arg)) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
54 arg = str2double (arg); |
14276
6b4bd6a86bdd
figure.m: Extend to accepting command form "figure N"
Rik <octave@nomad.inbox5.com>
parents:
14226
diff
changeset
|
55 endif |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
56 if (isfigure (arg)) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
57 f = arg; |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
58 init_new_figure = false; |
6257 | 59 varargin(1) = []; |
60 nargs--; | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
61 elseif (isnumeric (arg) && isscalar (arg) && arg > 0 && arg == fix (arg)) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
62 f = arg; |
6293 | 63 init_new_figure = true; |
6257 | 64 varargin(1) = []; |
65 nargs--; | |
66 else | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
67 error ("figure: N must be figure handle or figure number"); |
6257 | 68 endif |
3263 | 69 endif |
70 | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
71 if (rem (nargs, 2) == 1) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
72 error ("figure: PROPERTY/VALUE arguments must be in pairs"); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
73 endif |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
74 |
6293 | 75 ## Check to see if we already have a figure on the screen. If we do, |
76 ## then update it if it is different from the figure we are creating | |
77 ## or switching to. | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
78 cf = get (0, "currentfigure"); # Can't use gcf () because it calls figure() |
6293 | 79 if (! isempty (cf) && cf != 0) |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
80 if (init_new_figure || cf != f) |
6293 | 81 drawnow (); |
82 endif | |
83 endif | |
84 | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
85 if (init_new_figure) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
86 if (ismac () && strcmp (graphics_toolkit (), "fltk")) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
87 ## FIXME: Hack for fltk-aqua to work around bug #31931 |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
88 f = __go_figure__ (f); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
89 drawnow (); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
90 if (! isempty (varargin)) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
91 set (f, varargin{:}); |
14183
9e6ec5f55827
When creating an fltk (aqua) figure on MacOS, make sure one drawnow() occurs
Ben Abbott <bpabbott@mac.com>
parents:
14138
diff
changeset
|
92 endif |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
93 else |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
94 f = __go_figure__ (f, varargin{:}); |
2290 | 95 endif |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
96 __add_default_menu__ (f); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
97 elseif (nargs > 0) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
98 set (f, varargin{:}); |
2290 | 99 endif |
3263 | 100 |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
101 set (0, "currentfigure", f); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
102 ## When switching to figure N, make figure visible and on top of stack. |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
103 if (! init_new_figure) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
104 set (f, "visible", "on"); |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
105 endif |
11349
4a3258b1448f
Add default menu for fltk backend figures
Kai Habel <kai.habel@gmx.de>
parents:
10793
diff
changeset
|
106 |
6283 | 107 if (nargout > 0) |
108 h = f; | |
109 endif | |
110 | |
2290 | 111 endfunction |
13204 | 112 |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14276
diff
changeset
|
113 |
13204 | 114 %!test |
115 %! hf = figure ("visible", "off"); | |
116 %! unwind_protect | |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
117 %! assert (hf, gcf); |
13204 | 118 %! assert (isfigure (hf)); |
119 %! unwind_protect_cleanup | |
120 %! close (hf); | |
13279
984359717d71
Use common code idiom for checking whether a double value is an integer.
Rik <octave@nomad.inbox5.com>
parents:
13204
diff
changeset
|
121 %! end_unwind_protect |
14363
f3d52523cde1
Use Octave coding conventions in all m-file %!test blocks
Rik <octave@nomad.inbox5.com>
parents:
14276
diff
changeset
|
122 |
17143
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
123 %!error <N must be figure handle or figure number> figure ({1}) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
124 %!error <N must be figure handle or figure number> figure ([1 2]) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
125 %!error <N must be figure handle or figure number> figure (-1) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
126 %!error <N must be figure handle or figure number> figure (1.5) |
603ce503babd
figure.m: Overhaul function. When switching to figure N make it visible.
Rik <rik@octave.org>
parents:
17140
diff
changeset
|
127 |