75 lines
1.5 KiB
Text
75 lines
1.5 KiB
Text
|
class:: SharedIn
|
||
|
summary:: Read from a shared control bus.
|
||
|
related:: Classes/SharedOut
|
||
|
categories:: UGens>InOut
|
||
|
|
||
|
|
||
|
Description::
|
||
|
|
||
|
warning::
|
||
|
SharedIn has been deprecated. Synchronous access to busses on local servers is possible via
|
||
|
link::Classes/Bus#-getSynchronous:: and link::Classes/Bus#-setSynchronous::
|
||
|
::
|
||
|
|
||
|
Reads from a control bus shared between the internal server and the SC
|
||
|
client. Control rate only. Writing to a shared control bus from the
|
||
|
client is synchronous. When not using the internal server use node
|
||
|
arguments or the set method of Bus (or /c_set in messaging style).
|
||
|
|
||
|
|
||
|
classmethods::
|
||
|
|
||
|
method::kr
|
||
|
|
||
|
argument::bus
|
||
|
|
||
|
The index of the shared control bus to read from.
|
||
|
|
||
|
|
||
|
argument::numChannels
|
||
|
|
||
|
the number of channels (i.e. adjacent buses) to read in. The
|
||
|
default is 1. You cannot modulate this number by assigning it to
|
||
|
an argument in a SynthDef.
|
||
|
|
||
|
|
||
|
Examples::
|
||
|
|
||
|
code::
|
||
|
|
||
|
(
|
||
|
// only works with the internal server
|
||
|
s = Server.internal;
|
||
|
s.boot;
|
||
|
)
|
||
|
|
||
|
(
|
||
|
SynthDef("help-SharedIn1", {
|
||
|
Out.ar(0, SinOsc.ar(Lag.kr(SharedIn.kr(0, 1), 0.01), 0, 0.2));
|
||
|
}).add;
|
||
|
SynthDef("help-SharedIn2", {
|
||
|
Out.ar(1, SinOsc.ar(Lag.kr(SharedIn.kr(0, 1), 0.01, 1.5), 0, 0.2));
|
||
|
}).add;
|
||
|
)
|
||
|
|
||
|
(
|
||
|
s.setSharedControl(0, 300); // an initial value
|
||
|
s.sendMsg(\s_new, "help-SharedIn1", x = s.nextNodeID, 0, 1);
|
||
|
s.sendMsg(\s_new, "help-SharedIn2", y = s.nextNodeID, 0, 1);
|
||
|
|
||
|
Routine({
|
||
|
30.do({
|
||
|
s.setSharedControl(0, 300 * (10.rand + 1));
|
||
|
0.2.wait;
|
||
|
});
|
||
|
s.sendMsg(\n_free, x);
|
||
|
s.sendMsg(\n_free, y);
|
||
|
}).play;
|
||
|
)
|
||
|
|
||
|
|
||
|
s.quit;
|
||
|
|
||
|
::
|
||
|
|