diff --git a/CHANGELOG.md b/CHANGELOG.md index cf22a84..425e5e4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,14 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](http://keepachangelog.com/) and this project adheres to [Semantic Versioning](http://semver.org/). +## [Unreleased] +### Added +- Possibility to start session tracking without a `Player` instance + - `ConvivaAnalyticsIntegration(customerKey:config:)` constructor without a `Player` + - `ConvivaAnalyticsIntegration.attachPlayer()` to attach the `Player` at a later point in the session life-cycle + +### Removed +- Unintentionally public initializers from `ConvivaAnalyticsIntegration` which were not intended to be public and only meant for testing ## 2.6.0 - 2024-08-13 ### Added diff --git a/ConvivaExampleApp/src/main/java/com/bitmovin/analytics/convivaanalyticsexample/MainActivity.java b/ConvivaExampleApp/src/main/java/com/bitmovin/analytics/convivaanalyticsexample/MainActivity.java index 4a90b6c..307ab69 100644 --- a/ConvivaExampleApp/src/main/java/com/bitmovin/analytics/convivaanalyticsexample/MainActivity.java +++ b/ConvivaExampleApp/src/main/java/com/bitmovin/analytics/convivaanalyticsexample/MainActivity.java @@ -1,14 +1,17 @@ package com.bitmovin.analytics.convivaanalyticsexample; import android.os.Bundle; +import android.util.Log; import android.view.View; import android.view.ViewGroup; import android.widget.Button; import android.widget.LinearLayout; import android.widget.Switch; +import androidx.annotation.Nullable; import androidx.appcompat.app.AppCompatActivity; +import com.bitmovin.analytics.conviva.ConvivaAnalyticsException; import com.bitmovin.analytics.conviva.ConvivaAnalyticsIntegration; import com.bitmovin.analytics.conviva.ConvivaConfig; import com.bitmovin.analytics.conviva.MetadataOverrides; @@ -27,21 +30,27 @@ import java.util.Map; public class MainActivity extends AppCompatActivity implements View.OnClickListener { + private static final String TAG = "Example"; + // UI private Button pauseTrackingButton; private Button resumeTrackingButton; private Button releaseButton; private Button createButton; private Button sendCustomEventButton; + private Button startSessionButton; private Switch includeAdsSwitch; // Conviva private static final String customerKey = "YOUR-CUSTOMER-KEY"; private static String gatewayUrl; // Set only in debug mode + @Nullable private ConvivaAnalyticsIntegration convivaAnalyticsIntegration; // Player + @Nullable private Player bitmovinPlayer; + @Nullable private PlayerView bitmovinPlayerView; @Override @@ -54,10 +63,12 @@ protected void onCreate(Bundle savedInstanceState) { resumeTrackingButton.setOnClickListener(this); releaseButton = findViewById(R.id.release_button); releaseButton.setOnClickListener(this); - createButton = findViewById(R.id.create_button); + createButton = findViewById(R.id.create_player_button); createButton.setOnClickListener(this); sendCustomEventButton = findViewById(R.id.custom_event_button); sendCustomEventButton.setOnClickListener(this); + startSessionButton = findViewById(R.id.start_session_button); + startSessionButton.setOnClickListener(this); includeAdsSwitch = findViewById(R.id.include_ads_switch); this.setupBitmovinPlayer(); @@ -73,40 +84,12 @@ protected void setupBitmovinPlayer() { LinearLayout playerUIView = this.findViewById(R.id.bitmovinPlayerUIView); playerUIView.addView(bitmovinPlayerView); - // Create your ConvivaConfig object - ConvivaConfig convivaConfig = new ConvivaConfig(); - - // Set only in debug mode - if (gatewayUrl != null) { - convivaConfig.setGatewayUrl(gatewayUrl); + if (convivaAnalyticsIntegration == null) { + convivaAnalyticsIntegration = setupConvivaAnalytics(bitmovinPlayer); + } else { + convivaAnalyticsIntegration.attachPlayer(bitmovinPlayer); } - // Add optional parameters - convivaConfig.setDebugLoggingEnabled(true); - - // Create ConvivaAnalytics - convivaAnalyticsIntegration = new ConvivaAnalyticsIntegration( - bitmovinPlayer, - customerKey, - getApplicationContext(), - convivaConfig); - - MetadataOverrides metadata = new MetadataOverrides(); - metadata.setApplicationName("Bitmovin Android Conviva integration example app"); - metadata.setViewerId("awesomeViewerId"); - - Map standardTags = new HashMap<>(); - standardTags.put("c3.cm.contentType", "VOD"); - metadata.setAdditionalStandardTags(standardTags); - - Map customTags = new HashMap<>(); - customTags.put("custom_tag", "Episode"); - metadata.setCustom(customTags); - - metadata.setImaSdkVersion("3.31.0"); - - convivaAnalyticsIntegration.updateContentMetadata(metadata); - // load source using the created source configuration bitmovinPlayer.load(buildSourceConfiguration()); } @@ -118,6 +101,8 @@ private PlayerConfig buildPlayerConfiguration() { playerConfiguration.setAdvertisingConfig(buildAdConfiguration()); } + playerConfiguration.getPlaybackConfig().setAutoplayEnabled(true); + return playerConfiguration; } @@ -145,42 +130,132 @@ private AdvertisingConfig buildAdConfiguration() { @Override protected void onStart() { super.onStart(); - bitmovinPlayerView.onStart(); + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onStart(); + } } @Override protected void onResume() { super.onResume(); - bitmovinPlayerView.onResume(); + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onResume(); + } } @Override protected void onPause() { super.onPause(); - bitmovinPlayerView.onPause(); + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onStop(); + } } @Override protected void onStop() { super.onStop(); - bitmovinPlayerView.onStop(); + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onStop(); + } } @Override protected void onDestroy() { super.onDestroy(); - bitmovinPlayerView.onDestroy(); - convivaAnalyticsIntegration.release(); + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onDestroy(); + } + if (convivaAnalyticsIntegration != null) { + convivaAnalyticsIntegration.release(); + } } private void tearDownPlayer() { - convivaAnalyticsIntegration.release(); - ViewGroup parent = (ViewGroup) bitmovinPlayerView.getParent(); + if (convivaAnalyticsIntegration != null) { + convivaAnalyticsIntegration.release(); + convivaAnalyticsIntegration = null; + } + ViewGroup parent = null; + if (bitmovinPlayerView != null) { + parent = (ViewGroup) bitmovinPlayerView.getParent(); + } if (parent != null) { parent.removeView(bitmovinPlayerView); } - bitmovinPlayer.destroy(); - bitmovinPlayerView.onDestroy(); + if (bitmovinPlayer != null) { + bitmovinPlayer.destroy(); + } + if (bitmovinPlayerView != null) { + bitmovinPlayerView.onDestroy(); + } + bitmovinPlayer = null; + } + + private void startSession() { + ConvivaAnalyticsIntegration convivaAnalyticsIntegration = setupConvivaAnalytics(bitmovinPlayer); + convivaAnalyticsIntegration.updateContentMetadata(buildMetadataOverrides("Art of Motion")); + try { + convivaAnalyticsIntegration.initializeSession(); + + this.convivaAnalyticsIntegration = convivaAnalyticsIntegration; + } catch (ConvivaAnalyticsException e) { + Log.d(TAG, "ConvivaAnalytics initialization failed with error: " + e); + } + } + + private ConvivaAnalyticsIntegration setupConvivaAnalytics(@Nullable Player player) { + // Create your ConvivaConfig object + ConvivaConfig convivaConfig = new ConvivaConfig(); + + // Set only in debug mode + if (gatewayUrl != null) { + convivaConfig.setGatewayUrl(gatewayUrl); + } + + ConvivaAnalyticsIntegration convivaAnalyticsIntegration = null; + // Add optional parameters + convivaConfig.setDebugLoggingEnabled(true); + + if (player != null) { + convivaAnalyticsIntegration = new ConvivaAnalyticsIntegration( + player, + customerKey, + getApplicationContext(), + convivaConfig + ); + } else { + convivaAnalyticsIntegration = new ConvivaAnalyticsIntegration( + customerKey, + getApplicationContext(), + convivaConfig + ); + } + + convivaAnalyticsIntegration.updateContentMetadata(buildMetadataOverrides(null)); + + return convivaAnalyticsIntegration; + } + + private MetadataOverrides buildMetadataOverrides(@Nullable String assetName) { + MetadataOverrides metadata = new MetadataOverrides(); + metadata.setApplicationName("Bitmovin Android Conviva integration example app"); + metadata.setViewerId("awesomeViewerId"); + + Map standardTags = new HashMap<>(); + standardTags.put("c3.cm.contentType", "VOD"); + metadata.setAdditionalStandardTags(standardTags); + + Map customTags = new HashMap<>(); + customTags.put("custom_tag", "Episode"); + metadata.setCustom(customTags); + + metadata.setImaSdkVersion("3.31.0"); + + if (assetName != null) { + metadata.setAssetName(assetName); + } + + return metadata; } @Override @@ -192,11 +267,19 @@ public void onClick(View v) { } else if (v == sendCustomEventButton) { Map eventAttributes = new HashMap<>(); eventAttributes.put("Some", "Attributes"); - this.convivaAnalyticsIntegration.sendCustomPlaybackEvent("Custom Event", eventAttributes); + if (this.convivaAnalyticsIntegration != null) { + this.convivaAnalyticsIntegration.sendCustomPlaybackEvent("Custom Event", eventAttributes); + } } else if (v == pauseTrackingButton) { - this.convivaAnalyticsIntegration.pauseTracking(false); + if (this.convivaAnalyticsIntegration != null) { + this.convivaAnalyticsIntegration.pauseTracking(false); + } } else if (v == resumeTrackingButton) { - this.convivaAnalyticsIntegration.resumeTracking(); + if (this.convivaAnalyticsIntegration != null) { + this.convivaAnalyticsIntegration.resumeTracking(); + } + } else if (v == startSessionButton) { + this.startSession(); } } } diff --git a/ConvivaExampleApp/src/main/res/layout/activity_main.xml b/ConvivaExampleApp/src/main/res/layout/activity_main.xml index 8d1a73a..58de572 100644 --- a/ConvivaExampleApp/src/main/res/layout/activity_main.xml +++ b/ConvivaExampleApp/src/main/res/layout/activity_main.xml @@ -7,6 +7,18 @@ android:keepScreenOn="true" tools:context=".MainActivity"> +