59 lines
1.2 KiB
Text
59 lines
1.2 KiB
Text
|
#lang scribble/manual
|
||
|
@(require (for-label racket))
|
||
|
|
||
|
@title{Dreset}
|
||
|
demand rate reset@section{categories}
|
||
|
UGens>Demand
|
||
|
|
||
|
@section{description}
|
||
|
|
||
|
The reset of a demand ugen can be controlled "from the outside" by the reset input of the link::Classes/Demand:: or link::Classes/Duty:: UGen, which consumes the chain of demands. Dreset allows to reset a subset of the chain internally.
|
||
|
|
||
|
@section{classmethods}
|
||
|
|
||
|
@section{method}
|
||
|
new
|
||
|
@section{argument}
|
||
|
in
|
||
|
a demand UGen, producing values which are passed through
|
||
|
@section{argument}
|
||
|
reset
|
||
|
a demand or any other UGen. When crossing from nonpositive to positive, it resets the first argument.
|
||
|
|
||
|
@section{examples}
|
||
|
|
||
|
|
||
|
@racketblock[
|
||
|
(
|
||
|
{
|
||
|
var a, freq;
|
||
|
a = Dreset(Dseries(0, 2, inf), Drand([0, 0, 0, 1], inf));
|
||
|
freq = Duty.kr(1/MouseX.kr(1, 40, 1), 0, a) * 30 + 340;
|
||
|
SinOsc.ar(freq) * 0.1
|
||
|
}.play;
|
||
|
)
|
||
|
|
||
|
// reset when mouse button is pressed
|
||
|
(
|
||
|
{
|
||
|
var a, freq;
|
||
|
a = Dreset(Dseries(0, 2, inf), MouseButton.kr);
|
||
|
freq = Duty.kr(1/MouseX.kr(1, 40, 1), 0, a) * 30 + 340;
|
||
|
SinOsc.ar(freq) * 0.1
|
||
|
}.play;
|
||
|
)
|
||
|
|
||
|
// audio rate
|
||
|
(
|
||
|
{
|
||
|
var a, nmax = 90;
|
||
|
a = { Dreset(Dseries(0, 1, inf), Drand(0 ! nmax ++ 1, inf)) } ! 2;
|
||
|
Duty.ar(SampleDur.ir, 0, a) * (0.1 / nmax)
|
||
|
}.play;
|
||
|
)
|
||
|
::
|
||
|
|
||
|
]
|
||
|
|
||
|
|