87 lines
1.7 KiB
Text
87 lines
1.7 KiB
Text
|
#lang scribble/manual
|
|||
|
@(require (for-label racket))
|
|||
|
|
|||
|
@title{Pfset}
|
|||
|
Insert an environment into the event prototype before evaluating the supplied pattern@section{related}
|
|||
|
Classes/Pset
|
|||
|
@section{categories}
|
|||
|
Streams-Patterns-Events>Patterns>Data Sharing
|
|||
|
|
|||
|
@section{description}
|
|||
|
|
|||
|
Good for setting default values or loading server objects.
|
|||
|
|
|||
|
|
|||
|
@section{classmethods}
|
|||
|
|
|||
|
|
|||
|
@section{method}
|
|||
|
new
|
|||
|
|
|||
|
@section{argument}
|
|||
|
func
|
|||
|
Use environment variable syntax (e.g.,
|
|||
|
@racketblock[ ~x = 0 ::) to store values in the internal environment. These values are copied into the event prototype before running the supplied pattern.
|
|||
|
]
|
|||
|
@section{argument}
|
|||
|
pattern
|
|||
|
An event pattern (such as link::Classes/Pbind::).
|
|||
|
@section{argument}
|
|||
|
cleanupFunc
|
|||
|
Optional. A function to evaluate when the pattern is stopped, or when the supplied pattern runs out of values. For example, if you loaded a link::Classes/Buffer:: in the initializer function, you could free it in the
|
|||
|
@racketblock[cleanupFunc::.
|
|||
|
|
|||
|
|
|||
|
]
|
|||
|
@section{examples}
|
|||
|
|
|||
|
|
|||
|
@racketblock[
|
|||
|
(
|
|||
|
var a, b;
|
|||
|
a = Pfset({
|
|||
|
~legato = 0.3;
|
|||
|
~detune = rrand(0, 30);
|
|||
|
}, Pbind(\dur, 0.5));
|
|||
|
x = a.asStream;
|
|||
|
9.do({ x.next(Event.new).postln; });
|
|||
|
)
|
|||
|
::
|
|||
|
|
|||
|
Pfset does not override values placed into the event by the inner pattern:
|
|||
|
]
|
|||
|
|
|||
|
@racketblock[
|
|||
|
(
|
|||
|
var a, b;
|
|||
|
a = Pfset({
|
|||
|
~dur = 0.3;
|
|||
|
}, Pbind(\dur, 0.5));
|
|||
|
x = a.asStream;
|
|||
|
9.do({ x.next(Event.new).postln; });
|
|||
|
)
|
|||
|
::
|
|||
|
|
|||
|
Sound example
|
|||
|
]
|
|||
|
|
|||
|
@racketblock[
|
|||
|
(
|
|||
|
SynthDef(\sinegrain,
|
|||
|
{ arg out = 0, freq = 440, sustain = 0.02;
|
|||
|
var env;
|
|||
|
env = EnvGen.kr(Env.perc(0.001, sustain), 1, doneAction: Done.freeSelf);
|
|||
|
Out.ar(out, SinOsc.ar(freq, 0, env * 0.1))
|
|||
|
}).add;
|
|||
|
)
|
|||
|
|
|||
|
(
|
|||
|
a = Pbind(\dur, 0.5, \instrument, \sinegrain, \x, Pfunc { rrand(500, 600) });
|
|||
|
a = Pfset({ ~freq = { ~x.postln * 2 }; ~legato = 3; }, a);
|
|||
|
a.play;
|
|||
|
)
|
|||
|
::
|
|||
|
]
|
|||
|
|
|||
|
|