forked from DefinitelyTyped/DefinitelyTyped
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwaa.d.ts
1207 lines (1059 loc) · 65.6 KB
/
waa.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
// Type definitions for Web Audio API
// Project: http://www.w3.org/TR/webaudio/
// Definitions by: Baruch Berger </~https://github.com/bbss>, Kon <http://phyzkit.net/>, kubosho </~https://github.com/kubosho>
// Definitions: /~https://github.com/borisyankov/DefinitelyTyped
//
// This file refers to the latest published working draft (currently from 10 october 2013) http://www.w3.org/TR/2013/WD-webaudio-20131010/, not to be confused with the latest editor's draft http://webaudio.github.io/web-audio-api/
/// <reference path='../webrtc/MediaStream.d.ts' />
/**
* This interface represents a set of AudioNode objects and their connections. It allows for arbitrary routing of signals to the AudioDestinationNode (what the user ultimately hears). Nodes are created from the context and are then connected together. In most use cases, only a single AudioContext is used per document. An AudioContext is constructed as follows:
*
* var context = new AudioContext();
*/
interface AudioContext extends EventTarget {
/**
* An AudioDestinationNode with a single input representing the final destination for all audio (to be rendered to the audio hardware). All AudioNodes actively rendering audio will directly or indirectly connect to destination.
*/
destination: AudioDestinationNode;
/**
* The sample rate (in sample-frames per second) at which the AudioContext handles audio. It is assumed that all AudioNodes in the context run at this rate. In making this assumption, sample-rate converters or "varispeed" processors are not supported in real-time processing.
*/
sampleRate: number;
/**
* This is a time in seconds which starts at zero when the context is created and increases in real-time. All scheduled times are relative to it. This is not a "transport" time which can be started, paused, and re-positioned. It is always moving forward. A GarageBand-like timeline transport system can be very easily built on top of this (in JavaScript). This time corresponds to an ever-increasing hardware timestamp.
*/
currentTime: number;
/**
* An AudioListener which is used for 3D spatialization.
*/
listener: AudioListener;
/**
* Creates an AudioBuffer of the given size. The audio data in the buffer will be zero-initialized (silent). An exception will be thrown if the numberOfChannels or sampleRate are out-of-bounds.
* @param numberOfChannels how many channels the buffer will have. An implementation must support at least 32 channels.
* @param length the size of the buffer in sample-frames.
* @param sampleRate the sample-rate of the linear PCM audio data in the buffer in sample-frames per second. An implementation must support sample-rates in at least the range 22050 to 96000.
*/
createBuffer(numberOfChannels: number, length: number, sampleRate: number): AudioBuffer;
/**
* Creates an AudioBuffer given the audio file data contained in the ArrayBuffer. The ArrayBuffer can, for example, be loaded from an XMLHttpRequest's response attribute after setting the responseType to "arraybuffer". Audio file data can be in any of the formats supported by the audio element.
* The following steps must be performed:
* 1. Decode the encoded buffer from the AudioBuffer into linear PCM. If a decoding error is encountered due to the audio format not being recognized or supported, or because of corrupted/unexpected/inconsistent data then return NULL (and these steps will be terminated).
* 2. If mixToMono is true, then mixdown the decoded linear PCM data to mono.
* 3. Take the decoded (possibly mixed-down) linear PCM audio data, and resample it to the sample-rate of the AudioContext if it is different from the sample-rate of buffer. The final result will be stored in an AudioBuffer and returned as the result of this method.
* @param buffer the audio file data (for example from a .wav file).
* @param mixToMono if a mixdown to mono will be performed. Normally, this would not be set.
*/
createBuffer(buffer: ArrayBuffer, mixToMono: boolean): AudioBuffer;
/**
* Asynchronously decodes the audio file data contained in the ArrayBuffer. The ArrayBuffer can, for example, be loaded from an XMLHttpRequest's response attribute after setting the responseType to "arraybuffer". Audio file data can be in any of the formats supported by the audio element.
* The decodeAudioData() method is preferred over the createBuffer() from ArrayBuffer method because it is asynchronous and does not block the main JavaScript thread.
*
* The following steps must be performed:
* 1. Temporarily neuter the audioData ArrayBuffer in such a way that JavaScript code may not access or modify the data.
* 2. Queue a decoding operation to be performed on another thread.
* 3. The decoding thread will attempt to decode the encoded audioData into linear PCM. If a decoding error is encountered due to the audio format not being recognized or supported, or because of corrupted/unexpected/inconsistent data then the audioData neutered state will be restored to normal and the errorCallback will be scheduled to run on the main thread's event loop and these steps will be terminated.
* 4. The decoding thread will take the result, representing the decoded linear PCM audio data, and resample it to the sample-rate of the AudioContext if it is different from the sample-rate of audioData. The final result (after possibly sample-rate converting) will be stored in an AudioBuffer.
* 5. The audioData neutered state will be restored to normal
* 6. The successCallback function will be scheduled to run on the main thread's event loop given the AudioBuffer from step (4) as an argument.
*
* @param audioData an ArrayBuffer containing audio file data.
* @param successCallback callback function which will be invoked when the decoding is finished. The single argument to this callback is an AudioBuffer representing the decoded PCM audio data.
* @param errorCallback callback function which will be invoked if there is an error decoding the audio file data.
*/
decodeAudioData(audioData: ArrayBuffer, successCallback: (decodedData: AudioBuffer) => any, errorCallback?: Function): void;
/**
* Creates an AudioBufferSourceNode.
*/
createBufferSource(): AudioBufferSourceNode;
/**
* Creates a MediaElementAudioSourceNode given an HTMLMediaElement. As a consequence of calling this method, audio playback from the HTMLMediaElement will be re-routed into the processing graph of the AudioContext.
*/
createMediaElementSource(mediaElement: HTMLMediaElement): MediaElementAudioSourceNode;
/**
* Creates a MediaStreamAudioSourceNode given a MediaStream. As a consequence of calling this method, audio playback from the MediaStream will be re-routed into the processing graph of the AudioContext.
*/
createMediaStreamSource(mediaStream: MediaStream): MediaStreamAudioSourceNode;
/**
* Creates a MediaStreamAudioDestinationNode.
*/
createMediaStreamDestination(): MediaStreamAudioDestinationNode;
/**
* Creates a ScriptProcessorNode for direct audio processing using JavaScript. An exception will be thrown if bufferSize or numberOfInputChannels or numberOfOutputChannels are outside the valid range.
* It is invalid for both numberOfInputChannels and numberOfOutputChannels to be zero.
* @param bufferSize the buffer size in units of sample-frames. It must be one of the following values: 256, 512, 1024, 2048, 4096, 8192, 16384. This value controls how frequently the onaudioprocess event handler is called and how many sample-frames need to be processed each call. Lower values for bufferSize will result in a lower (better) latency. Higher values will be necessary to avoid audio breakup and glitches. The value chosen must carefully balance between latency and audio quality.
* @param numberOfInputChannels (defaults to 2) the number of channels for this node's input. Values of up to 32 must be supported.
* @param numberOfOutputChannels (defaults to 2) the number of channels for this node's output. Values of up to 32 must be supported.
*/
createScriptProcessor(bufferSize?: number, numberOfInputChannels?: number, numberOfOutputChannels?: number): ScriptProcessorNode;
/**
* Creates a AnalyserNode.
*/
createAnalyser(): AnalyserNode;
/**
* Creates a GainNode.
*/
createGain(): GainNode;
/**
* Creates a DelayNode representing a variable delay line. The initial default delay time will be 0 seconds.
* @param maxDelayTime the maximum delay time in seconds allowed for the delay line. If specified, this value must be greater than zero and less than three minutes or a NOT_SUPPORTED_ERR exception will be thrown.
*/
createDelay(maxDelayTime?: number): DelayNode;
/**
* Creates a BiquadFilterNode representing a second order filter which can be configured as one of several common filter types.
*/
createBiquadFilter(): BiquadFilterNode;
/**
* Creates a WaveShaperNode representing a non-linear distortion.
*/
createWaveShaper(): WaveShaperNode;
/**
* Creates an PannerNode.
*/
createPanner(): PannerNode;
/**
* Creates a ConvolverNode.
*/
createConvolver(): ConvolverNode;
/**
* Creates an ChannelSplitterNode representing a channel splitter. An exception will be thrown for invalid parameter values.
* @param numberOfOutputs the number of outputs. Values of up to 32 must be supported. If not specified, then 6 will be used.
*/
createChannelSplitter(numberOfOutputs?: number): ChannelSplitterNode;
/**
* Creates an ChannelMergerNode representing a channel merger. An exception will be thrown for invalid parameter values.
* @param numberOfInputs the number of inputs. Values of up to 32 must be supported. If not specified, then 6 will be used.
*/
createChannelMerger(numberOfInputs?: number): ChannelMergerNode;
/**
* Creates a DynamicsCompressorNode.
*/
createDynamicsCompressor(): DynamicsCompressorNode;
/**
* Creates an OscillatorNode.
*/
createOscillator(): OscillatorNode;
/**
* Creates a PeriodicWave representing a waveform containing arbitrary harmonic content. The real and imag parameters must be of type Float32Array (described in [TYPED-ARRAYS]) of equal lengths greater than zero and less than or equal to 4096 or an IndexSizeError exception must be thrown. These parameters specify the Fourier coefficients of a Fourier series representing the partials of a periodic waveform. The created PeriodicWave will be used with an OscillatorNode and will represent a normalized time-domain waveform having maximum absolute peak value of 1. Another way of saying this is that the generated waveform of an OscillatorNode will have maximum peak value at 0dBFS. Conveniently, this corresponds to the full-range of the signal values used by the Web Audio API. Because the PeriodicWave will be normalized on creation, the real and imag parameters represent relative values.
* As PeriodicWave objects maintain their own representation, any modification of the arrays uses as the real and imag parameters after the call to createPeriodicWave() will have no effect on the PeriodicWave object.
* @param real an array of cosine terms (traditionally the A terms). In audio terminology, the first element (index 0) is the DC-offset of the periodic waveform and is usually set to zero. The second element (index 1) represents the fundamental frequency. The third element represents the first overtone, and so on.
* @param imag an array of sine terms (traditionally the B terms). The first element (index 0) should be set to zero (and will be ignored) since this term does not exist in the Fourier series. The second element (index 1) represents the fundamental frequency. The third element represents the first overtone, and so on.
*/
createPeriodicWave(real: Float32Array, imag: Float32Array): PeriodicWave;
}
declare var AudioContext: {
new (): AudioContext;
}
declare var webkitAudioContext: {
new (): AudioContext;
}
/**
* OfflineAudioContext is a particular type of AudioContext for rendering/mixing-down (potentially) faster than real-time. It does not render to the audio hardware, but instead renders as quickly as possible, calling a render callback function upon completion with the result provided as an AudioBuffer. It is constructed by specifying the numberOfChannels, length, and sampleRate as follows:
*
* var offlineContext = new OfflineAudioContext(unsigned long numberOfChannels, unsigned long length, float sampleRate);
*/
interface OfflineAudioContext extends AudioContext{
startRendering(): void;
oncomplete: EventHandler;
}
declare var OfflineAudioContext: {
new (numberOfChannels: number, length: number, sampleRate: number): OfflineAudioContext;
}
declare var webkitOfflineAudioContext: {
new (numberOfChannels: number, length: number, sampleRate: number): OfflineAudioContext;
}
interface OfflineAudioCompletionEvent extends Event {
/**
* An AudioBuffer containing the rendered audio data once an OfflineAudioContext has finished rendering. It will have a number of channels equal to the numberOfChannels parameter of the OfflineAudioContext constructor.
*/
renderedBuffer: AudioBuffer;
}
declare enum ChannelCountMode {
'max',
'clamped-max',
'explicit'
}
declare enum ChannelInterpretation {
speakers,
discrete
}
/**
* AudioNodes are the building blocks of an AudioContext. This interface represents audio sources, the audio destination, and intermediate processing modules. These modules can be connected together to form processing graphs for rendering audio to the audio hardware. Each node can have inputs and/or outputs. An AudioSourceNode has no inputs and a single output. An AudioDestinationNode has one input and no outputs and represents the final destination to the audio hardware. Most processing nodes such as filters will have one input and one output. Each type of AudioNode differs in the details of how it processes or synthesizes audio. But, in general, AudioNodes will process its inputs (if it has any), and generate audio for its outputs (if it has any).
*
* An output may connect to one or more AudioNode inputs, thus fanout is supported. An input may be connected from one or more AudioNode outputs, thus fanin is supported.
*
* In order to handle this fanin, any AudioNode with inputs performs an up-mixing of all connections for each input:
*
* 1. Calculate N: the maximum number of channels of all the connections to the input. For example, if an input has a mono connection and a stereo connection then this number will be 2.
* 2. For each connection to the input, up-mix to N channels.
* 3. Mix together all the up-mixed streams from (2). This is a straight-forward mixing together of each of the corresponding channels from each connection.
*
* Please see Mixer Gain Structure for more informative details.
*
* For performance reasons, practical implementations will need to use block processing, with each AudioNode processing a fixed number of sample-frames of size block-size. In order to get uniform behavior across implementations, we will define this value explicitly. block-size is defined to be 128 sample-frames which corresponds to roughly 3ms at a sample-rate of 44.1KHz.
*/
interface AudioNode extends EventTarget {
/**
* Connects the AudioNode to another AudioNode.
*
* It is possible to connect an AudioNode output to more than one input with multiple calls to connect(). Thus, "fanout" is supported.
*
* It is possible to connect an AudioNode to another AudioNode which creates a cycle. In other words, an AudioNode may connect to another AudioNode, which in turn connects back to the first AudioNode. This is allowed only if there is at least one DelayNode in the cycle or an exception will be thrown.
*
* There can only be one connection between a given output of one specific node and a given input of another specific node. Multiple connections with the same termini are ignored. For example:
*
* nodeA.connect(nodeB);
* nodeA.connect(nodeB);
*
* will have the same effect as
*
* nodeA.connect(nodeB);
*
* @param destination the AudioNode to connect to.
* @param output an index describing which output of the AudioNode from which to connect. An out-of-bound value throws an exception.
* @param input an index describing which input of the destination AudioNode to connect to. An out-of-bound value throws an exception.
*/
connect(destination: AudioNode, output?: number, input?: number): void;
/**
* Connects the AudioNode to an AudioParam, controlling the parameter value with an audio-rate signal.
*
* It is possible to connect an AudioNode output to more than one AudioParam with multiple calls to connect(). Thus, "fanout" is supported.
*
* It is possible to connect more than one AudioNode output to a single AudioParam with multiple calls to connect(). Thus, "fanin" is supported.
*
* An AudioParam will take the rendered audio data from any AudioNode output connected to it and convert it to mono by down-mixing if it is not already mono, then mix it together with other such outputs and finally will mix with the intrinsic parameter value (the value the AudioParam would normally have without any audio connections), including any timeline changes scheduled for the parameter.
*
* There can only be one connection between a given output of one specific node and a specific AudioParam. Multiple connections with the same termini are ignored. For example:
*
* nodeA.connect(param);
* nodeA.connect(param);
*
* will have the same effect as
*
* nodeA.connect(param);
*
* @param destination the AudioParam to connect to.
* @param output an index describing which output of the AudioNode from which to connect. An out-of-bound value throws an exception.
*/
connect(destination: AudioParam, output?: number): void;
/**
* Disconnects an AudioNode's output.
* @param output an index describing which output of the AudioNode to disconnect. An out-of-bound value throws an exception.
*/
disconnect(output?: number): void;
/**
* The AudioContext which owns this AudioNode.
*/
context: AudioContext;
/**
* The number of inputs feeding into the AudioNode. This will be 0 for an AudioSourceNode.
*/
numberOfInputs: number;
/**
* The number of outputs coming out of the AudioNode. This will be 0 for an AudioDestinationNode.
*/
numberOfOutputs: number;
/**
* The number of channels used when up-mixing and down-mixing connections to any inputs to the node. The default value is 2 except for specific nodes where its value is specially determined. This attribute has no effect for nodes with no inputs. If this value is set to zero, the implementation MUST throw a NOT_SUPPORTED_ERR exception.
*/
channelCount: number;
/**
* Determines how channels will be counted when up-mixing and down-mixing connections to any inputs to the node . This attribute has no effect for nodes with no inputs.
*
* See the Channel up-mixing and down-mixing section for more information on this attribute.
*/
channelCountMode: ChannelCountMode;
/**
* Determines how individual channels will be treated when up-mixing and down-mixing connections to any inputs to the node. This attribute has no effect for nodes with no inputs.
*
* See the Channel up-mixing and down-mixing section for more information on this attribute.
*/
channelInterpretation: ChannelInterpretation;
}
/**
* This is an abstract interface representing an audio source, an AudioNode which has no inputs and a single output:
*
* numberOfInputs : 0
* numberOfOutputs : 1
*
* Subclasses of AudioSourceNode will implement specific types of audio sources.
*/
interface AudioSourceNode extends AudioNode {
}
/**
* This is an AudioNode representing the final audio destination and is what the user will ultimately hear. It can be considered as an audio output device which is connected to speakers. All rendered audio to be heard will be routed to this node, a "terminal" node in the AudioContext's routing graph. There is only a single AudioDestinationNode per AudioContext, provided through the destination attribute of AudioContext.
*
* numberOfInputs : 1
* numberOfOutputs : 0
*/
interface AudioDestinationNode extends AudioNode {
/**
* The maximum number of channels that the numberOfChannels attribute can be set to. An AudioDestinationNode representing the audio hardware end-point (the normal case) can potentially output more than 2 channels of audio if the audio hardware is multi-channel. maxNumberOfChannels is the maximum number of channels that this hardware is capable of supporting. If this value is 0, then this indicates that maxNumberOfChannels may not be changed. This will be the case for an AudioDestinationNode in an OfflineAudioContext.
* @readonly
*/
maxNumberOfChannels: number;
/**
* The number of channels of the destination's input. This value will default to 2, and may be set to any non-zero value less than or equal to maxNumberOfChannels. An exception will be thrown if this value is not within the valid range. Giving a concrete example, if the audio hardware supports 8-channel output, then we may set numberOfChannels to 8, and render 8-channels of output.
*/
numberOfChannels: number;
}
/**
* AudioParam controls an individual aspect of an AudioNode's functioning, such as volume. The parameter can be set immediately to a particular value using the "value" attribute. Or, value changes can be scheduled to happen at very precise times (in the coordinate system of AudioContext.currentTime), for envelopes, volume fades, LFOs, filter sweeps, grain windows, etc. In this way, arbitrary timeline-based automation curves can be set on any AudioParam. Additionally, audio signals from the outputs of AudioNodes can be connected to an AudioParam, summing with the intrinsic parameter value.
*
* Some synthesis and processing AudioNodes have AudioParams as attributes whose values must be taken into account on a per-audio-sample basis. For other AudioParams, sample-accuracy is not important and the value changes can be sampled more coarsely. Each individual AudioParam will specify that it is either an a-rate parameter which means that its values must be taken into account on a per-audio-sample basis, or it is a k-rate parameter.
*
* Implementations must use block processing, with each AudioNode processing 128 sample-frames in each block.
*
* For each 128 sample-frame block, the value of a k-rate parameter must be sampled at the time of the very first sample-frame, and that value must be used for the entire block. a-rate parameters must be sampled for each sample-frame of the block.
*/
interface AudioParam {
/**
* The parameter's floating-point value. This attribute is initialized to the defaultValue. If a value is set outside the allowable range described by minValue and maxValue no exception is thrown, because these limits are just nominal and may be exceeded. If a value is set during a time when there are any automation events scheduled then it will be ignored and no exception will be thrown.
*/
value: number;
/**
* Nominal minimum value. This attribute is informational and value may be set lower than this value.
*/
minValue: number;
/**
* Nominal maximum value. This attribute is informational and value may be set higher than this value.
*/
maxValue: number;
/**
* Initial value for the value attribute
*/
defaultValue: number;
/**
* Schedules a parameter value change at the given time.
*
* If there are no more events after this SetValue event, then for t >= startTime, v(t) = value. In other words, the value will remain constant.
*
* If the next event (having time T1) after this SetValue event is not of type LinearRampToValue or ExponentialRampToValue, then, for t: startTime <= t < T1, v(t) = value. In other words, the value will remain constant during this time interval, allowing the creation of "step" functions.
*
* If the next event after this SetValue event is of type LinearRampToValue or ExponentialRampToValue then please see details below.
*
* @param value the value the parameter will change to at the given time
* @param startTime parameter is the time in the same time coordinate system as AudioContext.currentTime.
*/
setValueAtTime(value: number, startTime: number): void;
/**
* Schedules a linear continuous change in parameter value from the previous scheduled parameter value to the given value.
*
* The value during the time interval T0 <= t < T1 (where T0 is the time of the previous event and T1 is the endTime parameter passed into this method) will be calculated as:
*
* v(t) = V0 + (V1 - V0) * ((t - T0) / (T1 - T0))
*
* Where V0 is the value at the time T0 and V1 is the value parameter passed into this method.
*
* If there are no more events after this LinearRampToValue event then for t >= T1, v(t) = V1
*
* @param value the value the parameter will linearly ramp to at the given time.
* @param endTime the time in the same time coordinate system as AudioContext.currentTime.
*/
linearRampToValueAtTime(value: number, endTime: number): void;
/**
* Schedules an exponential continuous change in parameter value from the previous scheduled parameter value to the given value. Parameters representing filter frequencies and playback rate are best changed exponentially because of the way humans perceive sound.
*
* The value during the time interval T0 <= t < T1 (where T0 is the time of the previous event and T1 is the endTime parameter passed into this method) will be calculated as:
*
* v(t) = V0 * (V1 / V0) ^ ((t - T0) / (T1 - T0))
*
* Where V0 is the value at the time T0 and V1 is the value parameter passed into this method.
*
* If there are no more events after this ExponentialRampToValue event then for t >= T1, v(t) = V1
*
* @param value the value the parameter will exponentially ramp to at the given time. An exception will be thrown if this value is less than or equal to 0, or if the value at the time of the previous event is less than or equal to 0.
* @param endTime the time in the same time coordinate system as AudioContext.currentTime.
*/
exponentialRampToValueAtTime(value: number, endTime: number): void;
/**
* Start exponentially approaching the target value at the given time with a rate having the given time constant. Among other uses, this is useful for implementing the "decay" and "release" portions of an ADSR envelope. Please note that the parameter value does not immediately change to the target value at the given time, but instead gradually changes to the target value.
*
* More precisely, timeConstant is the time it takes a first-order linear continuous time-invariant system to reach the value 1 - 1/e (around 63.2%) given a step input response (transition from 0 to 1 value).
*
* During the time interval: T0 <= t < T1, where T0 is the startTime parameter and T1 represents the time of the event following this event (or infinity if there are no following events):
*
* v(t) = V1 + (V0 - V1) * exp(-(t - T0) / timeConstant)
*
* Where V0 is the initial value (the .value attribute) at T0 (the startTime parameter) and V1 is equal to the target parameter.
*
* @param target the value the parameter will start changing to at the given time.
* @param startTime the time in the same time coordinate system as AudioContext.currentTime.
* @param timeConstant the time-constant value of first-order filter (exponential) approach to the target value. The larger this value is, the slower the transition will be.
*/
setTargetValueAtTime(target: number, startTime: number, timeConstant: number): void;
/**
* Sets an array of arbitrary parameter values starting at the given time for the given duration. The number of values will be scaled to fit into the desired duration.
*
* During the time interval: startTime <= t < startTime + duration, values will be calculated:
*
* v(t) = values[N * (t - startTime) / duration], where N is the length of the values array.
*
* After the end of the curve time interval (t >= startTime + duration), the value will remain constant at the final curve value, until there is another automation event (if any).
*
* @param values a Float32Array representing a parameter value curve. These values will apply starting at the given time and lasting for the given duration.
* @param startTime the time in the same time coordinate system as AudioContext.currentTime.
* @param duration the amount of time in seconds (after the time parameter) where values will be calculated according to the values parameter..
*
*/
setValueCurveAtTime(values: Float32Array, startTime: number, duration: number): void;
/**
* Cancels all scheduled parameter changes with times greater than or equal to startTime.
*
* @param startTime the starting time at and after which any previously scheduled parameter changes will be cancelled. It is a time in the same time coordinate system as AudioContext.currentTime.
*/
cancelScheduledValues(startTime: number): void;
}
/**
* Changing the gain of an audio signal is a fundamental operation in audio applications. The GainNode is one of the building blocks for creating mixers. This interface is an AudioNode with a single input and single output:
*
* numberOfInputs : 1
* numberOfOutputs : 1
*
* which multiplies the input audio signal by the (possibly time-varying) gain attribute, copying the result to the output. By default, it will take the input and pass it through to the output unchanged, which represents a constant gain change of 1.
*
* As with other AudioParams, the gain parameter represents a mapping from time (in the coordinate system of AudioContext.currentTime) to floating-point value. Every PCM audio sample in the input is multiplied by the gain parameter's value for the specific time corresponding to that audio sample. This multiplied value represents the PCM audio sample for the output.
*
* The number of channels of the output will always equal the number of channels of the input, with each channel of the input being multiplied by the gain values and being copied into the corresponding channel of the output.
*
* The implementation must make gain changes to the audio stream smoothly, without introducing noticeable clicks or glitches. This process is called "de-zippering".
*/
interface GainNode extends AudioNode {
/**
* Represents the amount of gain to apply. Its default value is 1 (no gain change). The nominal minValue is 0, but may be set negative for phase inversion. The nominal maxValue is 1, but higher values are allowed (no exception thrown).This parameter is a-rate
*/
gain: AudioParam;
}
/**
* A delay-line is a fundamental building block in audio applications. This interface is an AudioNode with a single input and single output:
*
* numberOfInputs : 1
* numberOfOutputs : 1
*
* which delays the incoming audio signal by a certain amount. The default amount is 0 seconds (no delay). When the delay time is changed, the implementation must make the transition smoothly, without introducing noticeable clicks or glitches to the audio stream.
*/
interface DelayNode extends AudioNode {
/**
* An AudioParam object representing the amount of delay (in seconds) to apply. The default value (delayTime.value) is 0 (no delay). The minimum value is 0 and the maximum value is determined by the maxDelayTime argument to the AudioContext method createDelay. This parameter is k-rate
*/
delayTime: AudioParam;
}
/**
* This interface represents a memory-resident audio asset (for one-shot sounds and other short audio clips). Its format is non-interleaved IEEE 32-bit linear PCM with a nominal range of -1 -> +1. It can contain one or more channels. It is analogous to a WebGL texture. Typically, it would be expected that the length of the PCM data would be fairly short (usually somewhat less than a minute). For longer sounds, such as music soundtracks, streaming should be used with the audio element and MediaElementAudioSourceNode.
*
* An AudioBuffer may be used by one or more AudioContexts.
*/
interface AudioBuffer {
/**
* The sample-rate for the PCM audio data in samples per second.
* @readonly
*/
sampleRate: number;
/**
* Length of the PCM audio data in sample-frames.
* @readonly
*/
length: number;
/**
* Duration of the PCM audio data in seconds.
* @readonly
*/
duration: number;
/**
* The number of discrete audio channels.
* @readonly
*/
numberOfChannels: number;
/**
* Returns the Float32Array representing the PCM audio data for the specific channel.
*
* The channel parameter is an index representing the particular channel to get data for. An index value of 0 represents the first channel. This index value MUST be less than numberOfChannels or an exception will be thrown.
*/
getChannelData(channel: number): Float32Array;
}
/**
* This interface represents an audio source from an in-memory audio asset in an AudioBuffer. It is useful for playing short audio assets which require a high degree of scheduling flexibility (can playback in rhythmically perfect ways). The start() method is used to schedule when sound playback will happen. The playback will stop automatically when the buffer's audio data has been completely played (if the loop attribute is false), or when the stop() method has been called and the specified time has been reached. Please see more details in the start() and stop() description. start() and stop() may not be issued multiple times for a given AudioBufferSourceNode.
*
* numberOfInputs : 0
* numberOfOutputs : 1
*/
interface AudioBufferSourceNode extends AudioNode {
/**
* Represents the audio asset to be played.
*/
buffer: AudioBuffer;
/**
* The speed at which to render the audio stream. The default playbackRate.value is 1. This parameter is a-rate
*/
playbackRate: AudioParam;
/**
* Indicates if the audio data should play in a loop. The default value is false.
*/
loop: boolean;
/**
* An optional value in seconds where looping should begin if the loop attribute is true. Its default value is 0, and it may usefully be set to any value between 0 and the duration of the buffer.
*/
loopStart: number;
/**
* An optional value in seconds where looping should end if the loop attribute is true. Its default value is 0, and it may usefully be set to any value between 0 and the duration of the buffer.
*/
loopEnd: number;
/**
* A property used to set the EventHandler for the ended event that is dispatched to AudioBufferSourceNode node types. When the playback of the buffer for an AudioBufferSourceNode is finished, an event of type Event will be dispatched to the event handler.
*/
onended: EventHandler;
/**
* Schedules a sound to playback at an exact time.
*
* @param when time (in seconds) the sound should start playing. It is in the same time coordinate system as AudioContext.currentTime. If 0 is passed in for this value or if the value is less than currentTime, then the sound will start playing immediately. start may only be called one time and must be called before stop is called or an exception will be thrown.
* @param offset the offset time in the buffer (in seconds) where playback will begin. This parameter is optional with a default value of 0 (playing back from the beginning of the buffer).
* @param duration the duration of the portion (in seconds) to be played. This parameter is optional, with the default value equal to the total duration of the AudioBuffer minus the offset parameter. Thus if neither offset nor duration are specified then the implied duration is the total duration of the AudioBuffer.
*/
start(when?: number, offset?: number, duration?: number): void;
/**
* Schedules a sound to stop playback at an exact time. Please see deprecation section for the old method name.
*
* The when parameter describes at what time (in seconds) the sound should stop playing. It is in the same time coordinate system as AudioContext.currentTime. If 0 is passed in for this value or if the value is less than currentTime, then the sound will stop playing immediately. stop must only be called one time and only after a call to start or stop, or an exception will be thrown.
*/
stop(when?: number): void;
}
/*
* This interface represents an audio source from an audio or video element.
*
* numberOfInputs : 0
* numberOfOutputs : 1
*/
interface MediaElementAudioSourceNode extends AudioNode {
}
interface AudioProcessingEventHandler {
(e: AudioProcessingEvent): void;
}
/**
* This interface is an AudioNode which can generate, process, or analyse audio directly using JavaScript.
*
* numberOfInputs : 1
* numberOfOutputs : 1
*
* The ScriptProcessorNode is constructed with a bufferSize which must be one of the following values: 256, 512, 1024, 2048, 4096, 8192, 16384. This value controls how frequently the onaudioprocess event handler is called and how many sample-frames need to be processed each call. Lower numbers for bufferSize will result in a lower (better) latency. Higher numbers will be necessary to avoid audio breakup and glitches. The value chosen must carefully balance between latency and audio quality.
*
* numberOfInputChannels and numberOfOutputChannels determine the number of input and output channels. It is invalid for both numberOfInputChannels and numberOfOutputChannels to be zero.
*
* var node = context.createScriptProcessor(bufferSize, numberOfInputChannels, numberOfOutputChannels);
*/
interface ScriptProcessorNode extends AudioNode {
/**
* An event listener which is called periodically for audio processing. An event of type AudioProcessingEvent will be passed to the event handler.
*/
onaudioprocess: AudioProcessingEventHandler;
/**
* The size of the buffer (in sample-frames) which needs to be processed each time onprocessaudio is called. Legal values are (256, 512, 1024, 2048, 4096, 8192, 16384).
*/
bufferSize: number;
}
/**
* This interface is a type of Event which is passed to the onaudioprocess event handler used by ScriptProcessorNode.
*
* The event handler processes audio from the input (if any) by accessing the audio data from the inputBuffer attribute. The audio data which is the result of the processing (or the synthesized data if there are no inputs) is then placed into the outputBuffer.
*/
interface AudioProcessingEvent extends Event {
/**
* The time when the audio will be played in the same time coordinate system as AudioContext.currentTime. playbackTime allows for very tight synchronization between processing directly in JavaScript with the other events in the context's rendering graph.
*/
playbackTime: number;
/**
* An AudioBuffer containing the input audio data. It will have a number of channels equal to the numberOfInputChannels parameter of the createScriptProcessor() method. This AudioBuffer is only valid while in the scope of the onaudioprocess function. Its values will be meaningless outside of this scope.
*/
inputBuffer: AudioBuffer;
/**
* An AudioBuffer where the output audio data should be written. It will have a number of channels equal to the numberOfOutputChannels parameter of the createScriptProcessor() method. Script code within the scope of the onaudioprocess function is expected to modify the Float32Array arrays representing channel data in this AudioBuffer. Any script modifications to this AudioBuffer outside of this scope will not produce any audible effects.
*/
outputBuffer: AudioBuffer;
}
declare enum PanningModelType {
/**
* A simple and efficient spatialization algorithm using equal-power panning.
*/
equalpower,
/**
* A higher quality spatialization algorithm using a convolution with measured impulse responses from human subjects. This panning method renders stereo output.
*/
HRTF
}
declare enum DistanceModelType {
/**
* A linear distance model which calculates distanceGain according to:
* 1 - rolloffFactor * (distance - refDistance) / (maxDistance - refDistance)
*/
linear,
/**
* An inverse distance model which calculates distanceGain according to:
* refDistance / (refDistance + rolloffFactor * (distance - refDistance))
*/
inverse,
/**
* An exponential distance model which calculates distanceGain according to:
* pow(distance / refDistance, -rolloffFactor)
*/
exponential
}
/**
* This interface represents a processing node which positions / spatializes an incoming audio stream in three-dimensional space. The spatialization is in relation to the AudioContext's AudioListener (listener attribute).
*
* numberOfInputs : 1
* numberOfOutputs : 1
*
* The audio stream from the input will be either mono or stereo, depending on the connection(s) to the input.
*
* The output of this node is hard-coded to stereo (2 channels) and currently cannot be configured.
*/
interface PannerNode extends AudioNode {
/**
* Determines which spatialization algorithm will be used to position the audio in 3D space. The default is "HRTF".
*/
panningModel: PanningModelType;
/**
* Sets the position of the audio source relative to the listener attribute. A 3D cartesian coordinate system is used.
*
* The default value is (0,0,0)
*
* @param x the x coordinates in 3D space.
* @param y the y coordinates in 3D space.
* @param z the z coordinates in 3D space.
*/
setPosition(x: number, y: number, z: number): void;
/**
* Describes which direction the audio source is pointing in the 3D cartesian coordinate space. Depending on how directional the sound is (controlled by the cone attributes), a sound pointing away from the listener can be very quiet or completely silent.
*
* The default value is (1,0,0)
*
* @param x
* @param y
* @param z
*/
setOrientation(x: number, y: number, z: number): void;
/**
* Sets the velocity vector of the audio source. This vector controls both the direction of travel and the speed in 3D space. This velocity relative to the listener's velocity is used to determine how much doppler shift (pitch change) to apply. The units used for this vector is meters / second and is independent of the units used for position and orientation vectors.
*
* The default value is (0,0,0)
*
* @param x a direction vector indicating direction of travel and intensity.
* @param y
* @param z
*/
setVelocity(x: number, y: number, z: number): void;
/**
* Determines which algorithm will be used to reduce the volume of an audio source as it moves away from the listener. The default is "inverse".
*/
distanceModel: DistanceModelType;
/**
* A reference distance for reducing volume as source move further from the listener. The default value is 1.
*/
refDistance: number;
/**
* The maximum distance between source and listener, after which the volume will not be reduced any further. The default value is 10000.
*/
maxDistance: number;
/**
* Describes how quickly the volume is reduced as source moves away from listener. The default value is 1.
*/
rolloffFactor: number;
/**
* A parameter for directional audio sources, this is an angle, inside of which there will be no volume reduction. The default value is 360.
*/
coneInnerAngle: number;
/**
* A parameter for directional audio sources, this is an angle, outside of which the volume will be reduced to a constant value of coneOuterGain. The default value is 360.
*/
coneOuterAngle: number;
/**
* A parameter for directional audio sources, this is the amount of volume reduction outside of the coneOuterAngle. The default value is 0.
*/
coneOuterGain: number;
}
/**
* This interface represents the position and orientation of the person listening to the audio scene. All PannerNode objects spatialize in relation to the AudioContext's listener. See this section for more details about spatialization.
*/
interface AudioListener {
/**
* A constant used to determine the amount of pitch shift to use when rendering a doppler effect. The default value is 1.
*/
dopplerFactor: number;
/**
* The speed of sound used for calculating doppler shift. The default value is 343.3 meters / second.
*/
speedOfSound: number;
/**
* Sets the position of the listener in a 3D cartesian coordinate space. PannerNode objects use this position relative to individual audio sources for spatialization.
*
* The default value is (0,0,0)
*
* @param x
* @param y
* @param z
*/
setPosition(x: number, y: number, z: number): void;
/**
* Describes which direction the listener is pointing in the 3D cartesian coordinate space. Both a front vector and an up vector are provided. In simple human terms, the front vector represents which direction the person's nose is pointing. The up vector represents the direction the top of a person's head is pointing. These values are expected to be linearly independent (at right angles to each other). For normative requirements of how these values are to be interpreted, see the spatialization section.
*
* @param x x coordinate of a front direction vector in 3D space, with the default value being 0
* @param y y coordinate of a front direction vector in 3D space, with the default value being 0
* @param z z coordinate of a front direction vector in 3D space, with the default value being -1
* @param xUp x coodinate of an up direction vector in 3D space, with the default value being 0
* @param yUp y coodinate of an up direction vector in 3D space, with the default value being 1
* @param zUp z coodinate of an up direction vector in 3D space, with the default value being 0
*/
setOrientation(x: number, y: number, z: number, xUp: number, yUp: number, zUp: number): void;
/**
* Sets the velocity vector of the listener. This vector controls both the direction of travel and the speed in 3D space. This velocity relative to an audio source's velocity is used to determine how much doppler shift (pitch change) to apply. The units used for this vector is meters / second and is independent of the units used for position and orientation vectors.
*
* @param x x coordinate of a direction vector indicating direction of travel and intensity. The default value is 0
* @param y y coordinate of a direction vector indicating direction of travel and intensity. The default value is 0
* @param z z coordinate of a direction vector indicating direction of travel and intensity. The default value is 0
*/
setVelocity(x: number, y: number, z: number): void;
}
/**
* This interface represents a processing node which applies a linear convolution effect given an impulse response. Normative requirements for multi-channel convolution matrixing are described [here](http://www.w3.org/TR/2012/WD-webaudio-20121213/#Convolution-reverb-effect).
*
* numberOfInputs : 1
* numberOfOutputs : 1
*/
interface ConvolverNode extends AudioNode {
/**
* A mono, stereo, or 4-channel AudioBuffer containing the (possibly multi-channel) impulse response used by the ConvolverNode. At the time when this attribute is set, the buffer and the state of the normalize attribute will be used to configure the ConvolverNode with this impulse response having the given normalization.
*/
buffer: AudioBuffer;
/**
* Controls whether the impulse response from the buffer will be scaled by an equal-power normalization when the buffer atttribute is set. Its default value is true in order to achieve a more uniform output level from the convolver when loaded with diverse impulse responses. If normalize is set to false, then the convolution will be rendered with no pre-processing/scaling of the impulse response. Changes to this value do not take effect until the next time the buffer attribute is set.
*/
normalize: boolean;
}
/**
* This interface represents a node which is able to provide real-time frequency and time-domain analysis information. The audio stream will be passed un-processed from input to output.
*
* numberOfInputs : 1
* numberOfOutputs : 1 Note that this output may be left unconnected.
*/
interface AnalyserNode extends AudioNode {
/**
* Copies the current frequency data into the passed floating-point array. If the array has fewer elements than the frequencyBinCount, the excess elements will be dropped.
* @param array where frequency-domain analysis data will be copied.
*/
getFloatFrequencyData(array: Float32Array): void;
/**
* Copies the current frequency data into the passed unsigned byte array. If the array has fewer elements than the frequencyBinCount, the excess elements will be dropped.
* @param array where frequency-domain analysis data will be copied.
*/
getByteFrequencyData(array: Uint8Array): void;
/**
* Copies the current time-domain (waveform) data into the passed unsigned byte array. If the array has fewer elements than the frequencyBinCount, the excess elements will be dropped. If the array has more elements than fftSize, the excess elements will be ignored.
* @param array where the time-domain sample data will be copied.
*/
getByteTimeDomainData(array: Uint8Array): void;
/**
* The size of the FFT used for frequency-domain analysis. This must be a power of two.
*/
fftSize: number;
/**
* Half the FFT size.
*/
frequencyBinCount: number;
/**
* The minimum power value in the scaling range for the FFT analysis data for conversion to unsigned byte values.
*/
minDecibels: number;
/**
* The maximum power value in the scaling range for the FFT analysis data for conversion to unsigned byte values.
*/
maxDecibels: number;
/**
* A value from 0 -> 1 where 0 represents no time averaging with the last analysis frame.
*/
smoothingTimeConstant: number;
}
/**
* The ChannelSplitterNode is for use in more advanced applications and would often be used in conjunction with ChannelMergerNode.
*
* numberOfInputs : 1
* numberOfOutputs : Variable N (defaults to 6) // number of "active" (non-silent) outputs is determined by number of channels in the input
*/
interface ChannelSplitterNode extends AudioNode {
}
/**
* The ChannelMergerNode is for use in more advanced applications and would often be used in conjunction with ChannelSplitterNode.
*
* numberOfInputs : Variable N (default to 6) // number of connected inputs may be less than this
* numberOfOutputs : 1
*/
interface ChannelMergerNode extends AudioNode {
}
/**
* DynamicsCompressorNode is an AudioNode processor implementing a dynamics compression effect.
*
* Dynamics compression is very commonly used in musical production and game audio. It lowers the volume of the loudest parts of the signal and raises the volume of the softest parts. Overall, a louder, richer, and fuller sound can be achieved. It is especially important in games and musical applications where large numbers of individual sounds are played simultaneous to control the overall signal level and help avoid clipping (distorting) the audio output to the speakers.
*
* numberOfInputs : 1
* numberOfOutputs : 1
*/
interface DynamicsCompressorNode extends AudioNode {
/**
* The decibel value above which the compression will start taking effect. Its default value is -24, with a nominal range of -100 to 0.
*/
threshold: AudioParam;
/**
* A decibel value representing the range above the threshold where the curve smoothly transitions to the "ratio" portion. Its default value is 30, with a nominal range of 0 to 40.
*/
knee: AudioParam;
/**
* The amount of dB change in input for a 1 dB change in output. Its default value is 12, with a nominal range of 1 to 20.
*/
ratio: AudioParam;
/**
* A read-only decibel value for metering purposes, representing the current amount of gain reduction that the compressor is applying to the signal. If fed no signal the value will be 0 (no gain reduction). The nominal range is -20 to 0.
*/
reduction: AudioParam;
/**
* The amount of time (in seconds) to reduce the gain by 10dB. Its default value is 0.003, with a nominal range of 0 to 1.
*/
attack: AudioParam;
/**
* The amount of time (in seconds) to increase the gain by 10dB. Its default value is 0.250, with a nominal range of 0 to 1.
*/
release: AudioParam;
}
declare enum BiquadFilterType {
/**
* A lowpass filter allows frequencies below the cutoff frequency to pass through and attenuates frequencies above the cutoff. It implements a standard second-order resonant lowpass filter with 12dB/octave rolloff.
*
* ## frequency
* The cutoff frequency
* ## Q
* Controls how peaked the response will be at the cutoff frequency. A large value makes the response more peaked. Please note that for this filter type, this value is not a traditional Q, but is a resonance value in decibels.
* ## gain
* Not used in this filter type
*/
lowpass,
/**
* A highpass filter is the opposite of a lowpass filter. Frequencies above the cutoff frequency are passed through, but frequencies below the cutoff are attenuated. It implements a standard second-order resonant highpass filter with 12dB/octave rolloff.
*
* ## frequency
* The cutoff frequency below which the frequencies are attenuated
* ## Q
* Controls how peaked the response will be at the cutoff frequency. A large value makes the response more peaked. Please note that for this filter type, this value is not a traditional Q, but is a resonance value in decibels.
* ## gain
* Not used in this filter type
*/
highpass,
/**
* A bandpass filter allows a range of frequencies to pass through and attenuates the frequencies below and above this frequency range. It implements a second-order bandpass filter.
*
* ## frequency
* The center of the frequency band
* ## Q
* Controls the width of the band. The width becomes narrower as the Q value increases.
* ## gain
* Not used in this filter type
*/
bandpass,
/**
* The lowshelf filter allows all frequencies through, but adds a boost (or attenuation) to the lower frequencies. It implements a second-order lowshelf filter.
*
* ## frequency
* The upper limit of the frequences where the boost (or attenuation) is applied.
* ## Q
* Not used in this filter type.
* ## gain
* The boost, in dB, to be applied. If the value is negative, the frequencies are attenuated.
*/
lowshelf,
/**
* The highshelf filter is the opposite of the lowshelf filter and allows all frequencies through, but adds a boost to the higher frequencies. It implements a second-order highshelf filter
*
* ## frequency
* The lower limit of the frequences where the boost (or attenuation) is applied.