Mercurial > hg > octave-nkf
diff scripts/plot/multiplot.m @ 1540:749b8b19733f
[project @ 1995-10-06 03:10:34 by jwe]
Initial revision
author | jwe |
---|---|
date | Fri, 06 Oct 1995 03:10:34 +0000 |
parents | |
children | 47bd45a30dda |
line wrap: on
line diff
new file mode 100644 --- /dev/null +++ b/scripts/plot/multiplot.m @@ -0,0 +1,115 @@ +# Copyright (C) 1995 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, 59 Temple Place - Suite 330, Boston, MA +# 02111-1307, USA. + +function multiplot (xn, yn) + +# usage: multiplot (xn, yn) +# +# Sets and resets multiplot mode +# +# If multiplot(0,0) then it will close multiplot mode and and if +# arguments are non-zero, then it will set up multiplot mode with +# xn,yn subplots along x and y axes. +# +# NOTE: this will work only with gnuplot installed with +# multiplot patch + +# Written by Vinayak Dutt, Dutt.Vinayak@mayo.EDU 3 Jul 95 + +# global variables to keep track of multiplot options + + global multiplot_mode + global multi_xsize multi_ysize + global multi_xn multi_yn + global multi_xi multi_yi + +# This is a real kludge. We gnuplot should be made so that replot can +# be executed while doing multiple plots... + + global multiplot_save_auto_replot = automatic_replot + + if (nargin != 2) + usage ("multiplot (xn, yn)"); + endif + + if (! (is_scalar (xn) && is_scalar (yn))) + error ("multiplot: xn and yn have to be scalars"); + endif + + if ((isstr (automatic_replot) && strcmp (automatic_replot,"true")) + || automatic_replot) + warning ("turning off automatic replot for multiplot mode"); + multiplot_save_auto_replot = automatic_replot; + automatic_replot = 0; + endif + + xn = round (xn); + yn = round (yn); + + if (xn == 0 && yn == 0) + + set nomultiplot; + set size 1,1 + set origin 0,0 + + multiplot_mode = 0; + multi_xsize = 1; + multi_ysize = 1; + multi_xn = 1; + multi_yn = 1; + multi_xi = 1; + multi_yi = 1; + +# Someone may have reset it betweeen calls... + + if (! isstr (automatic_replot) && ! automatic_replot) + automatic_replot = multiplot_save_auto_replot; + endif + + return; + + else + + if (xn < 1 || yn < 1) + error ("multiplot: xn and yn have to be positive integers"); + endif + + set multiplot; + + xsize = 1.0 ./ xn; + ysize = 1.0 ./ yn; + + eval (sprintf ("set size %g, %g", xsize, ysize)); + + xo = 0.0; + yo = (yn - 1.0)*ysize; + + eval (sprintf ("set origin %g, %g", xo, yo)); + + multiplot_mode = 1; + multi_xsize = xsize; + multi_ysize = ysize; + multi_xn = xn; + multi_yn = yn; + multi_xi = 1; + multi_yi = 1; + + endif + +endfunction