NAME
HTML::Object::DOM::TrackEvent - HTML Object DOM Track Event
SYNOPSIS
my
$event
= HTML::Object::DOM::TrackEvent->new(
$type
) ||
die
( HTML::Object::DOM::TrackEvent->error,
"\n"
);
VERSION
v0.2.0
DESCRIPTION
The TrackEvent
interface, which is part of the HTML DOM specification, is used for events which represent changes to a set of available tracks on an HTML media element; these events are addtrack
and removetrack
.
Events based on TrackEvent are always sent to one of the media track list types:
Events involving video tracks are always sent to the VideoTrackList found in "videoTracks" in HTML::Object::DOM::Element::Media
Events involving audio tracks are always sent to the AudioTrackList specified in "audioTracks" in HTML::Object::DOM::Element::Media
Events affecting text tracks are sent to the TextTrackList object indicated by "textTracks" in HTML::Object::DOM::Element::Media.
INHERITANCE
+---------------------+ +-------------------------------+
| HTML::Object::Event | --> | HTML::Object::DOM::TrackEvent |
+---------------------+ +-------------------------------+
PROPERTIES
TrackEvent is based on Event, so properties of Event are also available on TrackEvent
objects.
track
Read-only.
This is a DOM track object this event is in reference to. If not undef
, this is always an object of one of the media track types: AudioTrack, VideoTrack, or TextTrack).
See also Mozilla documentation
METHODS
TrackEvent has no methods of its own; however, it is based on Event, so it provides the methods available on Event objects.
EXAMPLE
my
$videoElem
=
$doc
->querySelector(
'video'
);
$videoElem
->videoTracks->addEventListener(
'addtrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
$videoElem
->videoTracks->addEventListener(
'removetrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
$videoElem
->audioTracks->addEventListener(
'addtrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
$videoElem
->audioTracks->addEventListener(
'removetrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
$videoElem
->textTracks->addEventListener(
'addtrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
$videoElem
->textTracks->addEventListener(
'removetrack'
, \
&handleTrackEvent
, {
capture
=> 0 });
sub
handleTrackEvent
{
my
$event
=
shift
(
@_
);
my
$trackKind
;
if
(
$event
->target->isa(
'HTML::Object::DOM::VideoTrackList'
) )
{
$trackKind
=
'video'
;
}
elsif
(
$event
->target->isa(
'HTML::Object::DOM::AudioTrackList'
) )
{
$trackKind
=
'audio'
;
}
elsif
(
$event
->target->isa(
'HTML::Object::DOM::TextTrackList'
) )
{
$trackKind
=
'text'
;
}
else
{
$trackKind
=
'unknown'
;
}
my
$type
=
$event
->type;
if
(
$type
eq
'addtrack'
)
{
say
(
"Added a $trackKind track"
);
}
elsif
(
$type
eq
'removetrack'
)
{
say
(
"Removed a $trackKind track"
);
}
}
AUTHOR
Jacques Deguest <jack@deguest.jp>
SEE ALSO
COPYRIGHT & LICENSE
Copyright(c) 2021 DEGUEST Pte. Ltd.
All rights reserved
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.