From a2af6ffd287a2c2ac066aa7cf1b744adb4397d15 Mon Sep 17 00:00:00 2001 From: Tim Ledbetter Date: Wed, 15 Jan 2025 23:08:23 +0000 Subject: [PATCH] LibWeb: Add `AudioContext.createMediaElementSource()` factory method --- Libraries/LibWeb/WebAudio/AudioContext.cpp | 8 ++++++++ Libraries/LibWeb/WebAudio/AudioContext.h | 3 +++ Libraries/LibWeb/WebAudio/AudioContext.idl | 2 +- .../audioparam-nominal-range.txt | 10 ++++++---- 4 files changed, 18 insertions(+), 5 deletions(-) diff --git a/Libraries/LibWeb/WebAudio/AudioContext.cpp b/Libraries/LibWeb/WebAudio/AudioContext.cpp index 68f88911b0fbb..2774ea83a56ee 100644 --- a/Libraries/LibWeb/WebAudio/AudioContext.cpp +++ b/Libraries/LibWeb/WebAudio/AudioContext.cpp @@ -318,4 +318,12 @@ bool AudioContext::start_rendering_audio_graph() return render_result; } +// https://webaudio.github.io/web-audio-api/#dom-audiocontext-createmediaelementsource +WebIDL::ExceptionOr> AudioContext::create_media_element_source(GC::Ptr media_element) +{ + MediaElementAudioSourceOptions options; + options.media_element = media_element; + return MediaElementAudioSourceNode::create(realm(), *this, options); +} + } diff --git a/Libraries/LibWeb/WebAudio/AudioContext.h b/Libraries/LibWeb/WebAudio/AudioContext.h index 7cdd8feecc03f..730e7d26b17ce 100644 --- a/Libraries/LibWeb/WebAudio/AudioContext.h +++ b/Libraries/LibWeb/WebAudio/AudioContext.h @@ -9,6 +9,7 @@ #include #include #include +#include namespace Web::WebAudio { @@ -39,6 +40,8 @@ class AudioContext final : public BaseAudioContext { WebIDL::ExceptionOr> suspend(); WebIDL::ExceptionOr> close(); + WebIDL::ExceptionOr> create_media_element_source(GC::Ptr); + private: explicit AudioContext(JS::Realm&, AudioContextOptions const& context_options); diff --git a/Libraries/LibWeb/WebAudio/AudioContext.idl b/Libraries/LibWeb/WebAudio/AudioContext.idl index b8cee9b2e5d6d..7402b156bdb53 100644 --- a/Libraries/LibWeb/WebAudio/AudioContext.idl +++ b/Libraries/LibWeb/WebAudio/AudioContext.idl @@ -13,7 +13,7 @@ interface AudioContext : BaseAudioContext { Promise resume (); Promise suspend (); Promise close (); - [FIXME] MediaElementAudioSourceNode createMediaElementSource (HTMLMediaElement mediaElement); + MediaElementAudioSourceNode createMediaElementSource (HTMLMediaElement mediaElement); [FIXME] MediaStreamAudioSourceNode createMediaStreamSource (MediaStream mediaStream); [FIXME] MediaStreamTrackAudioSourceNode createMediaStreamTrackSource (MediaStreamTrack mediaStreamTrack); [FIXME] MediaStreamAudioDestinationNode createMediaStreamDestination (); diff --git a/Tests/LibWeb/Text/expected/wpt-import/webaudio/the-audio-api/the-audioparam-interface/audioparam-nominal-range.txt b/Tests/LibWeb/Text/expected/wpt-import/webaudio/the-audio-api/the-audioparam-interface/audioparam-nominal-range.txt index c8ef18aa81f63..376b5912c6392 100644 --- a/Tests/LibWeb/Text/expected/wpt-import/webaudio/the-audio-api/the-audioparam-interface/audioparam-nominal-range.txt +++ b/Tests/LibWeb/Text/expected/wpt-import/webaudio/the-audio-api/the-audioparam-interface/audioparam-nominal-range.txt @@ -1,9 +1,9 @@ Harness status: OK -Found 302 tests +Found 304 tests -291 Pass -11 Fail +294 Pass +10 Fail Pass # AUDIT TASK RUNNER STARTED. Pass Executing "initialize" Pass Executing "Offline createGain" @@ -24,7 +24,7 @@ Fail Executing "Offline createScriptProcessor" Pass Executing "Offline createPeriodicWave" Pass Executing "Offline createChannelSplitter" Pass Executing "Offline createChannelMerger" -Fail Executing "Online createMediaElementSource" +Pass Executing "Online createMediaElementSource" Fail Executing "Online createMediaStreamDestination" Pass Executing "AudioListener" Pass Executing "verifyTests" @@ -241,6 +241,8 @@ Pass > [Offline createChannelMerger] Pass AudioNode has no AudioParams as expected Pass < [Offline createChannelMerger] All assertions passed. (total 1 assertions) Pass > [Online createMediaElementSource] +Pass MediaElementAudioSourceNode has no AudioParams as expected +Pass < [Online createMediaElementSource] All assertions passed. (total 1 assertions) Pass > [Online createMediaStreamDestination] Pass > [AudioListener] Pass AudioListener.positionX.minValue is equal to -3.4028234663852886e+38.