MediaMelon
  • MediaMelon SDK Integration
  • MediaMelon SDK Events
  • MediaMelon Player SDK Integration
    • React Native
      • React Native Video v5.2.0 with Mediamelon SDK
      • React Native Video v6.4.2 with Mediamelon SDK
    • Web SDK
      • VideoJS Web with Mediamelon Analytics
      • VideoJS Web with Google DAI
      • Shaka Player Web v4
      • MediaMelon Web Kaltura Player Plugin Integration Document
      • NexPlayer Web v4
      • THEOPlayer Web
      • JWPlayer Web
      • Radiant Player Web
      • ChromeCast Player
      • HLSJS Player Web
      • HbbTV SDK
      • Comcast PDK 6
      • Bitmovin Web Player
      • HTML5 Player Web
      • Flow Player Web
      • DashJS Player Web
      • Castlabs Player Web
      • Cordova Plugin Toast (Smart TV)
      • Custom Player Web SDK
      • Plyr Player Web with MediaMelon Analytics
      • React Player SDK with IMA
    • Android SDK
      • App Analytics SDK
      • Bitmovin Android v3.73 with Content Provider Metrics
      • Exoplayer v2.13.2 integration with MediaMelon SDK
      • Exoplayer v2.17.1 with Mediamelon SDK
      • Exoplayer v2.12.2 integration with MediaMelon SDK
      • EXOPlayer-Android(V2.14.2) MediaMelon SDK with Google IMA DAI
      • EXOPlayer-Android(V2.17.1) MediaMelon SDK with Google IMA DAI
      • Exoplayer v2.11
      • Exoplayer v2.18.1 with Mediamelon SDK
      • Theoplayer v6.0.0 with Mediamelon SDK
      • Theoplayer v4.12.6 with Mediamelon SDK
      • Theoplayer v7.5.0 with Mediamelon SDK
      • Exoplayer v2.13.3 integration with MediaMelon SDK
      • Kaltura Android Player Integration with Mediamelon SDK
      • Media3 v1.3.0 and ExoPlayer 2.19.1 with MediaMelon SDK
      • Media3 v1.3.1 with MediaMelon SDK
      • MediaMelon Android Media3 v1.1.1 SDK Integration Document
      • Media3Player-Android(V1.3.0) MediaMelon SDK with Google IMA
    • Roku SDK
      • Roku SDK
      • Roku with RAF SDK
      • Roku with IMA SDK
    • iOS SDK
      • AVPlayer (Cocoapods)
      • AVPlayer with Google DAI SDK ( Framework )
      • AVPlayer Quality Of Experience SDK
      • AVPlayer Generic Framework
      • AVPlayer with Google DAI (Cocoapods)
      • Bitmovin iOS v3.44 with Content Provider Metrics
      • THEOPlayer XCFramework
      • THEOplayer (Cocoapods)
      • MediaMelon iOS Kaltura Player Plugin Integration Document
    • tvOS SDK
      • AVPlayer tvOS XCFramework
      • THEOPlayer tvOS XCFramework
    • Toast SDK
    • Custom Player C++ SDK
    • C++ SDK QoE Ads
    • Ad Integrations
      • Google IMA
      • FreeWheel
      • ServerSide.AI
  • SmartSight Analytics
    • Product Features
    • QBR Streaming
  • SmartSight API's
    • API Overview
      • Metric and Dimensions Dictionary
      • General Guidelines
      • Video Experience
      • Ad Experience
      • Smartquery Insights
      • Errors
      • Alerts
    • Use-case dictionary
Powered by GitBook
On this page
  • Prerequisites
  • Step 1: Set up the build environment
  • Step 2: Register SDK
  • Step 3: Initialize Session & Report User Intent to Playback
  • Step 4: Report ended state when the player instance is released

Was this helpful?

  1. MediaMelon Player SDK Integration
  2. Android SDK

Exoplayer v2.18.1 with Mediamelon SDK

PreviousExoplayer v2.11NextTheoplayer v6.0.0 with Mediamelon SDK

Last updated 1 year ago

Was this helpful?

Prerequisites

  • ExoPlayer-r2.18.1

  • MediaMelon SmartSight SDK smartstreaming_release.aar

Step 1: Set up the build environment

Note $EXOPROJECT = {ExoPlayer-r2.18.1}

The SDK files are added to the build environment and the required network permissions are enabled.

  1. Copy smartstreaming-release.aar provided with the release package to the exoplayer project, Example $EXOPROJECT/demos/main/smartstreaming-release.aar

  2. Add the following library to $EXOPROJECT/demos/main/build.gradle :-

dependencies {
  .
  .
  .
   //<!-- <MMSmartStreaming 1b> -->
    api files ('smartstreaming-release.aar')
  //<!-- </MMSmartStreaming 1b> -->
  
}

Add network permissions to $EXOPROJECT/demos/main/src/main/AndroidManifest.xml

<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

<!-- <MMSmartStreaming 1c> -->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<!-- </MMSmartStreaming 1c> -->

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

// <MMSmartStreaming 2a>
import com.google.android.exoplayer2.ExoPlayerLibraryInfo;
import com.mediamelon.smartstreaming.MMQBRMode;
import com.mediamelon.smartstreaming.MMSmartStreaming;
import com.mediamelon.smartstreaming.MMSmartStreamingExo2;
import com.mediamelon.smartstreaming.MMSmartStreamingInitializationStatus;
import com.mediamelon.smartstreaming.MMSmartStreamingObserver;
import com.mediamelon.qubit.ep.ContentMetadata;
import java.util.ArrayList;
import android.util.Log;
// </MMSmartStreaming 2a>
// <MMSmartStreaming 2a>
import com.mediamelon.smartstreaming.MMSmartStreaming
import com.mediamelon.smartstreaming.MMSmartStreamingExo2
import com.mediamelon.smartstreaming.MMSmartStreamingInitializationStatus
import com.mediamelon.smartstreaming.MMSmartStreamingObserver
import com.mediamelon.qubit.ep.ContentMetadata
// <MMSmartStreaming 2a>

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

set the doHash variable for in registerMMSmarttreaming() API subscriberId hashing,set to true for hasing else false

The enableLogTrace() feature should be enabled for testing during the integration process. Set this to False before releasing the player to production

public void onCreate(Bundle savedInstanceState) {
  ...
  }else {
    trackSelectorParameters = new DefaultTrackSelector.ParametersBuilder().build();
    clearStartPosition();
  }

  //<MMSmartStreaming 2b>
  Log.d("SmartStreamingIntgr", MMSmartStreamingExo2.getVersion());
  MMSmartStreamingExo2.enableLogTrace(true); //set to "false" before releasing player to production
  if (MMSmartStreamingExo2.getRegistrationStatus() == false)

{ //Check if it is the first time Registration process is done

    MMSmartStreamingExo2.setDeviceInfo($DEVICE_MARKETING_NAME);
    MMSmartStreamingExo2.registerMMSmartStreaming($PLAYERNAME, $CUSTOMERID, $SUBSCRIBERID, $DOMAINNAME, $SUBSCRIBERTYPE, $SUBSCRIBERTAG,$doHash);
    MMSmartStreamingExo2.reportPlayerInfo("CustomPlayerName", ExoPlayerLibraryInfo.VERSION, "1.0");
    MMSmartStreamingExo2.getInstance().setContext(getApplicationContext()); //Please make sure to provide the application's context here, and not the activity's context
    MMSmartStreamingExo2.getInstance().reportAppInfo($APP_NAME,$APP_VERSION);
    MMSmartStreamingExo2.getInstance().reportVideoQuality($VIDEO_QUALITY);
  }
 MMSmartStreamingExo2.disableManifestsFetch(true); // pass true if you want to disable Manifests Fetch 
  // </MMSmartStreaming 2b> 
}
override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        progressBar = findViewById(R.id.progressBar)

        titleTv = findViewById(R.id.title)

        //MM
//    //<MMSmartStreaming 2b>
        Log.d("SmartStreamingIntgr", MMSmartStreamingExo2.getVersion())
        MMSmartStreamingExo2.enableLogTrace(true) //set to "false" before releasing player to production

        if (MMSmartStreamingExo2.getRegistrationStatus() == false) { //Check if it is the first time Registration process is done
            MMSmartStreamingExo2.setDeviceInfo("Samsung Prime A1")
            MMSmartStreamingExo2.getInstance()
                .setContext(applicationContext) //Please make sure to provide the application's context here, and not the activity's context
            // in the below line replace "199493832" with your customerID
            MMSmartStreamingExo2.registerMMSmartStreaming(
                "\$PLAYERNAME",
                "199493832",
                "\$SUBSCRIBERID",
                "\$DOMAINNAME",
                "\$SUBSCRIBERTYPE",
                "\$SUBSCRIBERTAG",
                true
            )
            MMSmartStreamingExo2.reportPlayerInfo(
                "CustomPlayerName",
                ExoPlayerLibraryInfo.VERSION,
                "1.0"
            )
            MMSmartStreamingExo2.getInstance()
                .setContext(applicationContext) //Please make sure to provide the application's context here, and not the activity's context
            MMSmartStreamingExo2.getInstance().reportCustomMetadata("key", "value")
            MMSmartStreamingExo2.reportAppInfo("LifeTime", "1.2.3")
            MMSmartStreamingExo2.reportVideoQuality("4K-HDR")
        }
        MMSmartStreamingExo2.disableManifestsFetch(true) // pass true if you want to disable Manifests Fetch
  // </MMSmartStreaming 2b> 
    }

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.

set isLive variable in initializeSession() call , set true for live stream else false

protected boolean initializePlayer() {
if (player == null) {
Intent intent = getIntent();
...
...
...

// after player is initialised and not null anymore
    String mediaUrl = "get the mediaURL from your application"
    String assetId  = "assetID"; //enter you assetId here
    String assetName = "assetNAME"; // enter your assetname here
    String videoId = "videoID"; // enter your videoId here
    ContentMetadata cm  = new ContentMetadata();
    String episodeNumber = "EpisodeNumber";
    String season = "Season";
    String genre = "Genre";
    String drmProtection = "drmProtection";
    String contentType = "contentType";
    String title = "Title";
    cm.videoId=videoId;
    cm.seriesTitle=title;
    cm.season=season;
    cm.genre=genre;
    cm.episodeNumber=episodeNumber;
    cm.drmProtection=drmProtection;
    cm.contentType=contentType;
    cm.assetName=assetName;
    cm.assetId=assetId;
    JSONObject contentMetadata = cm.getJSONObject();
    //optional content metadata
    //(optional) add custom tags
    MMSmartStreamingExo2.getInstance().reportCustomMetadata("key","value");
    MMSmartStreamingExo2.getInstance().initializeSession(player, MMQBRMode.QBRModeDisabled, mediaUrl, null, assetId, assetName, videoId,null,contentMetadata,isLive);
    MMSmartStreamingExo2.getInstance().reportUserInitiatedPlayback();
 ...
 ...
}
protected boolean initializePlayer() {
    val mediaUrl: String = " String mediaUrl = "get the mediaURL from your application";//getting the mediaURL from the application

        val assetId = "assetID" //enter you assetId here

        val assetName = "assetNAME" // enter your assetname here

        val videoId = "videoID" // enter your videoId here

        val cm = ContentMetadata()
        val episodeNumber = "EpisodeNumber"
        val season = "Season"
        val genre = "Genre"
        val drmProtection = "drmProtection"
        val contentType = "contentType"
        val title = "Title"
        cm.videoId = videoId
        cm.seriesTitle = title
        cm.season = season
        cm.genre = genre
        cm.episodeNumber = episodeNumber
        cm.drmProtection = drmProtection
        cm.contentType = contentType
        cm.assetName = assetName
        cm.assetId = assetId
        val contentMetadata = cm.jsonObject
        //optional content metadata
        //(optional) add custom tags
        MMSmartStreamingExo2.getInstance().reportCustomMetadata("key", "value")
        MMSmartStreamingExo2.getInstance().initializeSession(
            player,
            MMQBRMode.QBRModeDisabled,
            mediaUrl,
            null,
            assetId,
            assetName,
            videoId,
            null,
            contentMetadata,
            false
        )
        MMSmartStreamingExo2.getInstance().reportUserInitiatedPlayback();
}

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

private void releasePlayer() {
    if (player != null) {
      updateTrackSelectorParameters();
      updateStartPosition();
      debugViewHelper.stop();
      debugViewHelper = null;
      player.release();
      player = null;
      mediaSource = null;
      trackSelector = null;
       // <MMSmartStreaming 5> Start
	  MMSmartStreamingExo2.getInstance().reportPlayerState(false, Player.STATE_ENDED);
	  // </MMSmartStreaming 5> End
    }
    if (adsLoader != null) {
      adsLoader.setPlayer(null);
    }
  }
 private fun releasePlayer() {
        isPlayerPlaying = exoPlayer.playWhenReady
        playbackPosition = exoPlayer.currentPosition
        currentWindow = exoPlayer.currentMediaItemIndex
        
        //MM
        MMSmartStreamingExo2.getInstance().reportPlayerState(false, Player.STATE_ENDED)
        
        exoPlayer.release()
    }
    
 // if there is no releasePlayer API in your sample application, you can use onDestroy Listener
 
  override fun onDestroy() {
        super.onDestroy()
        Log.d(TAG, "onSaveInstanceState: " + player.currentPosition)
        //MM
        //MM
        MMSmartStreamingExo2.getInstance().reportPlayerState(false, Player.STATE_ENDED)
    }

https://github.com/google/ExoPlayer