Mercurial > hg > octave-lyh
view scripts/java/listdlg.m @ 15806:01d4f742d75d
doc: Re-organize and improve Java Interface documentation.
* doc/interpreter/java.txi: Add usejava, isjava functions, debug_java,
java_matrix_autoconversion, java_unsigned_autoconversion to docs.
Re-organize to put functions in logical order. Add new "Dialog Box Functions"
node.
* doc/interpreter/system.txi: Remove usejava from list of system functions.
* libinterp/octave-value/ov-java.cc(FjavaObject, FjavaMethod,
Fjava_unsigned_autoconversion): Improve docstrings.
* scripts/java/javaArray.m: Tweak docstring.
* scripts/java/listdlg.m: Wrap long lines in docstring. Improve
code example in docstring.
author | Rik <rik@octave.org> |
---|---|
date | Mon, 17 Dec 2012 10:23:43 -0800 |
parents | 921912c92102 |
children | 801297f14e4b |
line wrap: on
line source
## Copyright (C) 2010 Martin Hepperle ## ## 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{sel}, @var{ok}] =} listdlg (@var{key}, @var{value}, @dots{}) ## Return user inputs from a list dialog box in a vector of ## selection indices @var{sel} and a flag @var{ok} indicating how the ## user closed the dialog box. The value of @var{ok} is 1 if the user ## closed the box with the OK button, otherwise it is 0 and @var{sel} is ## empty. ## ## The indices in @var{sel} are 1 based. ## ## The arguments are specified in form of @var{key}, @var{value} pairs. ## The @code{"ListString"} argument pair must be specified. ## ## Valid @var{key} and @var{value} pairs are: ## ## @table @code ## @item "ListString" ## a cell array of strings comprising the content of the list. ## ## @item "SelectionMode" ## can be either @code{"Single"} or @code{"Multiple"} (default). ## ## @item "ListSize" ## a vector with two elements @var{width} and @var{height} defining ## the size of the list field in pixels. Default is [160 300]. ## ## @item "InitialValue" ## a vector containing 1-based indices of preselected elements. Default ## is 1 (first item). ## ## @item "Name" ## a string to be used as the dialog caption. Default is "". ## ## @item "PromptString" ## a cell array of strings to be displayed above the list field. Default ## is @{@}. ## ## @item "OKString" ## a string used to label the OK button. Default is "OK". ## ## @item "CancelString" ## a string used to label the Cancel button. Default is "Cancel". ## @end table ## ## Example: ## ## @example ## @group ## [sel, ok] = listdlg ("ListString", @{"An item", "another", "yet another"@}, ## "SelectionMode", "Multiple"); ## if (ok == 1) ## for i = 1:numel (sel) ## disp (sel(i)); ## endfor ## endif ## @end group ## @end example ## ## @seealso{errordlg, helpdlg, inputdlg, msgbox, questdlg, warndlg} ## @end deftypefn function varargout = listdlg (varargin) if (nargin < 2) print_usage (); endif listcell = {""}; selmode = "multiple"; listsize = [160, 300]; initialvalue = 1; name = ""; prompt = {""}; okstring = "OK"; cancelstring = "Cancel"; ## handle key, value pairs for i = 1:2:nargin-1 if strcmp (varargin{i}, "ListString") listcell = varargin{i+1}; elseif strcmp (varargin{i}, "SelectionMode") selmode = varargin{i+1}; elseif strcmp (varargin{i}, "ListSize") listsize = varargin{i+1}; elseif strcmp (varargin{i}, "InitialValue") initialvalue = varargin{i+1}; elseif strcmp (varargin{i}, "Name") name = varargin{i+1}; elseif strcmp (varargin{i}, "PromptString") prompt = varargin{i+1}; elseif strcmp (varargin{i}, "OKString") okstring = varargin{i+1}; elseif strcmp (varargin{i}, "CancelString") cancelstring = varargin{i+1}; endif endfor ## make sure prompt strings are a cell array if (! iscell (prompt)) prompt = {prompt}; endif ## make sure listcell strings are a cell array if (! iscell (listcell)) listcell = {listcell}; endif ## transform matrices to cell arrays of strings ## swap width and height to correct calling format for JDialogBox listsize = {num2str(listsize(2)), num2str(listsize(1))}; initialvalue = arrayfun (@num2str, initialvalue, "UniformOutput", false); ret = javaMethod ("listdlg", "org.octave.JDialogBox", listcell, selmode, listsize, initialvalue, name, prompt, okstring, cancelstring); if (numel (ret) > 0) varargout = {ret, 1}; else varargout = {{}, 0}; endif endfunction