diff --git a/index.html b/index.html index fdcd059..2cf80e2 100644 --- a/index.html +++ b/index.html @@ -619,16 +619,22 @@
The configuration (capabilities, constraints or settings) of a {{MediaStreamTrack}} may be changed dynamically + outside the control of web applications. One example is when a user decides to switch on background blur through + the operating system. Web applications might want to know that the configuration + of a particular {{MediaStreamTrack}} has changed. For that purpose, a new event is defined below. +
+The configuration (capabilities, constraints or settings) of a {{MediaStreamTrack}} may be changed dynamically - outside the control of web applications. One example is when a user decides to switch on background blur through - the operating system. Web applications might want to know that the configuration - of a particular {{MediaStreamTrack}} has changed. For that purpose, a new event is defined below. -
-+partial interface MediaStreamTrack { attribute EventHandler onconfigurationchange; };+The onconfigurationchange attribute + is an [=event handler IDL attribute=] for the `onconfigurationchange` + [=event handler=], whose [=event handler event type=] is + configurationchange. +
When the [=User Agent=] detects a change of configuration in a track's underlying source, the [=User Agent=] MUST run the following steps:
@@ -636,13 +642,18 @@Exposing change of MediaStreamTrack configuration
If track.{{MediaStreamTrack/muted}} is true
, wait for track.{{MediaStreamTrack/muted}}
to become false
or track.{{MediaStreamTrack/readyState}} to be "ended".
If track.{{MediaStreamTrack/readyState}} is "ended", abort these steps.
If track's capabilities, constraints and settings are matching source configuration, abort these steps. +
If track's capabilities, constraints and settings are matching source configuration, abort these steps.
Update track's capabilities, constraints and settings according track's underlying source.
[=Fire an event=] named configurationchange on track.
+Let changes be an empty [=sequence=].
For each change in track's capabilities and settings, add its name to changes.
[=Fire an event=] named {{MediaStreamTrack/configurationchange}} + at track using {{ConfigurationChangeEvent}}, with its + {{ConfigurationChangeEvent.changes}} attribute initialized to + changes.
+[Exposed=Window] +interface ConfigurationChangeEvent : Event { + constructor(DOMString type, ConfigurationChangeEventInit changeEventInitDict); + readonly attribute FrozenArray<DOMString> changes; +}; + +dictionary ConfigurationChangeEventInit : EventInit { + required sequence<DOMString> changes; +};+
The changes getter + steps are to return the value that the corresponding attribute was + initialized to. +
+This example shows how to monitor external background blur changes.
++const stream = await navigator.mediaDevices.getUserMedia({ video: true }); +const [track] = stream.getVideoTracks(); +track.addEventListener("configurationchange", (event) => { + if (event.changes.includes("backgroundBlur")) { + // User has changed background blur. + } +});+