Mercurial > hg > octave-nkf
view scripts/plot/private/__line__.m @ 13929:9cae456085c2
Grammarcheck of documentation before 3.6.0 release.
* accumarray.m, blkdiag.m, nargoutchk.m, nthargout.m, profexplore.m, profile.m,
computer.m, orderfields.m, recycle.m, version.m, sqp.m, matlabroot.m,
__plt_get_axis_arg__.m, isonormals.m, isosurface.m, __fltk_file_filter__.m,
__is_function__.m, __uigetdir_fltk__.m, __uigetfile_fltk__.m,
__uiobject_split_args__.m, __uiputfile_fltk__.m, uicontextmenu.m, uiresume.m,
uiwait.m, mkpp.m, ppder.m, residue.m, addpref.m, getpref.m, ispref.m,
loadprefs.m, prefsfile.m, saveprefs.m, rmpref.m, setpref.m, fftshift.m, bicg.m,
bicgstab.m, cgs.m, gmres.m, __sprand_impl__.m, quantile.m, deblank.m,
strsplit.m, addtodate.m, bsxfun.cc, kron.cc, regexp.cc, data.cc, file-io.cc,
graphics.cc, load-save.cc, mappers.cc: Grammarcheck of documentation
before 3.6.0 release.
author | Rik <octave@nomad.inbox5.com> |
---|---|
date | Wed, 23 Nov 2011 08:38:19 -0800 |
parents | 571557ddabb9 |
children | 72c96de7a403 |
line wrap: on
line source
## Copyright (C) 2005-2011 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 ## <http://www.gnu.org/licenses/>. ## -*- texinfo -*- ## @deftypefn {Function File} {@var{h} =} __line__ (@var{p}, @dots{}) ## Undocumented internal function. ## @end deftypefn ## __line__ (p, x, y, z) ## Create line object from x, y, and z with parent p. ## Return handle to line object. ## Author: jwe function h = __line__ (p, varargin) if (nargin < 1) print_usage (); endif nvargs = numel (varargin); if (nvargs > 1 && isnumeric (varargin{1}) && isnumeric (varargin{2})) if (nvargs > 2 && isnumeric (varargin{3})) num_data_args = 3; else num_data_args = 2; endif else num_data_args = 0; endif if (num_data_args > 0 && ! size_equal (varargin{1:num_data_args})) error ("line: number of X, Y, and Z points must be equal"); endif if (rem (nvargs - num_data_args, 2) != 0) error ("line: invalid number of PROPERTY / VALUE pairs"); endif other_args = {}; if (nvargs > num_data_args) other_args = varargin(num_data_args+1:end); endif nlines = 0; nvecpts = 0; ismat = false (1, 3); for i = 1:num_data_args tmp = varargin{i}(:,:); if (isvector (tmp)) nlines = max (1, nlines); if (! isscalar (tmp)) if (nvecpts == 0) nvecpts = numel (tmp); elseif (nvecpts != numel (tmp)) error ("line: data size mismatch"); endif endif else ismat(i) = true; nlines = max (columns (tmp), nlines); endif varargin{i} = tmp; endfor if (num_data_args == 0) varargin = {[0, 1], [0, 1]}; num_data_args = 2; nlines = 1; endif handles = zeros (nlines, 1); data = cell (1, 3); if (num_data_args > 1) data(1) = varargin{1}; data(2) = varargin{2}; if (num_data_args == 3) data(3) = varargin{3}; endif endif data_args = reshape ({"xdata", "ydata", "zdata"; data{:}}, [1, 6]); mask = reshape ([false(1,3); ismat], [1, 6]); for i = 1:nlines tmp = data(ismat); if (! size_equal (tmp) || (nvecpts != 0 && any (nvecpts != cellfun ("size", tmp, 1)))) error ("line: data size_mismatch"); endif data_args(mask) = cellfun (@(x) x(:,i), data(ismat), "uniformoutput", false); handles(i) = __go_line__ (p, data_args{:}, other_args{:}); endfor if (nargout > 0) h = handles; endif endfunction