Interface IAnalyticsSession
- All Superinterfaces:
- PlayerControllerPlugin.Component
- All Known Implementing Classes:
- AnalyticsSession,- AnalyticsSessionProxy
- Since:
- 3.1.0
- 
Method SummaryModifier and TypeMethodDescriptionvoidInform the session that the ad is clickedvoidadError(Ad ad, CastlabsPlayerException exception) Inform the session that an ad error occurred.voidadPause()Inform the session that the ad is paused.voidInform the session that an ad playback resumed.voidInform the session that the ad is skipped.voidInform the session that an ad playback started.voidadStop()Inform the session that an ad playback stopped.voidadWillStart(Ad ad) Inform the session that an Ad begins loadingvoidDetach the Analytics session from the PlayerController.voidonExoPlayerStateChanged(boolean playWhenReady, int playbackState) Lets the Analytics Sessions know of any state changes in ExoPlayer.voidrelease()Terminate the AnalyticsSession.voidReport the current player state manually.voidseekEnd()Inform the session that the seeking has completed.voidInform the session that the requested seek position of the video playback is processed.voidseekStart(long newPosition) Inform the session that the new position of the video playback is requested.voidSend an error manually.voidstart(PlayerController playerController, AnalyticsMetaData analyticsMetaData) Start the session on the given controllervoidstop()Stop the session.Methods inherited from interface com.castlabs.android.player.PlayerControllerPlugin.Componentid, onDestroy, onOpenBundle, onOpenState
- 
Method Details- 
startvoid start(@NonNull PlayerController playerController, @NonNull AnalyticsMetaData analyticsMetaData) Start the session on the given controller- Parameters:
- playerController- The player controller
- analyticsMetaData- The meta-data associated with this session
 
- 
stopvoid stop()Stop the session.
- 
adWillStartInform the session that an Ad begins loading- Parameters:
- ad- The Ad object. Notice that in this level, some properties of the ad such as- Ad.titlemight be null.
 
- 
adStartInform the session that an ad playback started.- Parameters:
- ad- The ad metadata. Contains streamType (Either- SdkConsts.AD_EMBEDDEDif the ad is embedded into the content or- SdkConsts.AD_SEPARATEif the ad is played separate from the main content.), playerType (Either- SdkConsts.AD_EMBEDDEDif the ad is using the same player as the main content or- SdkConsts.AD_SEPARATEif the ad is played in a separate player and adPosition The ad position. One of- SdkConsts.AD_POSITION_PREROLL- SdkConsts.AD_POSITION_MIDROLL, or- SdkConsts.AD_POSITION_POSTROLL
 
- 
adStopvoid adStop()Inform the session that an ad playback stopped.
- 
adErrorInform the session that an ad error occurred.- Parameters:
- ad- The ad
- exception- The error's exception
 
- 
adSkippedvoid adSkipped()Inform the session that the ad is skipped.
- 
adPausevoid adPause()Inform the session that the ad is paused.
- 
adResumeInform the session that an ad playback resumed. This is usually triggered after an adPause.Nevertheless, it is also possible that this event is fired without a preceding adPause. This is the case when re-opening the player from the background with a saved state. - Parameters:
- ad- the ad that has been resumed
 
- 
adClickInform the session that the ad is clicked- Parameters:
- clickthroughUrl- the clickthrough url of the ad
 
- 
reportPlayerStateReport the current player state manually. This is used for the cases thatPlayerListener.onStateChanged(PlayerController.State)is called before but we want to report it now, same as switching between playlist items inMultiControllerPlaylist
- 
sendErrorSend an error manually. Note that the player integration takes care of playback error occurring during playback. Use this method to send error that happen outside of the playback session.- Parameters:
- code- The error code
- message- The error message
- severity- The severity of the error
 
- 
seekStartvoid seekStart(long newPosition) Inform the session that the new position of the video playback is requested.- Parameters:
- newPosition- the new position in microseconds
 
- 
seekEndvoid seekEnd()Inform the session that the seeking has completed.Triggered when the player is ready to continue playback by transitioning to either PlayerController.State.PlayingorPlayerController.State.Pausing.
- 
seekProcessedvoid seekProcessed()Inform the session that the requested seek position of the video playback is processed. This is called right after the player has updated the internal playback position.
- 
detachFromControllervoid detachFromController()Detach the Analytics session from the PlayerController. Unregister listeners and remove any references.This method allows to unbind the AnalyticsSession from a PlayerController, to later set it to a new controller and continue with the same analytics session. Should be called by client code after getting the AnalyticsSession via PlayerController.getAnalyticsSession(), and before releasing the PlayerController.You can later re-attach the AnalyticsSession to a PlayerController before openingit with thePlayerController.setAnalyticsSession(AnalyticsSession)method
- 
onExoPlayerStateChangedvoid onExoPlayerStateChanged(boolean playWhenReady, int playbackState) Lets the Analytics Sessions know of any state changes in ExoPlayer.This method allows any interested Analytics sessions to know of any changes in the ExoPlayer even if it doesn't correspond to any state changes in the PlayerController. 
- 
releasevoid release()Terminate the AnalyticsSession. Although implementation is vendor-specific, this method will terminate any ongoing session as if the player itself had been destroyed. Generally, there's no need to call this manually. Unless you're detaching the session and not reusing it later.
 
-