rsc3/doc-schelp/HelpSource/Classes/SharedIn.schelp

74 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;
::