W3cubDocs

/Web APIs

RTCTrackEvent

The WebRTC API interface RTCTrackEvent represents the track event, which is sent when a new MediaStreamTrack is added to an RTCRtpReceiver which is part of the RTCPeerConnection.

The target is the RTCPeerConnection object to which the track is being added.

This event is sent by the WebRTC layer to the website or application, so you will not typically need to instantiate an RTCTrackEvent yourself.

Event RTCTrackEvent

Constructor

RTCTrackEvent()

Creates and returns a new RTCTrackEvent object. You will probably not need to create new track events yourself, since they're typically created by the WebRTC infrastructure and sent to the connection's ontrack event handler.

Instance properties

Since RTCTrackEvent is based on Event, its properties are also available.

receiver Read only

The RTCRtpReceiver used by the track that's been added to the RTCPeerConnection.

streams Read only Optional

An array of MediaStream objects, each representing one of the media streams to which the added track belongs. By default, the array is empty, indicating a streamless track.

track Read only

The MediaStreamTrack which has been added to the connection.

transceiver Read only

The RTCRtpTransceiver being used by the new track.

Track event types

There is only one type of track event.

track

The track event is sent to the RTCPeerConnection when a new track has been added to the connection. By the time the track event is delivered to the RTCPeerConnection's ontrack handler, the new media has completed its negotiation for a specific RTCRtpReceiver (which is specified by the event's receiver property).

In addition, the MediaStreamTrack specified by the receiver's track is the same one specified by the event's track, and the track has been added to any associated remote MediaStream objects.

You can add a track event listener to be notified when the new track is available so that you can, for example, attach its media to a <video> element, using either RTCPeerConnection.addEventListener() or the ontrack event handler property.

Note: It may be helpful to keep in mind that you receive the track event when a new inbound track has been added to your connection, and you call addTrack() to add a track to the far end of the connection, thereby triggering a track event on the remote peer.

Example

This simple example creates an event listener for the track event which sets the srcObject of the <video> element with the ID videobox to the first stream in the list passed in the event's streams array.

js

peerConnection.addEventListener(
  "track",
  (e) => {
    let videoElement = document.getElementById("videobox");
    videoElement.srcObject = e.streams[0];
  },
  false,
);

Specifications

Browser compatibility

Desktop Mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on IOS Samsung Internet
RTCTrackEvent 64 79 46 No 51 11 64 64 46 47 11 9.0
RTCTrackEvent 56 79 22 No 43 11 56 56 24 43 11 6.0
receiver 56 79 34 No 43 11 56 56 34 43 11 6.0
streams 56 79 22 No 43 11 56 56 24 43 11 6.0
track 56 79 22 No 43 11 56 56 24 43 11 6.0
transceiver 69 79 59 No 43 11 69 69 59 43 11 6.0

© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/RTCTrackEvent