Exoplayer v2.17.1 with Mediamelon SDK
Prerequisites
ExoPlayer-r2.17.1 https://github.com/google/ExoPlayer
MediaMelon SmartSight SDK
smartstreaming_release.aar
Step 1: Set up the build environment
Note $EXOPROJECT = {ExoPlayer-r2.17.1}
The SDK files are added to the build environment and the required network permissions are enabled.
Copy smartstreaming-release.aar provided with the release package to the exoplayer project, Example
$EXOPROJECT/demos/main/smartstreaming-release.aar
Add the following library to
$EXOPROJECT/demos/main/build.gradle
:-
Add network permissions to $EXOPROJECT/demos/main/src/main/AndroidManifest.xml
Step 2: Register SDK
The player application must register the SDK and provide player information once when the application launches. Please note that values provided in this integration step persist across video sessions. This is typically done when the player itself is initialized.
Step 2a: Import packages
$EXOPROJECT/demos/main/src/main/java/com/google/android/exoplayer2/demo/PlayerActivity.java
Step 2b: Registration
Perform registration tasks by modifying the onCreate()
method in $EXOPROJECT/demos/main/src/main/java/com/google/android/exoplayer2/demo/PlayerActivity.java
The enableLogTrace()
feature should be enabled for testing during the integration process. Set this to False before releasing the player to production
Variable | Description |
$PLAYERNAME | String containing the player version (e.g. “Bitmovin_Android_Player_2.28.0”). |
$CUSTOMERID | String containing your MediaMelon-assigned Customer ID. |
$SUBSCRIBERID | String containing your subscriber’s ID. If you do not use subscriber IDs, enter null |
$DOMAINNAME | String containing your section of your subscriber or assets. (Optional) |
$SUBSCRIBERTYPE | String containing the subscriber type (e.g. “Free”, “Paid”). If you do not use subscriber types, enter null |
$SUBSCRIBERTAG | String containing an additional subscriber-specific information. This is sent in clear (not hashed) to SmartSight and it is advised to not send sensitive information in this field. |
$ASSETID | String containing Asset Id. |
$ASSETNAME | String containing Asset Name. |
$VIDEOID | String containing your video’s ID. If you do not use videos IDs, enter null. |
$PLAYER_BRAND | String containing the player brand (e.g. “bitmovin”). |
$PLAYER_MODEL | String containing the player model. For example - This could be a variant of player. Say name of third party player used by organisation. Or any human readable name of the player. |
$PLAYER_VERSION | String containing the player version. |
$DEVICE_MARKETING_NAME | Device marketing name |
$APP_NAME | Application Name |
$APP_VERSION | Application Version |
$VIDEO_QUALITY | "4K_HDR" or "4K_HLG". Use this if you need to pass a user defined video quality. Dont call this API otherwise |
$SERIESTITLE | Name of the Series |
$EPISODENUMBER | Episode Number |
$GENRE | Genre |
$DRMPROTECTION | Type of DRM Protection |
$CONTENTTYPE | Type of Content : movie, trailer, episode etc |
$SEASON | Season number |
Step 3: Initialize Session & Report User Intent to Playback
The SDK must be initialized at the start of each video session. Initialization includes setting the application context, initializing the playback session, and indicating the intent for playback with the SDK.
Step 4: Report ended state when the player instance is released
In $EXOPROJECT/demos/main/src/main/java/com/google/android/exoplayer2/demo/PlayerActivity.java
Last updated