Skip to content

Commit 1cb0515

Browse files
tcl3pbrw
authored andcommitted
LibWeb: Implement the OscillatorNode.detune attribute
1 parent 2c3fdec commit 1cb0515

File tree

3 files changed

+9
-1
lines changed

3 files changed

+9
-1
lines changed

Libraries/LibWeb/WebAudio/OscillatorNode.cpp

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4,6 +4,7 @@
44
* SPDX-License-Identifier: BSD-2-Clause
55
*/
66

7+
#include <AK/Math.h>
78
#include <LibWeb/Bindings/Intrinsics.h>
89
#include <LibWeb/Bindings/OscillatorNodePrototype.h>
910
#include <LibWeb/WebAudio/AudioParam.h>
@@ -43,6 +44,7 @@ WebIDL::ExceptionOr<GC::Ref<OscillatorNode>> OscillatorNode::construct_impl(JS::
4344
OscillatorNode::OscillatorNode(JS::Realm& realm, GC::Ref<BaseAudioContext> context, OscillatorOptions const& options)
4445
: AudioScheduledSourceNode(realm, context)
4546
, m_frequency(AudioParam::create(realm, options.frequency, -context->nyquist_frequency(), context->nyquist_frequency(), Bindings::AutomationRate::ARate))
47+
, m_detune(AudioParam::create(realm, options.detune, -1200 * AK::log2(NumericLimits<float>::max()), 1200 * AK::log2(NumericLimits<float>::max()), Bindings::AutomationRate::ARate))
4648
{
4749
}
4850

@@ -83,6 +85,7 @@ void OscillatorNode::visit_edges(Cell::Visitor& visitor)
8385
{
8486
Base::visit_edges(visitor);
8587
visitor.visit(m_frequency);
88+
visitor.visit(m_detune);
8689
}
8790

8891
}

Libraries/LibWeb/WebAudio/OscillatorNode.h

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,8 @@ class OscillatorNode : public AudioScheduledSourceNode {
3434
WebIDL::ExceptionOr<void> set_type(Bindings::OscillatorType);
3535

3636
GC::Ref<AudioParam const> frequency() const { return m_frequency; }
37+
GC::Ref<AudioParam const> detune() const { return m_detune; }
38+
3739
WebIDL::UnsignedLong number_of_inputs() override { return 0; }
3840
WebIDL::UnsignedLong number_of_outputs() override { return 1; }
3941

@@ -51,6 +53,9 @@ class OscillatorNode : public AudioScheduledSourceNode {
5153

5254
// https://webaudio.github.io/web-audio-api/#dom-oscillatornode-frequency
5355
GC::Ref<AudioParam> m_frequency;
56+
57+
// https://webaudio.github.io/web-audio-api/#dom-oscillatornode-detune
58+
GC::Ref<AudioParam> m_detune;
5459
};
5560

5661
}

Libraries/LibWeb/WebAudio/OscillatorNode.idl

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,6 @@ interface OscillatorNode : AudioScheduledSourceNode {
2424
constructor(BaseAudioContext context, optional OscillatorOptions options = {});
2525
attribute OscillatorType type;
2626
readonly attribute AudioParam frequency;
27-
[FIXME] readonly attribute AudioParam detune;
27+
readonly attribute AudioParam detune;
2828
[FIXME] undefined setPeriodicWave(PeriodicWave periodicWave);
2929
};

0 commit comments

Comments
 (0)