diff --git a/AdvancedExample/app/build.gradle b/AdvancedExample/app/build.gradle index 402de0e8..4f019164 100644 --- a/AdvancedExample/app/build.gradle +++ b/AdvancedExample/app/build.gradle @@ -40,5 +40,5 @@ dependencies { implementation 'androidx.legacy:legacy-support-v4:1.0.0' implementation 'androidx.mediarouter:mediarouter:1.7.0' implementation 'com.android.support.constraint:constraint-layout:2.0.4' - implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.34.0' + implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.35.0' } diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/SampleVideoPlayer.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/SampleVideoPlayer.java index 9835b1f4..f322d0e2 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/SampleVideoPlayer.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/SampleVideoPlayer.java @@ -4,7 +4,6 @@ import android.content.Context; import android.media.AudioManager; -import android.media.MediaPlayer; import android.media.MediaPlayer.OnCompletionListener; import android.media.MediaPlayer.OnErrorListener; import android.util.AttributeSet; @@ -24,7 +23,7 @@ private enum PlaybackState { private MediaController mediaController; private PlaybackState playbackState; - private final List videoPlayerCallbacks = new ArrayList(1); + private final List videoPlayerCallbacks = new ArrayList<>(1); public SampleVideoPlayer(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); @@ -49,36 +48,28 @@ private void init() { // Set OnCompletionListener to notify our callbacks when the video is completed. super.setOnCompletionListener( - new OnCompletionListener() { - - @Override - public void onCompletion(MediaPlayer mediaPlayer) { - // Reset the MediaPlayer. - playbackState = PlaybackState.STOPPED; - mediaPlayer.reset(); - mediaPlayer.setDisplay(getHolder()); - - for (PlayerCallback callback : videoPlayerCallbacks) { - callback.onComplete(); - } + mediaPlayer -> { + // Reset the MediaPlayer. + playbackState = PlaybackState.STOPPED; + mediaPlayer.reset(); + mediaPlayer.setDisplay(getHolder()); + + for (PlayerCallback callback : videoPlayerCallbacks) { + callback.onComplete(); } }); // Set OnErrorListener to notify our callbacks if the video errors. super.setOnErrorListener( - new OnErrorListener() { - - @Override - public boolean onError(MediaPlayer mp, int what, int extra) { - playbackState = PlaybackState.STOPPED; - for (PlayerCallback callback : videoPlayerCallbacks) { - callback.onError(); - } - - // Returning true signals to MediaPlayer that we handled the error. This will - // prevent the completion handler from being called. - return true; + (mp, what, extra) -> { + playbackState = PlaybackState.STOPPED; + for (PlayerCallback callback : videoPlayerCallbacks) { + callback.onError(); } + + // Returning true signals to MediaPlayer that we handled the error. This will + // prevent the completion handler from being called. + return true; }); } diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/VideoPlayer.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/VideoPlayer.java index dec4ca1a..170e7625 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/VideoPlayer.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/samplevideoplayer/VideoPlayer.java @@ -6,7 +6,7 @@ public interface VideoPlayer { /** Interface for alerting caller of major video events. */ - public interface PlayerCallback { + interface PlayerCallback { /** Called when the current video starts playing from the beginning. */ void onPlay(); diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java index 495b2374..5c8751be 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java @@ -5,11 +5,13 @@ import android.view.Menu; import android.view.MenuItem; import android.view.View; +import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.fragment.app.Fragment; import androidx.fragment.app.FragmentManager; import androidx.fragment.app.FragmentTransaction; import androidx.multidex.MultiDex; +import java.util.Objects; /** Main Activity. */ public class MyActivity extends AppCompatActivity @@ -61,16 +63,15 @@ public boolean onCreateOptionsMenu(Menu menu) { } @Override - public boolean onOptionsItemSelected(MenuItem item) { + public boolean onOptionsItemSelected(@NonNull MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. - int id = item.getItemId(); return super.onOptionsItemSelected(item); } @Override - public void onConfigurationChanged(Configuration configuration) { + public void onConfigurationChanged(@NonNull Configuration configuration) { super.onConfigurationChanged(configuration); orientAppUi(); } @@ -123,6 +124,7 @@ public void onVideoSelected(VideoItem videoItem) { VideoListFragment videoListFragment = (VideoListFragment) getSupportFragmentManager().findFragmentByTag(VIDEO_PLAYLIST_FRAGMENT_TAG); + assert videoListFragment != null; int videoPlaylistFragmentId = videoListFragment.getId(); videoFragment = new VideoFragment(); @@ -154,11 +156,11 @@ private void hideStatusBar() { .getDecorView() .setSystemUiVisibility( View.SYSTEM_UI_FLAG_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_FULLSCREEN); - getSupportActionBar().hide(); + Objects.requireNonNull(getSupportActionBar()).hide(); } private void showStatusBar() { getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE); - getSupportActionBar().show(); + Objects.requireNonNull(getSupportActionBar()).show(); } } diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoFragment.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoFragment.java index f8064aed..b09e5853 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoFragment.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoFragment.java @@ -23,7 +23,7 @@ public class VideoFragment extends Fragment { /** Listener called when the fragment's onCreateView is fired. */ public interface OnVideoFragmentViewCreatedListener { - public void onVideoFragmentViewCreated(); + void onVideoFragmentViewCreated(); } @Override @@ -61,7 +61,7 @@ private void initUi(View rootView) { // Make the dummyScrollContent height the size of the screen height. DisplayMetrics displayMetrics = new DisplayMetrics(); - getActivity().getWindowManager().getDefaultDisplay().getMetrics(displayMetrics); + requireActivity().getWindowManager().getDefaultDisplay().getMetrics(displayMetrics); ConstraintLayout constraintLayout = rootView.findViewById(R.id.constraintLayout); ConstraintSet forceHeight = new ConstraintSet(); forceHeight.clone(constraintLayout); @@ -72,13 +72,10 @@ private void initUi(View rootView) { // Provide an implementation of a logger so we can output SDK events to the UI. VideoPlayerController.Logger logger = - new VideoPlayerController.Logger() { - @Override - public void log(String message) { - Log.i("ImaExample", message); - if (logText != null) { - logText.append(message); - } + message -> { + Log.i("ImaExample", message); + if (logText != null) { + logText.append(message); } }; @@ -113,10 +110,6 @@ public void makeFullscreen(boolean isFullscreen) { } } - public VideoPlayerController getVideoPlayerController() { - return videoPlayerController; - } - @Override public void onPause() { if (videoPlayerController != null) { @@ -141,8 +134,4 @@ public void onDestroy() { } super.onDestroy(); } - - public boolean isVmap() { - return videoItem.getIsVmap(); - } } diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoItemAdapter.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoItemAdapter.java index ae0a5355..a07b0353 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoItemAdapter.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoItemAdapter.java @@ -7,20 +7,22 @@ import android.widget.ArrayAdapter; import android.widget.ImageView; import android.widget.TextView; +import androidx.annotation.NonNull; import java.util.List; /** Renders VideoItems into a GridView for displaying videos in a playlist format. */ public class VideoItemAdapter extends ArrayAdapter { - private int layoutResourceId; + private final int layoutResourceId; public VideoItemAdapter(Context context, int layoutResourceId, List data) { super(context, layoutResourceId, data); this.layoutResourceId = layoutResourceId; } + @NonNull @Override - public View getView(int position, View convertView, ViewGroup parent) { + public View getView(int position, View convertView, @NonNull ViewGroup parent) { VideoItemHolder videoItemHolder; View row = convertView; @@ -29,8 +31,8 @@ public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = LayoutInflater.from(getContext()); row = inflater.inflate(layoutResourceId, parent, false); videoItemHolder = new VideoItemHolder(); - videoItemHolder.title = (TextView) row.findViewById(R.id.videoItemText); - videoItemHolder.image = (ImageView) row.findViewById(R.id.videoItemImage); + videoItemHolder.title = row.findViewById(R.id.videoItemText); + videoItemHolder.image = row.findViewById(R.id.videoItemImage); row.setTag(videoItemHolder); } else { videoItemHolder = (VideoItemHolder) row.getTag(); @@ -38,6 +40,7 @@ public View getView(int position, View convertView, ViewGroup parent) { VideoItem item = getItem(position); + assert item != null; videoItemHolder.title.setText(item.getTitle()); videoItemHolder.image.setImageResource(item.getImageResource()); @@ -45,7 +48,7 @@ public View getView(int position, View convertView, ViewGroup parent) { } /** Holds the UI element equivalents of a VideoItem. */ - private class VideoItemHolder { + private static class VideoItemHolder { TextView title; ImageView image; diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoListFragment.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoListFragment.java index ded40416..38c68d59 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoListFragment.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoListFragment.java @@ -2,15 +2,14 @@ import android.app.AlertDialog; import android.content.Context; -import android.content.DialogInterface; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; -import android.widget.AdapterView; import android.widget.CheckBox; import android.widget.EditText; import android.widget.ListView; +import androidx.annotation.NonNull; import androidx.fragment.app.Fragment; import java.util.ArrayList; import java.util.List; @@ -18,7 +17,7 @@ /** Fragment for displaying a playlist of video thumbnails that the user can select from to play. */ public class VideoListFragment extends Fragment { - private OnVideoSelectedListener selectedCallback; + OnVideoSelectedListener selectedCallback; LayoutInflater inflater; ViewGroup container; @@ -38,22 +37,20 @@ public interface OnVideoListFragmentResumedListener { } @Override - public void onAttach(Context context) { + public void onAttach(@NonNull Context context) { super.onAttach(context); try { selectedCallback = (OnVideoSelectedListener) context; } catch (ClassCastException e) { throw new ClassCastException( - context.toString() + " must implement " + OnVideoSelectedListener.class.getName()); + context + " must implement " + OnVideoSelectedListener.class.getName()); } try { resumeCallback = (OnVideoListFragmentResumedListener) context; } catch (ClassCastException e) { throw new ClassCastException( - context.toString() - + " must implement " - + OnVideoListFragmentResumedListener.class.getName()); + context + " must implement " + OnVideoListFragmentResumedListener.class.getName()); } } @@ -64,24 +61,21 @@ public View onCreateView( this.container = container; View rootView = inflater.inflate(R.layout.fragment_video_list, container, false); - final ListView listView = (ListView) rootView.findViewById(R.id.videoListView); + final ListView listView = rootView.findViewById(R.id.videoListView); VideoItemAdapter videoItemAdapter = new VideoItemAdapter(rootView.getContext(), R.layout.video_item, getVideoItems()); listView.setAdapter(videoItemAdapter); listView.setOnItemClickListener( - new AdapterView.OnItemClickListener() { - @Override - public void onItemClick(AdapterView parent, View v, int position, long id) { - if (selectedCallback != null) { - VideoItem selectedVideo = (VideoItem) listView.getItemAtPosition(position); - - // If applicable, prompt the user to input a custom ad tag. - if (selectedVideo.getAdTagUrl().equals(getString(R.string.custom_ad_tag_value))) { - getCustomAdTag(selectedVideo); - } else { - selectedCallback.onVideoSelected(selectedVideo); - } + (parent, v, position, id) -> { + if (selectedCallback != null) { + VideoItem selectedVideo = (VideoItem) listView.getItemAtPosition(position); + + // If applicable, prompt the user to input a custom ad tag. + if (selectedVideo.getAdTagUrl().equals(getString(R.string.custom_ad_tag_value))) { + getCustomAdTag(selectedVideo); + } else { + selectedCallback.onVideoSelected(selectedVideo); } } }); @@ -91,9 +85,9 @@ public void onItemClick(AdapterView parent, View v, int position, long id) { private void getCustomAdTag(VideoItem originalVideoItem) { View dialogueView = inflater.inflate(R.layout.custom_ad_tag, container, false); - final EditText txtUrl = (EditText) dialogueView.findViewById(R.id.customTag); + final EditText txtUrl = dialogueView.findViewById(R.id.customTag); txtUrl.setHint("VAST ad tag URL"); - final CheckBox isVmap = (CheckBox) dialogueView.findViewById(R.id.isVmap); + final CheckBox isVmap = dialogueView.findViewById(R.id.isVmap); final VideoItem videoItem = originalVideoItem; new AlertDialog.Builder(this.getActivity()) @@ -101,32 +95,26 @@ private void getCustomAdTag(VideoItem originalVideoItem) { .setView(dialogueView) .setPositiveButton( "OK", - new DialogInterface.OnClickListener() { - public void onClick(DialogInterface dialog, int whichButton) { - String customAdTagUrl = txtUrl.getText().toString(); - VideoItem customAdTagVideoItem = - new VideoItem( - videoItem.getVideoUrl(), - videoItem.getTitle(), - customAdTagUrl, - videoItem.getImageResource(), - isVmap.isChecked()); - - if (selectedCallback != null) { - selectedCallback.onVideoSelected(customAdTagVideoItem); - } + (dialog, whichButton) -> { + String customAdTagUrl = txtUrl.getText().toString(); + VideoItem customAdTagVideoItem = + new VideoItem( + videoItem.getVideoUrl(), + videoItem.getTitle(), + customAdTagUrl, + videoItem.getImageResource(), + isVmap.isChecked()); + + if (selectedCallback != null) { + selectedCallback.onVideoSelected(customAdTagVideoItem); } }) - .setNegativeButton( - "Cancel", - new DialogInterface.OnClickListener() { - public void onClick(DialogInterface dialog, int whichButton) {} - }) + .setNegativeButton("Cancel", (dialog, whichButton) -> {}) .show(); } private List getVideoItems() { - final List videoItems = new ArrayList(); + final List videoItems = new ArrayList<>(); // Iterate through the videos' metadata and add video items to list. for (int i = 0; i < VideoMetadata.APP_VIDEOS.size(); i++) { diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoMetadata.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoMetadata.java index 621454f5..ade88a67 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoMetadata.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoMetadata.java @@ -82,8 +82,7 @@ public enum VideoMetadata { /** If the ad is VMAP. */ public final boolean isVmap; - private VideoMetadata( - String videoUrl, String title, String adTagUrl, int thumbnail, boolean isVmap) { + VideoMetadata(String videoUrl, String title, String adTagUrl, int thumbnail, boolean isVmap) { this.videoUrl = videoUrl; this.title = title; this.adTagUrl = adTagUrl; diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerController.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerController.java index a5e2ef1c..9987f86e 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerController.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerController.java @@ -6,6 +6,7 @@ import android.view.MotionEvent; import android.view.View; import android.view.ViewGroup; +import androidx.annotation.NonNull; import com.google.ads.interactivemedia.v3.api.AdDisplayContainer; import com.google.ads.interactivemedia.v3.api.AdErrorEvent; import com.google.ads.interactivemedia.v3.api.AdEvent; @@ -26,7 +27,7 @@ public interface Logger { } // Container with references to video player and ad UI ViewGroup. - private AdDisplayContainer adDisplayContainer; + private final AdDisplayContainer adDisplayContainer; // The AdsLoader instance exposes the requestAds method. private final AdsLoader adsLoader; @@ -35,10 +36,10 @@ public interface Logger { private AdsManager adsManager; // Factory class for creating SDK objects. - private ImaSdkFactory sdkFactory; + private final ImaSdkFactory sdkFactory; // Ad-enabled video player. - private VideoPlayerWithAdPlayback videoPlayerWithAdPlayback; + private final VideoPlayerWithAdPlayback videoPlayerWithAdPlayback; // Button the user taps to begin video playback and ad request. private View playButton; @@ -50,17 +51,17 @@ public interface Logger { private String contentVideoUrl; // ViewGroup to render an associated companion ad into. - private ViewGroup companionViewGroup; + private final ViewGroup companionViewGroup; // Tracks if the SDK is playing an ad, since the SDK might not necessarily use the video // player provided to play the video ad. private boolean isAdPlaying; // View that handles taps to toggle ad pause/resume during video playback. - private View playPauseToggle; + private final View playPauseToggle; // View that we can write log messages to, to display in the UI. - private Logger log; + private final Logger log; private double playAdsAfterTime = -1; @@ -80,7 +81,7 @@ public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) { new AdErrorEvent.AdErrorListener() { /** An event raised when there is an error loading or playing ads. */ @Override - public void onAdError(AdErrorEvent adErrorEvent) { + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { log("Ad Error: " + adErrorEvent.getError().getMessage()); resumeContent(); } @@ -89,7 +90,7 @@ public void onAdError(AdErrorEvent adErrorEvent) { new AdEvent.AdEventListener() { /** Responds to AdEvents. */ @Override - public void onAdEvent(AdEvent adEvent) { + public void onAdEvent(@NonNull AdEvent adEvent) { if (adEvent.getType() != AdEvent.AdEventType.AD_PROGRESS) { log("Event: " + adEvent.getType()); } @@ -179,7 +180,7 @@ public VideoPlayerController( new AdErrorEvent.AdErrorListener() { /** An event raised when there is an error loading or playing ads. */ @Override - public void onAdError(AdErrorEvent adErrorEvent) { + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { log("Ad Error: " + adErrorEvent.getError().getMessage()); resumeContent(); } @@ -188,13 +189,7 @@ public void onAdError(AdErrorEvent adErrorEvent) { adsLoader.addAdsLoadedListener(new VideoPlayerController.AdsLoadedListener()); // When Play is clicked, request ads and hide the button. - playButton.setOnClickListener( - new View.OnClickListener() { - @Override - public void onClick(View view) { - requestAndPlayAds(-1); - } - }); + playButton.setOnClickListener(view -> requestAndPlayAds(-1)); } private void log(String message) { @@ -226,7 +221,7 @@ public String getAdTagUrl() { /** Request and subsequently play video ads from the ad server. */ public void requestAndPlayAds(double playAdsAfterTime) { - if (currentAdTagUrl == null || currentAdTagUrl == "") { + if (currentAdTagUrl == null || currentAdTagUrl.isEmpty()) { log("No VAST ad tag URL specified"); resumeContent(); return; @@ -255,19 +250,18 @@ private void setPlayPauseOnAdTouch() { // Use AdsManager pause/resume methods instead of the video player pause/resume methods // in case the SDK is using a different, SDK-created video player for ad playback. playPauseToggle.setOnTouchListener( - new View.OnTouchListener() { - public boolean onTouch(View view, MotionEvent event) { - // If an ad is playing, touching it will toggle playback. - if (event.getAction() == MotionEvent.ACTION_DOWN) { - if (isAdPlaying) { - adsManager.pause(); - } else { - adsManager.resume(); - } - return true; + (view, event) -> { + view.performClick(); + // If an ad is playing, touching it will toggle playback. + if (event.getAction() == MotionEvent.ACTION_DOWN) { + if (isAdPlaying) { + adsManager.pause(); } else { - return false; + adsManager.resume(); } + return true; + } else { + return false; } }); } diff --git a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerWithAdPlayback.java b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerWithAdPlayback.java index 02bc721f..1cb059d0 100644 --- a/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerWithAdPlayback.java +++ b/AdvancedExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerWithAdPlayback.java @@ -7,6 +7,7 @@ import android.util.Log; import android.view.ViewGroup; import android.widget.RelativeLayout; +import androidx.annotation.NonNull; import com.google.ads.interactivemedia.v3.api.AdPodInfo; import com.google.ads.interactivemedia.v3.api.player.AdMediaInfo; import com.google.ads.interactivemedia.v3.api.player.ContentProgressProvider; @@ -56,8 +57,7 @@ public class VideoPlayerWithAdPlayback extends RelativeLayout { // ContentProgressProvider interface implementation for the SDK to check content progress. private ContentProgressProvider contentProgressProvider; - private final List adCallbacks = - new ArrayList(1); + private final List adCallbacks = new ArrayList<>(1); public VideoPlayerWithAdPlayback(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); @@ -110,8 +110,8 @@ private void init() { contentHasCompleted = false; savedAdPosition = 0; savedContentPosition = 0; - videoPlayer = (VideoPlayer) this.getRootView().findViewById(R.id.videoPlayer); - adUiContainer = (ViewGroup) this.getRootView().findViewById(R.id.adUiContainer); + videoPlayer = this.getRootView().findViewById(R.id.videoPlayer); + adUiContainer = this.getRootView().findViewById(R.id.adUiContainer); // Define VideoAdPlayer connector. videoAdPlayer = @@ -122,7 +122,7 @@ public int getVolume() { } @Override - public void playAd(AdMediaInfo info) { + public void playAd(@NonNull AdMediaInfo info) { startTracking(); if (isAdDisplayed) { videoPlayer.resume(); @@ -133,20 +133,20 @@ public void playAd(AdMediaInfo info) { } @Override - public void loadAd(AdMediaInfo info, AdPodInfo api) { + public void loadAd(@NonNull AdMediaInfo info, @NonNull AdPodInfo api) { adMediaInfo = info; isAdDisplayed = false; videoPlayer.setVideoPath(info.getUrl()); } @Override - public void stopAd(AdMediaInfo info) { + public void stopAd(@NonNull AdMediaInfo info) { stopTracking(); videoPlayer.stopPlayback(); } @Override - public void pauseAd(AdMediaInfo info) { + public void pauseAd(@NonNull AdMediaInfo info) { stopTracking(); videoPlayer.pause(); } @@ -157,15 +157,16 @@ public void release() { } @Override - public void addCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void addCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { adCallbacks.add(videoAdPlayerCallback); } @Override - public void removeCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void removeCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { adCallbacks.remove(videoAdPlayerCallback); } + @NonNull @Override public VideoProgressUpdate getAdProgress() { if (!isAdDisplayed || videoPlayer.getDuration() <= 0) { @@ -177,15 +178,12 @@ public VideoProgressUpdate getAdProgress() { }; contentProgressProvider = - new ContentProgressProvider() { - @Override - public VideoProgressUpdate getContentProgress() { - if (isAdDisplayed || videoPlayer.getDuration() <= 0) { - return VideoProgressUpdate.VIDEO_TIME_NOT_READY; - } - return new VideoProgressUpdate( - videoPlayer.getCurrentPosition(), videoPlayer.getDuration()); + () -> { + if (isAdDisplayed || videoPlayer.getDuration() <= 0) { + return VideoProgressUpdate.VIDEO_TIME_NOT_READY; } + return new VideoProgressUpdate( + videoPlayer.getCurrentPosition(), videoPlayer.getDuration()); }; // Set player callbacks for delegating major video events. diff --git a/AdvancedExample/gradle/wrapper/gradle-wrapper.properties b/AdvancedExample/gradle/wrapper/gradle-wrapper.properties index de183985..82e606a5 100644 --- a/AdvancedExample/gradle/wrapper/gradle-wrapper.properties +++ b/AdvancedExample/gradle/wrapper/gradle-wrapper.properties @@ -2,5 +2,5 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-all.zip diff --git a/ExoPlayerExample/app/build.gradle b/ExoPlayerExample/app/build.gradle index 3a2c949d..87a61f29 100644 --- a/ExoPlayerExample/app/build.gradle +++ b/ExoPlayerExample/app/build.gradle @@ -32,7 +32,7 @@ repositories { } dependencies { - def media3_version = "1.3.1" + def media3_version = "1.4.1" implementation "androidx.media3:media3-ui:$media3_version" implementation "androidx.media3:media3-exoplayer:$media3_version" diff --git a/ExoPlayerExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/exoplayerexample/MyActivity.java b/ExoPlayerExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/exoplayerexample/MyActivity.java index d092684c..7ccd0aba 100644 --- a/ExoPlayerExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/exoplayerexample/MyActivity.java +++ b/ExoPlayerExample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/exoplayerexample/MyActivity.java @@ -57,20 +57,17 @@ public AdEvent.AdEventListener buildAdEventListener() { logText = findViewById(R.id.logText); logText.setMovementMethod(new ScrollingMovementMethod()); - AdEvent.AdEventListener imaAdEventListener = - event -> { - AdEvent.AdEventType eventType = event.getType(); - if (eventType == AdEvent.AdEventType.AD_PROGRESS) { - return; - } - String log = "IMA event: " + eventType; - if (logText != null) { - logText.append(log + "\n"); - } - Log.i(LOG_TAG, log); - }; - - return imaAdEventListener; + return event -> { + AdEvent.AdEventType eventType = event.getType(); + if (eventType == AdEvent.AdEventType.AD_PROGRESS) { + return; + } + String log = "IMA event: " + eventType; + if (logText != null) { + logText.append(log + "\n"); + } + Log.i(LOG_TAG, log); + }; } @Override diff --git a/ExoPlayerExample/gradle/wrapper/gradle-wrapper.properties b/ExoPlayerExample/gradle/wrapper/gradle-wrapper.properties index 5d6560a4..348c409e 100644 --- a/ExoPlayerExample/gradle/wrapper/gradle-wrapper.properties +++ b/ExoPlayerExample/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-all.zip diff --git a/audioplayerexample/app/build.gradle b/audioplayerexample/app/build.gradle index 858057a1..1b2e9e26 100644 --- a/audioplayerexample/app/build.gradle +++ b/audioplayerexample/app/build.gradle @@ -44,11 +44,11 @@ dependencies { implementation(platform("org.jetbrains.kotlin:kotlin-bom:1.8.0")) implementation 'androidx.appcompat:appcompat:1.7.0' implementation 'androidx.media:media:1.7.0' - def media3_version = "1.3.1" + def media3_version = "1.4.1" implementation "androidx.media3:media3-ui:$media3_version" implementation "androidx.media3:media3-exoplayer:$media3_version" implementation "androidx.media3:media3-session:$media3_version" implementation 'com.google.guava:guava:32.1.3-android' - implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.34.0' + implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.35.0' } diff --git a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/AudioPlayerService.java b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/AudioPlayerService.java index 6e060ec0..998a4c3a 100644 --- a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/AudioPlayerService.java +++ b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/AudioPlayerService.java @@ -14,6 +14,7 @@ import android.os.Binder; import android.os.IBinder; import android.view.ViewGroup; +import androidx.annotation.NonNull; import androidx.annotation.Nullable; import androidx.media3.common.C; import androidx.media3.common.MediaItem; @@ -74,8 +75,9 @@ public void onCreate() { MediaDescriptionAdapter descriptionAdapter = new MediaDescriptionAdapter() { + @NonNull @Override - public String getCurrentContentTitle(Player player) { + public String getCurrentContentTitle(@NonNull Player player) { if (isAdPlaying) { return getString(R.string.ad_content_title); } @@ -84,13 +86,13 @@ public String getCurrentContentTitle(Player player) { @Nullable @Override - public PendingIntent createCurrentContentIntent(Player player) { + public PendingIntent createCurrentContentIntent(@NonNull Player player) { return null; } @Nullable @Override - public String getCurrentContentText(Player player) { + public String getCurrentContentText(@NonNull Player player) { if (isAdPlaying) { // Null will remove the extra line for description. return null; @@ -100,7 +102,8 @@ public String getCurrentContentText(Player player) { @Nullable @Override - public Bitmap getCurrentLargeIcon(Player player, BitmapCallback callback) { + public Bitmap getCurrentLargeIcon( + @NonNull Player player, @NonNull BitmapCallback callback) { // Use null for ad playback unless your ad has an icon to show in the notification // menu. if (isAdPlaying) { @@ -123,7 +126,7 @@ public Bitmap getCurrentLargeIcon(Player player, BitmapCallback callback) { new NotificationListener() { @Override public void onNotificationPosted( - int notificationId, Notification notification, boolean ongoing) { + int notificationId, @NonNull Notification notification, boolean ongoing) { // This must be called within 5 seconds of the notification being displayed and // before the main app has been killed. startForeground( @@ -142,7 +145,7 @@ public void onNotificationCancelled(int notificationId, boolean dismissedByUser) mediaSession = new MediaSession.Builder(context, player).build(); - playerNotificationManager.setMediaSessionToken(mediaSession.getSessionCompatToken()); + playerNotificationManager.setMediaSessionToken(mediaSession.getPlatformToken()); imaService = new ImaService(context, dataSourceFactory, new SharedAudioPlayer()); } diff --git a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Constants.java b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Constants.java index 14f98d3f..f7293f3e 100644 --- a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Constants.java +++ b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Constants.java @@ -4,7 +4,6 @@ public final class Constants { public static final String PLAYBACK_CHANNEL_ID = "playback_channel"; public static final int PLAYBACK_NOTIFICATION_ID = 1; - public static final String MEDIA_SESSION_TAG = "audio_demo"; private Constants() {} } diff --git a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/ImaService.java b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/ImaService.java index f237196b..87a50689 100644 --- a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/ImaService.java +++ b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/ImaService.java @@ -24,7 +24,6 @@ import com.google.ads.interactivemedia.v3.api.ImaSdkFactory; import com.google.ads.interactivemedia.v3.api.ImaSdkSettings; import com.google.ads.interactivemedia.v3.api.player.AdMediaInfo; -import com.google.ads.interactivemedia.v3.api.player.ContentProgressProvider; import com.google.ads.interactivemedia.v3.api.player.VideoAdPlayer; import com.google.ads.interactivemedia.v3.api.player.VideoAdPlayer.VideoAdPlayerCallback; import com.google.ads.interactivemedia.v3.api.player.VideoProgressUpdate; @@ -51,7 +50,6 @@ public final class ImaService private final ImaSdkFactory sdkFactory; private final ImaSdkSettings imaSdkSettings; private final DefaultDataSource.Factory dataSourceFactory; - public ImaVideoAdPlayer imaVideoAdPlayer = new ImaVideoAdPlayer(); @androidx.media3.common.util.UnstableApi @@ -86,12 +84,7 @@ public void requestAds(String adTagUrl) { request.setAdTagUrl(adTagUrl); // The ContentProgressProvider is only needed for scheduling ads with VMAP ad requests request.setContentProgressProvider( - new ContentProgressProvider() { - @Override - public VideoProgressUpdate getContentProgress() { - return new VideoProgressUpdate(exoPlayer.getCurrentPosition(), exoPlayer.getDuration()); - } - }); + () -> new VideoProgressUpdate(exoPlayer.getCurrentPosition(), exoPlayer.getDuration())); adsLoader.requestAds(request); } @@ -105,11 +98,7 @@ public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) { @Override public void onAdError(AdErrorEvent adErrorEvent) { - if (adErrorEvent.getError().getMessage() != null) { - Log.e(LOGGING_TAG, "Ad Error: ".concat(adErrorEvent.getError().getMessage().toString())); - } else { - Log.e(LOGGING_TAG, "Ad Error: null"); - } + Log.e(LOGGING_TAG, "Ad Error: ".concat(adErrorEvent.getError().getMessage())); } @Override @@ -141,7 +130,7 @@ public void onAdEvent(AdEvent adEvent) { /** Allows IMA to tell the custom player what to do. */ class ImaVideoAdPlayer implements VideoAdPlayer { @Override - public void loadAd(AdMediaInfo adMediaInfo, AdPodInfo adPodInfo) { + public void loadAd(@NonNull AdMediaInfo adMediaInfo, @NonNull AdPodInfo adPodInfo) { // If implementing preloading, we would pass the url back to the audio player here. } @@ -168,7 +157,7 @@ public void playAd(AdMediaInfo adMediaInfo) { } @Override - public void pauseAd(AdMediaInfo adMediaInfo) { + public void pauseAd(@NonNull AdMediaInfo adMediaInfo) { exoPlayer.setPlayWhenReady(false); progressTracker.stop(); for (VideoAdPlayerCallback callback : callbacks) { @@ -177,7 +166,7 @@ public void pauseAd(AdMediaInfo adMediaInfo) { } @Override - public void stopAd(AdMediaInfo adMediaInfo) { + public void stopAd(@NonNull AdMediaInfo adMediaInfo) { progressTracker.stop(); exoPlayer.setPlayWhenReady(false); notifyEnded(); @@ -189,12 +178,12 @@ public void release() { } @Override - public void addCallback(VideoAdPlayerCallback callback) { + public void addCallback(@NonNull VideoAdPlayerCallback callback) { callbacks.add(callback); } @Override - public void removeCallback(VideoAdPlayerCallback callback) { + public void removeCallback(@NonNull VideoAdPlayerCallback callback) { callbacks.remove(callback); } @@ -228,7 +217,7 @@ public int getVolume() { @androidx.media3.common.util.UnstableApi class ImaListener implements AnalyticsListener { @Override - public void onPlaybackStateChanged(EventTime eventTime, int playbackState) { + public void onPlaybackStateChanged(@NonNull EventTime eventTime, int playbackState) { if (currentAd == null) { // This may be null if state changes after stopAd for a given mediaInfo return; @@ -255,7 +244,7 @@ public void onPlaybackStateChanged(EventTime eventTime, int playbackState) { @Override public void onPlayWhenReadyChanged( - AnalyticsListener.EventTime eventTime, boolean playWhenReady, int playbackState) { + @NonNull AnalyticsListener.EventTime eventTime, boolean playWhenReady, int playbackState) { if (currentAd == null) { // This may be null if state changes after stopAd for a given mediaInfo return; diff --git a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/MainActivity.java b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/MainActivity.java index 11368755..1999ffc7 100644 --- a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/MainActivity.java +++ b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/MainActivity.java @@ -7,11 +7,7 @@ import android.content.ServiceConnection; import android.os.Bundle; import android.os.IBinder; -import android.view.View; -import android.view.View.OnClickListener; import android.view.ViewGroup; -import android.widget.AdapterView; -import android.widget.AdapterView.OnItemClickListener; import android.widget.ArrayAdapter; import android.widget.Button; import android.widget.ListView; @@ -48,23 +44,17 @@ protected void onCreate(Bundle savedInstanceState) { ListView listView = findViewById(R.id.list_view); listView.setAdapter(new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, sampleList)); listView.setOnItemClickListener( - new OnItemClickListener() { - @Override - public void onItemClick(AdapterView parent, View view, int position, long id) { - if (serviceBound) { - binder.updateSong(position); - } + (parent, view, position, id) -> { + if (serviceBound) { + binder.updateSong(position); } }); Button requestAdButton = findViewById(R.id.requestAd); requestAdButton.setOnClickListener( - new OnClickListener() { - @Override - public void onClick(View v) { - if (serviceBound) { - binder.requestAd(AD_TAG_URL); - } + view -> { + if (serviceBound) { + binder.requestAd(AD_TAG_URL); } }); } @@ -72,9 +62,7 @@ public void onClick(View v) { @Override public void onDestroy() { super.onDestroy(); - if (connection != null) { - unbindService(connection); - } + unbindService(connection); } /** Defines callbacks for service binding, passed to bindService() */ diff --git a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Samples.java b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Samples.java index 722669e6..e3cadb1f 100644 --- a/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Samples.java +++ b/audioplayerexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/audioplayerexample/Samples.java @@ -8,6 +8,7 @@ import android.support.v4.media.MediaDescriptionCompat; import android.support.v4.media.MediaMetadataCompat; import androidx.annotation.DrawableRes; +import androidx.annotation.NonNull; /** Helper to provide a list of sample audio files for the app. */ public final class Samples { @@ -29,6 +30,7 @@ public Sample( this.bitmapResource = bitmapResource; } + @NonNull @Override public String toString() { return title; @@ -76,7 +78,11 @@ public static MediaDescriptionCompat getMediaDescription(Context context, Sample } public static Bitmap getBitmap(Context context, @DrawableRes int bitmapResource) { - return ((BitmapDrawable) context.getResources().getDrawable(bitmapResource)).getBitmap(); + return ((BitmapDrawable) + Objects.requireNonNull( + ResourcesCompat.getDrawable( + context.getResources(), bitmapResource, context.getTheme()))) + .getBitmap(); } private Samples() {} diff --git a/audioplayerexample/gradle/wrapper/gradle-wrapper.properties b/audioplayerexample/gradle/wrapper/gradle-wrapper.properties index 5d6560a4..348c409e 100644 --- a/audioplayerexample/gradle/wrapper/gradle-wrapper.properties +++ b/audioplayerexample/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-all.zip diff --git a/basicexample/app/build.gradle b/basicexample/app/build.gradle index 65294779..172d41ad 100644 --- a/basicexample/app/build.gradle +++ b/basicexample/app/build.gradle @@ -36,5 +36,5 @@ dependencies { implementation 'androidx.appcompat:appcompat:1.7.0' implementation 'androidx.browser:browser:1.8.0' implementation 'androidx.media:media:1.7.0' - implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.34.0' + implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.35.0' } diff --git a/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java b/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java index f03dbdf9..7fa41304 100644 --- a/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java +++ b/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/MyActivity.java @@ -58,7 +58,6 @@ public class MyActivity extends AppCompatActivity { // the VideoView. private VideoView videoPlayer; private MediaController mediaController; - private View playButton; private VideoAdPlayerAdapter videoAdPlayerAdapter; @Override @@ -91,7 +90,7 @@ protected void onCreate(Bundle savedInstanceState) { new AdErrorEvent.AdErrorListener() { /** An event raised when there is an error loading or playing ads. */ @Override - public void onAdError(AdErrorEvent adErrorEvent) { + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { Log.i(LOGTAG, "Ad Error: " + adErrorEvent.getError().getMessage()); resumeContent(); } @@ -99,7 +98,7 @@ public void onAdError(AdErrorEvent adErrorEvent) { adsLoader.addAdsLoadedListener( new AdsLoader.AdsLoadedListener() { @Override - public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) { + public void onAdsManagerLoaded(@NonNull AdsManagerLoadedEvent adsManagerLoadedEvent) { // Ads were successfully loaded, so get the AdsManager instance. AdsManager has // events for ad playback and errors. adsManager = adsManagerLoadedEvent.getAdsManager(); @@ -109,7 +108,7 @@ public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) { new AdErrorEvent.AdErrorListener() { /** An event raised when there is an error loading or playing ads. */ @Override - public void onAdError(AdErrorEvent adErrorEvent) { + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { Log.e(LOGTAG, "Ad Error: " + adErrorEvent.getError().getMessage()); String universalAdIds = Arrays.toString(adsManager.getCurrentAd().getUniversalAdIds()); @@ -125,7 +124,7 @@ public void onAdError(AdErrorEvent adErrorEvent) { new AdEvent.AdEventListener() { /** Responds to AdEvents. */ @Override - public void onAdEvent(AdEvent adEvent) { + public void onAdEvent(@NonNull AdEvent adEvent) { if (adEvent.getType() != AdEvent.AdEventType.AD_PROGRESS) { Log.i(LOGTAG, "Event: " + adEvent.getType()); } @@ -182,7 +181,7 @@ public void onAdEvent(AdEvent adEvent) { }); // When the play button is clicked, request ads and hide the button. - playButton = findViewById(R.id.playButton); + View playButton = findViewById(R.id.playButton); playButton.setOnClickListener( view -> { videoPlayer.setVideoPath(SAMPLE_VIDEO_URL); diff --git a/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoAdPlayerAdapter.java b/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoAdPlayerAdapter.java index e916220a..8fa26438 100644 --- a/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoAdPlayerAdapter.java +++ b/basicexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoAdPlayerAdapter.java @@ -7,6 +7,7 @@ import android.net.Uri; import android.util.Log; import android.widget.VideoView; +import androidx.annotation.NonNull; import com.google.ads.interactivemedia.v3.api.AdPodInfo; import com.google.ads.interactivemedia.v3.api.player.AdMediaInfo; import com.google.ads.interactivemedia.v3.api.player.VideoAdPlayer; @@ -40,12 +41,12 @@ public VideoAdPlayerAdapter(VideoView videoPlayer, AudioManager audioManager) { } @Override - public void addCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void addCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { videoAdPlayerCallbacks.add(videoAdPlayerCallback); } @Override - public void loadAd(AdMediaInfo adMediaInfo, AdPodInfo adPodInfo) { + public void loadAd(@NonNull AdMediaInfo adMediaInfo, @NonNull AdPodInfo adPodInfo) { // This simple ad loading logic works because preloading is disabled. To support // preloading ads your app must maintain state for the currently playing ad // while handling upcoming ad downloading and buffering at the same time. @@ -55,7 +56,7 @@ public void loadAd(AdMediaInfo adMediaInfo, AdPodInfo adPodInfo) { } @Override - public void pauseAd(AdMediaInfo adMediaInfo) { + public void pauseAd(@NonNull AdMediaInfo adMediaInfo) { Log.i(LOGTAG, "pauseAd"); savedAdPosition = videoPlayer.getCurrentPosition(); stopAdTracking(); @@ -89,12 +90,12 @@ public void release() { } @Override - public void removeCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void removeCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { videoAdPlayerCallbacks.remove(videoAdPlayerCallback); } @Override - public void stopAd(AdMediaInfo adMediaInfo) { + public void stopAd(@NonNull AdMediaInfo adMediaInfo) { Log.i(LOGTAG, "stopAd"); stopAdTracking(); } @@ -176,6 +177,7 @@ private void stopAdTracking() { } } + @NonNull @Override public VideoProgressUpdate getAdProgress() { long adPosition = videoPlayer.getCurrentPosition(); diff --git a/basicexample/gradle/wrapper/gradle-wrapper.properties b/basicexample/gradle/wrapper/gradle-wrapper.properties index 5d6560a4..348c409e 100644 --- a/basicexample/gradle/wrapper/gradle-wrapper.properties +++ b/basicexample/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-all.zip diff --git a/umpexample/app/build.gradle b/umpexample/app/build.gradle index 19ae58c7..9aa3700f 100644 --- a/umpexample/app/build.gradle +++ b/umpexample/app/build.gradle @@ -36,6 +36,6 @@ dependencies { implementation 'androidx.appcompat:appcompat:1.7.0' implementation 'androidx.browser:browser:1.8.0' implementation 'androidx.media:media:1.7.0' - implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.34.0' - implementation 'com.google.android.ump:user-messaging-platform:2.2.0' + implementation 'com.google.ads.interactivemedia.v3:interactivemedia:3.35.0' + implementation 'com.google.android.ump:user-messaging-platform:3.0.0' } diff --git a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/ConsentManager.java b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/ConsentManager.java index 6e00f764..1258424f 100644 --- a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/ConsentManager.java +++ b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/ConsentManager.java @@ -72,13 +72,8 @@ public void gatherConsent(OnConsentGatheringCompleteListener onConsentGatheringC params, () -> UserMessagingPlatform.loadAndShowConsentFormIfRequired( - activity, - formError -> { - // Consent has been gathered. - onConsentGatheringCompleteListener.consentGatheringComplete(formError); - }), - requestConsentError -> - onConsentGatheringCompleteListener.consentGatheringComplete(requestConsentError)); + activity, onConsentGatheringCompleteListener::consentGatheringComplete), + onConsentGatheringCompleteListener::consentGatheringComplete); } /** Shows a form to app users for collecting their consent. */ diff --git a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/MyActivity.java b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/MyActivity.java index cfa0a7ea..19d25af3 100644 --- a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/MyActivity.java +++ b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/MyActivity.java @@ -18,7 +18,6 @@ import com.google.ads.interactivemedia.v3.api.AdEvent; import com.google.ads.interactivemedia.v3.api.AdsLoader; import com.google.ads.interactivemedia.v3.api.AdsManager; -import com.google.ads.interactivemedia.v3.api.AdsManagerLoadedEvent; import com.google.ads.interactivemedia.v3.api.AdsRenderingSettings; import com.google.ads.interactivemedia.v3.api.AdsRequest; import com.google.ads.interactivemedia.v3.api.ImaSdkFactory; @@ -140,105 +139,92 @@ private void createAdsLoader() { new AdErrorEvent.AdErrorListener() { /** An event raised when there is an error loading or playing ads. */ @Override - public void onAdError(AdErrorEvent adErrorEvent) { + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { Log.i(LOGTAG, "Ad Error: " + adErrorEvent.getError().getMessage()); resumeContent(); } }); + adsLoader.addAdsLoadedListener( - new AdsLoader.AdsLoadedListener() { - @Override - public void onAdsManagerLoaded(AdsManagerLoadedEvent adsManagerLoadedEvent) { - // Ads were successfully loaded, so get the AdsManager instance. AdsManager has - // events for ad playback and errors. - adsManager = adsManagerLoadedEvent.getAdsManager(); - - // Attach event and error event listeners. - adsManager.addAdErrorListener( - new AdErrorEvent.AdErrorListener() { - /** An event raised when there is an error loading or playing ads. */ - @Override - public void onAdError(AdErrorEvent adErrorEvent) { - Log.e(LOGTAG, "Ad Error: " + adErrorEvent.getError().getMessage()); - String universalAdIds = - Arrays.toString(adsManager.getCurrentAd().getUniversalAdIds()); - Log.i( - LOGTAG, - "Discarding the current ad break with universal " - + "ad Ids: " - + universalAdIds); - adsManager.discardAdBreak(); + adsManagerLoadedEvent -> { + // Ads were successfully loaded, so get the AdsManager instance. AdsManager has + // events for ad playback and errors. + adsManager = adsManagerLoadedEvent.getAdsManager(); + + // Attach event and error event listeners. + adsManager.addAdErrorListener( + new AdErrorEvent.AdErrorListener() { + /** An event raised when there is an error loading or playing ads. */ + @Override + public void onAdError(@NonNull AdErrorEvent adErrorEvent) { + Log.e(LOGTAG, "Ad Error: " + adErrorEvent.getError().getMessage()); + String universalAdIds = + Arrays.toString(adsManager.getCurrentAd().getUniversalAdIds()); + Log.i( + LOGTAG, + "Discarding the current ad break with universal " + + "ad Ids: " + + universalAdIds); + adsManager.discardAdBreak(); + } + }); + adsManager.addAdEventListener( + new AdEvent.AdEventListener() { + /** Responds to AdEvents. */ + @Override + public void onAdEvent(@NonNull AdEvent adEvent) { + if (adEvent.getType() != AdEvent.AdEventType.AD_PROGRESS) { + Log.i(LOGTAG, "Event: " + adEvent.getType()); } - }); - adsManager.addAdEventListener( - new AdEvent.AdEventListener() { - /** Responds to AdEvents. */ - @Override - public void onAdEvent(AdEvent adEvent) { - if (adEvent.getType() != AdEvent.AdEventType.AD_PROGRESS) { - Log.i(LOGTAG, "Event: " + adEvent.getType()); - } - // These are the suggested event types to handle. For full list of - // all ad event types, see AdEvent.AdEventType documentation. - switch (adEvent.getType()) { - case LOADED: - // AdEventType.LOADED is fired when ads are ready to play. - - // This sample app uses the sample tag - // single_preroll_skippable_ad_tag_url that requires calling - // AdsManager.start() to start ad playback. - // If you use a different ad tag URL that returns a VMAP or - // an ad rules playlist, the adsManager.init() function will - // trigger ad playback automatically and the IMA SDK will - // ignore the adsManager.start(). - // It is safe to always call adsManager.start() in the - // LOADED event. - adsManager.start(); - break; - case CONTENT_PAUSE_REQUESTED: - // AdEventType.CONTENT_PAUSE_REQUESTED is fired when you - // should pause your content and start playing an ad. - pauseContentForAds(); - break; - case CONTENT_RESUME_REQUESTED: - // AdEventType.CONTENT_RESUME_REQUESTED is fired when the ad - // you should play your content. - resumeContent(); - break; - case ALL_ADS_COMPLETED: - // Calling adsManager.destroy() triggers the function - // VideoAdPlayer.release(). - adsManager.destroy(); - adsManager = null; - break; - case CLICKED: - // When the user clicks on the Learn More button, the IMA SDK fires - // this event, pauses the ad, and opens the ad's click-through URL. - // When the user returns to the app, the IMA SDK calls the - // VideoAdPlayer.playAd() function automatically. - break; - default: - break; - } + // These are the suggested event types to handle. For full list of + // all ad event types, see AdEvent.AdEventType documentation. + switch (adEvent.getType()) { + case LOADED: + // AdEventType.LOADED is fired when ads are ready to play. + + // This sample app uses the sample tag + // single_preroll_skippable_ad_tag_url that requires calling + // AdsManager.start() to start ad playback. + // If you use a different ad tag URL that returns a VMAP or + // an ad rules playlist, the adsManager.init() function will + // trigger ad playback automatically and the IMA SDK will + // ignore the adsManager.start(). + // It is safe to always call adsManager.start() in the + // LOADED event. + adsManager.start(); + break; + case CONTENT_PAUSE_REQUESTED: + // AdEventType.CONTENT_PAUSE_REQUESTED is fired when you + // should pause your content and start playing an ad. + pauseContentForAds(); + break; + case CONTENT_RESUME_REQUESTED: + // AdEventType.CONTENT_RESUME_REQUESTED is fired when the ad + // you should play your content. + resumeContent(); + break; + case ALL_ADS_COMPLETED: + // Calling adsManager.destroy() triggers the function + // VideoAdPlayer.release(). + adsManager.destroy(); + adsManager = null; + break; + case CLICKED: + // When the user clicks on the Learn More button, the IMA SDK fires + // this event, pauses the ad, and opens the ad's click-through URL. + // When the user returns to the app, the IMA SDK calls the + // VideoAdPlayer.playAd() function automatically. + break; + default: + break; } - }); - AdsRenderingSettings adsRenderingSettings = - ImaSdkFactory.getInstance().createAdsRenderingSettings(); - // Add any ads rendering settings here. - // This init() only loads the UI rendering settings locally. - adsManager.init(adsRenderingSettings); - } - }); - } - - private void setUpPlayButton() { - // When the play button is clicked, request ads and hide the button. - View playButton = findViewById(R.id.playButton); - playButton.setOnClickListener( - view -> { - videoPlayer.setVideoPath(SAMPLE_VIDEO_URL); - requestAds(SAMPLE_VAST_TAG_URL); - view.setVisibility(View.GONE); + } + }); + AdsRenderingSettings adsRenderingSettings = + ImaSdkFactory.getInstance().createAdsRenderingSettings(); + // Add any ads rendering settings here. + // This init() only loads the UI rendering settings locally. + adsManager.init(adsRenderingSettings); }); } diff --git a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/VideoAdPlayerAdapter.java b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/VideoAdPlayerAdapter.java index 959e16da..01ea3e14 100644 --- a/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/VideoAdPlayerAdapter.java +++ b/umpexample/app/src/main/java/com/google/ads/interactivemedia/v3/samples/umpimaapp/VideoAdPlayerAdapter.java @@ -7,6 +7,7 @@ import android.net.Uri; import android.util.Log; import android.widget.VideoView; +import androidx.annotation.NonNull; import com.google.ads.interactivemedia.v3.api.AdPodInfo; import com.google.ads.interactivemedia.v3.api.player.AdMediaInfo; import com.google.ads.interactivemedia.v3.api.player.VideoAdPlayer; @@ -40,12 +41,12 @@ public VideoAdPlayerAdapter(VideoView videoPlayer, AudioManager audioManager) { } @Override - public void addCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void addCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { videoAdPlayerCallbacks.add(videoAdPlayerCallback); } @Override - public void loadAd(AdMediaInfo adMediaInfo, AdPodInfo adPodInfo) { + public void loadAd(@NonNull AdMediaInfo adMediaInfo, @NonNull AdPodInfo adPodInfo) { // This simple ad loading logic works because preloading is disabled. To support // preloading ads your app must maintain state for the currently playing ad // while handling upcoming ad downloading and buffering at the same time. @@ -55,7 +56,7 @@ public void loadAd(AdMediaInfo adMediaInfo, AdPodInfo adPodInfo) { } @Override - public void pauseAd(AdMediaInfo adMediaInfo) { + public void pauseAd(@NonNull AdMediaInfo adMediaInfo) { Log.i(LOGTAG, "pauseAd"); savedAdPosition = videoPlayer.getCurrentPosition(); stopAdTracking(); @@ -89,12 +90,12 @@ public void release() { } @Override - public void removeCallback(VideoAdPlayerCallback videoAdPlayerCallback) { + public void removeCallback(@NonNull VideoAdPlayerCallback videoAdPlayerCallback) { videoAdPlayerCallbacks.remove(videoAdPlayerCallback); } @Override - public void stopAd(AdMediaInfo adMediaInfo) { + public void stopAd(@NonNull AdMediaInfo adMediaInfo) { Log.i(LOGTAG, "stopAd"); stopAdTracking(); } @@ -176,6 +177,7 @@ private void stopAdTracking() { } } + @NonNull @Override public VideoProgressUpdate getAdProgress() { long adPosition = videoPlayer.getCurrentPosition(); diff --git a/umpexample/gradle/wrapper/gradle-wrapper.properties b/umpexample/gradle/wrapper/gradle-wrapper.properties index 5d6560a4..348c409e 100644 --- a/umpexample/gradle/wrapper/gradle-wrapper.properties +++ b/umpexample/gradle/wrapper/gradle-wrapper.properties @@ -2,4 +2,4 @@ distributionBase=GRADLE_USER_HOME distributionPath=wrapper/dists zipStoreBase=GRADLE_USER_HOME zipStorePath=wrapper/dists -distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.9-all.zip