scide: implement selectionLength for openDocument
[supercollider.git] / HelpSource / Classes / ListView.schelp
blobb1023a1ad1dde2fdcc53c53fe9f6afed3e228194
1 CLASS:: ListView
2 redirect:: implClass
3 summary:: A view displaying a list of text items.
4 categories:: GUI>Views
6 DESCRIPTION::
8 A view that displays a list of text items and allows one of them to be selected.
10 An item can be selected by clicking on it. Pressing the up or down arrow keys while an item is selected will select the previous or next item respectively (if available).
12 CLASSMETHODS::
14 PRIVATE:: key
19 INSTANCEMETHODS::
23 SUBSECTION:: Data
25 METHOD:: items
26         The list of items displayed by the view.
28         argument::
29                 An Array of Strings, each String defining the text to represent an item.
31 METHOD:: value
32         The index of the currently selected item, or nil when no item is selected.
34         argument::
35                 An Integer or nil.
37 METHOD:: valueAction
38         Sets link::#-value:: and triggers the link::#-action::.
42 SUBSECTION:: Appearance
44 METHOD:: colors
45         The background colors of the items.
47         argument::
48                 An Array of Colors, one Color for each item.
50 METHOD:: stringColor
51         The color used to display all the text of all unselected items.
53         argument::
54                 A Color.
56 METHOD:: selectedStringColor
57         The color used to display the selected item's text.
59         argument::
60                 A Color.
62 METHOD:: hiliteColor
63         The color used to indicate the selected item (aside from the color of its text).
65         argument::
66                 A Color.
71 SUBSECTION:: Interaction
73 METHOD:: selectionMode
74         note:: Only available in Qt GUI ::
76         The allowed mode of item selection, according to the following table:
78         table::
79         ## strong::Value::  || strong::Meaning::
80         ## \none            || No item can be selected.
81         ## \single          || Only a single item can be selected at once.
82         ## \multi           || Multiple items can be selected. An item's selection is toggled when clicked.
83         ## \extended        || Multiple items can be selected, individually by holding the Ctrl key, and in a batch by holding the Shift key.
84         ## \contiguous      || Mutliple neighbouring items can be selected by holding the Shift key.
85         ::
87         argument::
88                 One of the Symbols listed in the table above.
92 SUBSECTION:: Actions
94 METHOD:: action
95         The action object evaluated whenever the user changes the item selection.
97 METHOD:: enterKeyAction
98         The action object evaluated whenever the user presses the Enter (Return) key.
100 METHOD:: defaultKeyDownAction
102         Implements the default effects of key presses as follows:
104         table::
105         ## strong::Key::   || strong::Effect::
106         ## space           || select next item and trigger action
107         ## r               || trigger enterKeyAction
108         ## n               || trigger enterKeyAction
109         ## a number        || trigger enterKeyAction
110         ## up arrow        || select previous item and trigger action
111         ## down arrow      || select next item and trigger action
112         ## left arrow      || select previous item and trigger action
113         ## right arrow     || select next item and trigger action
114         ::
118 SUBSECTION:: Drag and drop
120 METHOD:: defaultGetDrag
121         returns::
122                 The link::#-value::.
124 METHOD:: defaultCanReceiveDrag
125         returns::
126                 True if the current drag data is a number.
128 METHOD:: defaultReceiveDrag
129         Sets link::#-valueAction:: to the current drag data.
132 EXAMPLES::
134 subsection:: Basic Example
136 code::
138 w = Window.new.front;
140 v = ListView(w,Rect(10,10,120,70))
141     .items_([ "SinOsc", "Saw", "LFSaw", "WhiteNoise", "PinkNoise", "BrownNoise", "Osc" ])
142     .background_(Color.clear)
143     .hiliteColor_(Color.green(alpha:0.6))
144     .action_({ arg sbs;
145         [sbs.value, v.items[sbs.value]].postln; // .value returns the integer
146     });
151 subsection:: Sound Example
153 Use ListView to switch filters:
154 code::
156 Server.default = s = Stethoscope.defaultServer.boot;
157 s.waitForBoot({
158     var f, freq, ww;
159     n={r=LFSaw.ar([220, 530],0,0.3)*LFPulse.ar(12,0,0.3,0.4); [r[0],Delay2.ar(r[1])]}.play;
160     freq={SinOsc.kr(0.5,0,4000,4200)}.play;
161     w=Window("Filters").front;
162     v = ListView(w,Rect(10,10,180,120))
163         .items_([ "No Filter","RLPF", "RHPF", "BPF", "Resonz", "MoogFF" ])
164         .background_(Color.clear)
165         .hiliteColor_(Color.green(alpha:0.6))
166         .action_({arg v;
167             v.value.switch(
168             0,{try{f.free};"test".postln},
169             1,{try{f.free};f={ReplaceOut.ar(0,RLPF.ar(In.ar(0,2),In.kr(0,1),0.2,0.3))}.play(addAction:\addToTail)},
170             2,{try{f.free};f={ReplaceOut.ar(0,RHPF.ar(In.ar(0,2),In.kr(0,1),0.2,0.3))}.play(addAction:\addToTail)},
171             3,{try{f.free};f={ReplaceOut.ar(0,BPF.ar(In.ar(0,2),In.kr(0,1),0.2,1.5))}.play(addAction:\addToTail)},
172             4,{try{f.free};f={ReplaceOut.ar(0,Resonz.ar(In.ar(0,2),In.kr(0,1),0.2,2))}.play(addAction:\addToTail)},
173             5,{try{f.free};f={ReplaceOut.ar(0,MoogFF.ar(In.ar(0,2),In.kr(0,1),1.5))}.play(addAction:\addToTail)}
174             );
175         });
177     ww=FreqScope.new(400, 200, 0);
178     w.bounds=Rect(50,Window.screenBounds.height-300,200,200);
179     ww.window.bounds=ww.window.bounds.moveTo(255,Window.screenBounds.height-328);
180     CmdPeriod.doOnce({{ww.window.close}.defer(0.5);w.close;});
181             //defer or crash, because FreqScopeWindow Class contains its own routine for cleaning up on CmdPeriod
182     w.onClose_({n.free;f.free;freq.free});