IMediaPlayerSourceObserver

Provides callbacks for media players.

OnAudioVolumeIndication

Reports the volume of the media player.

public virtual void OnAudioVolumeIndication(int volume) {}

The SDK triggers this callback every 200 milliseconds to report the current volume of the media player.

Parameters

volume
The volume of the media player. The value ranges from 0 to 255.

OnMetaData

Occurs when the media metadata is received.

public virtual void OnMetaData(byte[] data, int length) { }

The callback occurs when the player receives the media metadata and reports the detailed information of the media metadata.

Parameters

data
The detailed data of the media metadata.
length
The data length (bytes).

OnPlayBufferUpdated

Reports the playback duration that the buffered data can support.

public virtual void OnPlayBufferUpdated(Int64 playCachedBuffer) { }
When playing online media resources, the SDK triggers this callback every two seconds to report the playback duration that the currently buffered data can support.
  • When the playback duration supported by the buffered data is less than the threshold (0 by default), the SDK returns PLAYER_EVENT_BUFFER_LOW (6).
  • When the playback duration supported by the buffered data is greater than the threshold (0 by default), the SDK returns PLAYER_EVENT_BUFFER_RECOVER (7).

Parameters

playCachedBuffer
The playback duration (ms) that the buffered data can support.

OnPlayerCacheStats

Reports the statistics of the media file being cached.

public virtual void OnPlayerCacheStats(CacheStatistics stats)
                {
                }

Details

After you call the OpenWithMediaSource method and set enableCache as true, the SDK triggers this callback once per second to report the statistics of the media file being cached.

Parameters

stats
The statistics of the media file being cached. See CacheStatistics.

OnPlayerEvent

Reports the player events.

public virtual void OnPlayerEvent(MEDIA_PLAYER_EVENT eventCode, Int64 elapsedTime, string message) { }
  • After calling the Seek method, the SDK triggers the callback to report the results of the seek operation.

Parameters

eventCode
The player event. See MEDIA_PLAYER_EVENT.
elapsedTime
The time (ms) when the event occurs.
message
Information about the event.

OnPlayerInfoUpdated

Occurs when information related to the media player changes.

public virtual void OnPlayerInfoUpdated(PlayerUpdatedInfo info) { }

When the information about the media player changes, the SDK triggers this callback. You can use this callback for troubleshooting.

Parameters

info
Information related to the media player. See PlayerUpdatedInfo.

OnPlayerPlaybackStats

The statistics of the media file being played.

public virtual void OnPlayerPlaybackStats(PlayerPlaybackStats stats)
                {
                }

Details

The SDK triggers this callback once per second to report the statistics of the media file being played.

Parameters

stats
The statistics of the media file. See PlayerPlaybackStats.

OnPlayerSourceStateChanged

Reports the changes of playback state.

public virtual void OnPlayerSourceStateChanged(MEDIA_PLAYER_STATE state, MEDIA_PLAYER_REASON reason)

When the state of the media player changes, the SDK triggers this callback to report the current playback state.

Parameters

state
The playback state. See MEDIA_PLAYER_STATE.
reason
The reason for the changes in the media player status. See MEDIA_PLAYER_REASON.

OnPlayerSrcInfoChanged

Occurs when the video bitrate of the media resource changes.

public virtual void OnPlayerSrcInfoChanged(SrcInfo from, SrcInfo to) {}

Parameters

from
Information about the video bitrate of the media resource being played. See SrcInfo.
to
Information about the changed video bitrate of media resource being played. See SrcInfo.

OnPositionChanged

Reports the playback progress of the media file.

public virtual void OnPositionChanged(Int64 position_ms) { }

When playing media files, the SDK triggers this callback every two second to report current playback progress.

Parameters

position_ms
The playback position (ms) of media files.
timeStampMs
The NTP timestamp (ms) of the current playback progress.

OnPreloadEvent

Reports the events of preloaded media resources.

public virtual void OnPreloadEvent(string src, PLAYER_PRELOAD_EVENT @event) { }

Parameters

src
The URL of the media resource.
@event
Events that occur when media resources are preloaded. See PLAYER_PRELOAD_EVENT.