HTMLMediaElement.idl [plain text]
typedef (
#if defined(ENABLE_MEDIA_STREAM) && ENABLE_MEDIA_STREAM
MediaStream or
#endif
#if defined(ENABLE_MEDIA_SOURCE) && ENABLE_MEDIA_SOURCE
MediaSource or
#endif
Blob) MediaProvider;
[
ActiveDOMObject,
Conditional=VIDEO,
ExportMacro=WEBCORE_EXPORT,
JSGenerateToNativeObject,
Exposed=Window
] interface HTMLMediaElement : HTMLElement {
readonly attribute MediaError error;
[CEReactions=NotNeeded, Reflect, URL] attribute USVString src;
attribute MediaProvider? srcObject;
[URL] readonly attribute USVString currentSrc;
[CEReactions=NotNeeded] attribute DOMString? crossOrigin;
const unsigned short NETWORK_EMPTY = 0;
const unsigned short NETWORK_IDLE = 1;
const unsigned short NETWORK_LOADING = 2;
const unsigned short NETWORK_NO_SOURCE = 3;
readonly attribute unsigned short networkState;
[CEReactions=NotNeeded] attribute DOMString preload;
readonly attribute TimeRanges buffered;
undefined load();
DOMString canPlayType(DOMString type);
const unsigned short HAVE_NOTHING = 0;
const unsigned short HAVE_METADATA = 1;
const unsigned short HAVE_CURRENT_DATA = 2;
const unsigned short HAVE_FUTURE_DATA = 3;
const unsigned short HAVE_ENOUGH_DATA = 4;
readonly attribute unsigned short readyState;
readonly attribute boolean seeking;
[ImplementedAs=currentTimeForBindings] attribute unrestricted double currentTime;
readonly attribute unrestricted double duration;
Date getStartDate();
readonly attribute boolean paused;
attribute unrestricted double defaultPlaybackRate;
attribute unrestricted double playbackRate;
readonly attribute TimeRanges played;
readonly attribute TimeRanges seekable;
readonly attribute boolean ended;
[CEReactions=NotNeeded, Reflect] attribute boolean autoplay;
[CEReactions=NotNeeded, Reflect] attribute boolean loop;
Promise<undefined> play();
undefined pause();
undefined fastSeek(unrestricted double time);
[CEReactions=NotNeeded] attribute boolean controls;
attribute double volume;
attribute boolean muted;
[CEReactions=NotNeeded, Reflect=muted] attribute boolean defaultMuted;
[CEReactions=NotNeede] attribute boolean webkitPreservesPitch;
readonly attribute boolean webkitHasClosedCaptions;
attribute boolean webkitClosedCaptionsVisible;
[Conditional=MEDIA_STATISTICS] readonly attribute unsigned long webkitAudioDecodedByteCount;
[Conditional=MEDIA_STATISTICS] readonly attribute unsigned long webkitVideoDecodedByteCount;
[Conditional=LEGACY_ENCRYPTED_MEDIA, EnabledBySetting=LegacyEncryptedMediaAPI] readonly attribute WebKitMediaKeys webkitKeys;
[Conditional=LEGACY_ENCRYPTED_MEDIA, EnabledBySetting=LegacyEncryptedMediaAPI] undefined webkitSetMediaKeys(WebKitMediaKeys? mediaKeys);
[Conditional=ENCRYPTED_MEDIA, EnabledBySetting=EncryptedMediaAPI, DisabledByQuirk=hasBrokenEncryptedMediaAPISupport] readonly attribute MediaKeys mediaKeys;
[Conditional=ENCRYPTED_MEDIA, EnabledBySetting=EncryptedMediaAPI, DisabledByQuirk=hasBrokenEncryptedMediaAPISupport] attribute EventHandler onencrypted;
[Conditional=ENCRYPTED_MEDIA, EnabledBySetting=EncryptedMediaAPI, DisabledByQuirk=hasBrokenEncryptedMediaAPISupport] attribute EventHandler onwaitingforkey;
[Conditional=ENCRYPTED_MEDIA, EnabledBySetting=EncryptedMediaAPI, DisabledByQuirk=hasBrokenEncryptedMediaAPISupport] Promise<undefined> setMediaKeys(MediaKeys? mediaKeys);
[MayThrowException] TextTrack addTextTrack(DOMString kind, optional DOMString label = "", optional DOMString language = "");
[ImplementedAs=ensureAudioTracks] readonly attribute AudioTrackList audioTracks;
[ImplementedAs=ensureTextTracks] readonly attribute TextTrackList textTracks;
[ImplementedAs=ensureVideoTracks] readonly attribute VideoTrackList videoTracks;
[Reflect] attribute DOMString mediaGroup;
[ImplementedAs=controllerForBindings] attribute MediaController? controller;
VideoPlaybackQuality getVideoPlaybackQuality();
[Conditional=WIRELESS_PLAYBACK_TARGET] undefined webkitShowPlaybackTargetPicker();
[Conditional=WIRELESS_PLAYBACK_TARGET] readonly attribute boolean webkitCurrentPlaybackTargetIsWireless;
};