74 lines
2 KiB
Text
74 lines
2 KiB
Text
|
class:: FreeSelfWhenDone
|
||
|
summary:: Free the enclosing synth when a UGen is finished
|
||
|
related:: Classes/Done, Classes/PauseSelfWhenDone, Classes/Done
|
||
|
categories:: UGens>Synth control
|
||
|
|
||
|
Description::
|
||
|
|
||
|
Some UGens set a 'done' flag when they are finished playing.
|
||
|
FreeSelfWhenDone will free the enclosing synth when this flag is set to true.
|
||
|
|
||
|
See link::Classes/Done:: for a complete list of these UGens.
|
||
|
|
||
|
Note that many of these UGens have doneActions, which are another way of accomplishing the same thing. See link::Classes/Done:: for more detail.
|
||
|
|
||
|
note:: One must be careful when using binary operations on UGens with done flags, as these will return a link::Classes/BinaryOpUGen::, and thus prevent the done flag from being accessible. See example below. ::
|
||
|
|
||
|
classmethods::
|
||
|
private:: categories
|
||
|
|
||
|
method::kr
|
||
|
|
||
|
argument::src
|
||
|
|
||
|
the UGen to check for done.
|
||
|
|
||
|
examples::
|
||
|
code::
|
||
|
s.boot;
|
||
|
|
||
|
// simple example
|
||
|
(
|
||
|
{ var env;
|
||
|
env = Line.kr(0, 1, 1);
|
||
|
FreeSelfWhenDone.kr(env); // free synth at end of line
|
||
|
SinOsc.ar(200, 0, 0.5) * env
|
||
|
}.play;
|
||
|
)
|
||
|
|
||
|
// the previous example works, because FreeSelfWhenDone operates on the Line
|
||
|
// this version won't work
|
||
|
(
|
||
|
{ var env, output;
|
||
|
env = Line.kr(0, 1, 1);
|
||
|
output = SinOsc.ar(200, 0, 0.5) * env;
|
||
|
output.postln; // output is a BinaryOpUGen, which has no 'done' flag
|
||
|
FreeSelfWhenDone.kr(output); // won't ever be done
|
||
|
output
|
||
|
}.play;
|
||
|
)
|
||
|
|
||
|
// record for four seconds
|
||
|
b = Buffer.alloc(s, 44100 * 4.0, 1);
|
||
|
(
|
||
|
SynthDef("help-RecordBuf",{ arg out=0,bufnum=0;
|
||
|
var formant, recbuf;
|
||
|
formant = Formant.ar(XLine.kr(400,1000, 4), 2000, 800, 0.125);
|
||
|
recbuf = RecordBuf.ar(formant, bufnum, recLevel: Line.kr(1, 1), loop: 0);
|
||
|
// The RecordBuf doesn't loop, so you can check it for 'done' status
|
||
|
FreeSelfWhenDone.kr(recbuf);
|
||
|
}).play(s,[\out, 0, \bufnum, b]);
|
||
|
)
|
||
|
|
||
|
// play it back
|
||
|
(
|
||
|
SynthDef("help-RecordBuf play",{ arg out=0,bufnum=0;
|
||
|
var playbuf;
|
||
|
playbuf = PlayBuf.ar(1,bufnum);
|
||
|
FreeSelfWhenDone.kr(playbuf); // frees the synth when the PlayBuf is finished
|
||
|
Out.ar(out, playbuf);
|
||
|
}).play(s,[\out, 0, \bufnum, b]);
|
||
|
)
|
||
|
::
|
||
|
|