scide: LookupDialog - redo lookup on classes after partial lookup
[supercollider.git] / HelpSource / Classes / GrainBuf.schelp
blob7a96e7ef9f4bf112d56030134c5cc071b63abf19
1 class:: GrainBuf
2 summary:: Granular synthesis with sound stored in a buffer
3 categories:: UGens>Buffer, UGens>Generators>Granular
4 related:: Classes/GrainIn, Classes/GrainFM, Classes/GrainSin
6 classmethods::
7 private:: categories
9 method:: ar
11 argument:: numChannels
12 the number of channels to output. If 1, mono is returned and pan is ignored.
14 argument:: trigger
15 a kr or ar trigger to start a new grain. If ar, grains after the start of the synth are sample accurate.
17 argument:: dur
18 size of the grain (in seconds).
20 argument:: sndbuf
21 the buffer holding a mono audio signal. If using multi-channel files, use Buffer.readChannel.
23 argument:: rate
24 the playback rate of the sampled sound
26 argument:: pos
27 the playback position for the grain to start with (0 is beginning, 1 is end of file)
29 argument:: interp
30 the interpolation method used for pitchshifting grains:
31 list::
32 ## 1 = no interpolation
33 ## 2 = linear
34 ## 4 = cubic interpolation (more computationally intensive)
37 argument:: pan
38 determines where to pan the output.
39 list::
40 ## If numChannels = 1, no panning is done.
41 ## If numChannels = 2, panning is similar to Pan2.
42 ## If numChannels > 2, pannins is the same as PanAz.
45 argument:: envbufnum
46 the buffer number containing a singal to use for the grain envelope. -1 uses a built-in Hann envelope.
48 argument:: maxGrains
49 the maximum number of overlapping grains that can be used at a given time. This value is set at the UGens init time and can't be modified. Defaults to 512. This can be set lower for more efficient use of memory.
51 warning:: The above parameter is new (post SC 3.3.1) and has the potential to break code written <= 3.3.1. This parameter is BEFORE the mul slot, and you may need to update code to account for this difference. ::
53 argument:: mul
55 argument:: add
57 discussion:: All args except numChannels and trigger are polled at grain creation time.
58 instancemethods::
59 private:: init, argNamesInputsOffset
61 examples::
62 code::
63 s.boot;
66 var winenv;
68 b = Buffer.read(s, Platform.resourceDir +/+ "sounds/a11wlk01-44_1.aiff");
69 // a custom envelope
70 winenv = Env([0, 1, 0], [0.5, 0.5], [8, -8]);
71 z = Buffer.sendCollection(s, winenv.discretize, 1);
73 SynthDef(\buf_grain_test, {arg gate = 1, amp = 1, sndbuf, envbuf;
74         var pan, env, freqdev;
75         // use mouse x to control panning
76         pan = MouseX.kr(-1, 1);
77         env = EnvGen.kr(
78                 Env([0, 1, 0], [1, 1], \sin, 1),
79                 gate,
80                 levelScale: amp,
81                 doneAction: 2);
82         Out.ar(0,
83                 GrainBuf.ar(2, Impulse.kr(10), 0.1, sndbuf, LFNoise1.kr.range(0.5, 2),
84                         LFNoise2.kr(0.1).range(0, 1), 2, pan, envbuf) * env)
85         }).send(s);
89 // use built-in env
90 x = Synth(\buf_grain_test, [\sndbuf, b, \envbuf, -1])
92 // switch to the custom env
93 x.set(\envbuf, z)
94 x.set(\envbuf, -1);
96 x.set(\gate, 0);