chore(android): fix some android studio warning (#3290)
Co-authored-by: olivier <olivier.bouillet@ifeelsmart.com>
This commit is contained in:
		| @@ -1,6 +1,5 @@ | |||||||
| package com.brentvatne.exoplayer; | package com.brentvatne.exoplayer; | ||||||
|  |  | ||||||
| import android.annotation.TargetApi; |  | ||||||
| import android.content.Context; | import android.content.Context; | ||||||
| import androidx.core.content.ContextCompat; | import androidx.core.content.ContextCompat; | ||||||
| import android.util.AttributeSet; | import android.util.AttributeSet; | ||||||
|   | |||||||
| @@ -1,13 +1,11 @@ | |||||||
| package com.brentvatne.exoplayer; | package com.brentvatne.exoplayer; | ||||||
|  |  | ||||||
| import java.io.IOException; |  | ||||||
| import com.google.android.exoplayer2.upstream.DefaultLoadErrorHandlingPolicy; | import com.google.android.exoplayer2.upstream.DefaultLoadErrorHandlingPolicy; | ||||||
| import com.google.android.exoplayer2.upstream.HttpDataSource.HttpDataSourceException; | import com.google.android.exoplayer2.upstream.HttpDataSource.HttpDataSourceException; | ||||||
| import com.google.android.exoplayer2.upstream.LoadErrorHandlingPolicy.LoadErrorInfo; |  | ||||||
| import com.google.android.exoplayer2.C; | import com.google.android.exoplayer2.C; | ||||||
|  |  | ||||||
| public final class ReactExoplayerLoadErrorHandlingPolicy extends DefaultLoadErrorHandlingPolicy { | public final class ReactExoplayerLoadErrorHandlingPolicy extends DefaultLoadErrorHandlingPolicy { | ||||||
|   private int minLoadRetryCount = Integer.MAX_VALUE; |   private final int minLoadRetryCount; | ||||||
|  |  | ||||||
|   public ReactExoplayerLoadErrorHandlingPolicy(int minLoadRetryCount) { |   public ReactExoplayerLoadErrorHandlingPolicy(int minLoadRetryCount) { | ||||||
|     super(minLoadRetryCount); |     super(minLoadRetryCount); | ||||||
| @@ -16,9 +14,11 @@ public final class ReactExoplayerLoadErrorHandlingPolicy extends DefaultLoadErro | |||||||
|  |  | ||||||
|   @Override |   @Override | ||||||
|   public long getRetryDelayMsFor(LoadErrorInfo loadErrorInfo) { |   public long getRetryDelayMsFor(LoadErrorInfo loadErrorInfo) { | ||||||
|  |     String errorMessage = loadErrorInfo.exception.getMessage(); | ||||||
|  |  | ||||||
|     if ( |     if ( | ||||||
|       loadErrorInfo.exception instanceof HttpDataSourceException && |       loadErrorInfo.exception instanceof HttpDataSourceException && | ||||||
|       (loadErrorInfo.exception.getMessage() == "Unable to connect" || loadErrorInfo.exception.getMessage() == "Software caused connection abort") |       errorMessage != null && (errorMessage.equals("Unable to connect") || errorMessage.equals("Software caused connection abort")) | ||||||
|     ) { |     ) { | ||||||
|       // Capture the error we get when there is no network connectivity and keep retrying it |       // Capture the error we get when there is no network connectivity and keep retrying it | ||||||
|       return 1000; // Retry every second |       return 1000; // Retry every second | ||||||
|   | |||||||
| @@ -22,6 +22,7 @@ import android.view.accessibility.CaptioningManager; | |||||||
| import android.widget.FrameLayout; | import android.widget.FrameLayout; | ||||||
| import android.widget.ImageButton; | import android.widget.ImageButton; | ||||||
|  |  | ||||||
|  | import androidx.annotation.NonNull; | ||||||
| import androidx.annotation.WorkerThread; | import androidx.annotation.WorkerThread; | ||||||
| import androidx.activity.OnBackPressedCallback; | import androidx.activity.OnBackPressedCallback; | ||||||
|  |  | ||||||
| @@ -485,7 +486,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|      * Update the layout |      * Update the layout | ||||||
|      * @param view  view needs to update layout |      * @param view  view needs to update layout | ||||||
|      * |      * | ||||||
|      * This is a workaround for the open bug in react-native: https://github.com/facebook/react-native/issues/17968 |      * This is a workaround for the open bug in react-native: <a href="https://github.com/facebook/react-native/issues/17968">...</a> | ||||||
|      */ |      */ | ||||||
|     private void reLayout(View view) { |     private void reLayout(View view) { | ||||||
|         if (view == null) return; |         if (view == null) return; | ||||||
| @@ -495,8 +496,8 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     private class RNVLoadControl extends DefaultLoadControl { |     private class RNVLoadControl extends DefaultLoadControl { | ||||||
|         private int availableHeapInBytes = 0; |         private final int availableHeapInBytes; | ||||||
|         private Runtime runtime; |         private final Runtime runtime; | ||||||
|         public RNVLoadControl(DefaultAllocator allocator, int minBufferMs, int maxBufferMs, int bufferForPlaybackMs, int bufferForPlaybackAfterRebufferMs, int targetBufferBytes, boolean prioritizeTimeOverSizeThresholds, int backBufferDurationMs, boolean retainBackBufferFromKeyframe) { |         public RNVLoadControl(DefaultAllocator allocator, int minBufferMs, int maxBufferMs, int bufferForPlaybackMs, int bufferForPlaybackAfterRebufferMs, int targetBufferBytes, boolean prioritizeTimeOverSizeThresholds, int backBufferDurationMs, boolean retainBackBufferFromKeyframe) { | ||||||
|             super(allocator, |             super(allocator, | ||||||
|                     minBufferMs, |                     minBufferMs, | ||||||
| @@ -508,7 +509,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|                     backBufferDurationMs, |                     backBufferDurationMs, | ||||||
|                     retainBackBufferFromKeyframe); |                     retainBackBufferFromKeyframe); | ||||||
|             runtime = Runtime.getRuntime(); |             runtime = Runtime.getRuntime(); | ||||||
|             ActivityManager activityManager = (ActivityManager) themedReactContext.getSystemService(themedReactContext.ACTIVITY_SERVICE); |             ActivityManager activityManager = (ActivityManager) themedReactContext.getSystemService(ThemedReactContext.ACTIVITY_SERVICE); | ||||||
|             availableHeapInBytes = (int) Math.floor(activityManager.getMemoryClass() * maxHeapAllocationPercent * 1024 * 1024); |             availableHeapInBytes = (int) Math.floor(activityManager.getMemoryClass() * maxHeapAllocationPercent * 1024 * 1024); | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -539,13 +540,6 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private void startBufferCheckTimer() { |  | ||||||
|         Player player = this.player; |  | ||||||
|         VideoEventEmitter eventEmitter = this.eventEmitter; |  | ||||||
|         Handler mainHandler = this.mainHandler; |  | ||||||
|  |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void initializePlayer() { |     private void initializePlayer() { | ||||||
|         ReactExoplayerView self = this; |         ReactExoplayerView self = this; | ||||||
|         Activity activity = themedReactContext.getCurrentActivity(); |         Activity activity = themedReactContext.getCurrentActivity(); | ||||||
| @@ -734,7 +728,6 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         initializePlayerControl(); |         initializePlayerControl(); | ||||||
|         setControls(controls); |         setControls(controls); | ||||||
|         applyModifiers(); |         applyModifiers(); | ||||||
|         startBufferCheckTimer(); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private DrmSessionManager buildDrmSessionManager(UUID uuid, String licenseUrl, String[] keyRequestPropertiesArray) throws UnsupportedDrmException { |     private DrmSessionManager buildDrmSessionManager(UUID uuid, String licenseUrl, String[] keyRequestPropertiesArray) throws UnsupportedDrmException { | ||||||
| @@ -790,8 +783,8 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         MediaItem mediaItem = mediaItemBuilder.build(); |         MediaItem mediaItem = mediaItemBuilder.build(); | ||||||
|         MediaSource mediaSource = null; |         MediaSource mediaSource; | ||||||
|         DrmSessionManagerProvider drmProvider = null; |         DrmSessionManagerProvider drmProvider; | ||||||
|         if (drmSessionManager != null) { |         if (drmSessionManager != null) { | ||||||
|             drmProvider = new DrmSessionManagerProvider() { |             drmProvider = new DrmSessionManagerProvider() { | ||||||
|                 @Override |                 @Override | ||||||
| @@ -868,10 +861,8 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|             Uri uri = Uri.parse(textTrack.getString("uri")); |             Uri uri = Uri.parse(textTrack.getString("uri")); | ||||||
|             MediaSource textSource = buildTextSource(title, uri, textTrack.getString("type"), |             MediaSource textSource = buildTextSource(title, uri, textTrack.getString("type"), | ||||||
|                     language); |                     language); | ||||||
|             if (textSource != null) { |  | ||||||
|             textSources.add(textSource); |             textSources.add(textSource); | ||||||
|         } |         } | ||||||
|         } |  | ||||||
|         return textSources; |         return textSources; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1074,7 +1065,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onEvents(Player player, Player.Events events) { |     public void onEvents(@NonNull Player player, Player.Events events) { | ||||||
|         if (events.contains(Player.EVENT_PLAYBACK_STATE_CHANGED) || events.contains(Player.EVENT_PLAY_WHEN_READY_CHANGED)) { |         if (events.contains(Player.EVENT_PLAYBACK_STATE_CHANGED) || events.contains(Player.EVENT_PLAY_WHEN_READY_CHANGED)) { | ||||||
|             int playbackState = player.getPlaybackState(); |             int playbackState = player.getPlaybackState(); | ||||||
|             boolean playWhenReady = player.getPlayWhenReady(); |             boolean playWhenReady = player.getPlayWhenReady(); | ||||||
| @@ -1122,6 +1113,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|                 text += "unknown"; |                 text += "unknown"; | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|  |             DebugLog.d(TAG, text); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1267,12 +1259,12 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         final Uri sourceUri = this.srcUri; |         final Uri sourceUri = this.srcUri; | ||||||
|         final long startTime = this.contentStartTime * 1000 - 100; // s -> ms with 100ms offset |         final long startTime = this.contentStartTime * 1000 - 100; // s -> ms with 100ms offset | ||||||
|  |  | ||||||
|         Future<ArrayList<VideoTrack>> result = es.submit(new Callable<ArrayList<VideoTrack>>() { |         Future<ArrayList<VideoTrack>> result = es.submit(new Callable<>() { | ||||||
|             DataSource ds = dataSource; |             final DataSource ds = dataSource; | ||||||
|             Uri uri = sourceUri; |             final Uri uri = sourceUri; | ||||||
|             long startTimeUs = startTime * 1000; // ms -> us |             final long startTimeUs = startTime * 1000; // ms -> us | ||||||
|  |  | ||||||
|             public ArrayList<VideoTrack> call() throws Exception { |             public ArrayList<VideoTrack> call() { | ||||||
|                 ArrayList<VideoTrack> videoTracks = new ArrayList<>(); |                 ArrayList<VideoTrack> videoTracks = new ArrayList<>(); | ||||||
|                 try  { |                 try  { | ||||||
|                     DashManifest manifest = DashUtil.loadManifest(this.ds, this.uri); |                     DashManifest manifest = DashUtil.loadManifest(this.ds, this.uri); | ||||||
| @@ -1307,7 +1299,9 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|                             } |                             } | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|                 } catch (Exception e) {} |                 } catch (Exception e) { | ||||||
|  |                     DebugLog.w(TAG, "error in getVideoTrackInfoFromManifest:" + e.getMessage()); | ||||||
|  |                 } | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|         }); |         }); | ||||||
| @@ -1319,7 +1313,9 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|             } |             } | ||||||
|             es.shutdown(); |             es.shutdown(); | ||||||
|             return results; |             return results; | ||||||
|         } catch (Exception e) {} |         } catch (Exception e) { | ||||||
|  |             DebugLog.w(TAG, "error in getVideoTrackInfoFromManifest handling request:" + e.getMessage()); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| @@ -1359,15 +1355,11 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         isBuffering = buffering; |         isBuffering = buffering; | ||||||
|         if (buffering) { |         eventEmitter.buffering(buffering); | ||||||
|             eventEmitter.buffering(true); |  | ||||||
|         } else { |  | ||||||
|             eventEmitter.buffering(false); |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onPositionDiscontinuity(Player.PositionInfo oldPosition, Player.PositionInfo newPosition, int reason) { |     public void onPositionDiscontinuity(@NonNull Player.PositionInfo oldPosition, @NonNull Player.PositionInfo newPosition, int reason) { | ||||||
|         if (playerNeedsSource) { |         if (playerNeedsSource) { | ||||||
|             // This will only occur if the user has performed a seek whilst in the error state. Update the |             // This will only occur if the user has performed a seek whilst in the error state. Update the | ||||||
|             // resume position so that if the user then retries, playback will resume from the position to |             // resume position so that if the user then retries, playback will resume from the position to | ||||||
| @@ -1389,7 +1381,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onTimelineChanged(Timeline timeline, int reason) { |     public void onTimelineChanged(@NonNull Timeline timeline, int reason) { | ||||||
|         // Do nothing. |         // Do nothing. | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1416,7 +1408,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onTracksChanged(Tracks tracks) { |     public void onTracksChanged(@NonNull Tracks tracks) { | ||||||
|         eventEmitter.textTracks(getTextTrackInfo()); |         eventEmitter.textTracks(getTextTrackInfo()); | ||||||
|         eventEmitter.audioTracks(getAudioTrackInfo()); |         eventEmitter.audioTracks(getAudioTrackInfo()); | ||||||
|         eventEmitter.videoTracks(getVideoTrackInfo()); |         eventEmitter.videoTracks(getVideoTrackInfo()); | ||||||
| @@ -1433,13 +1425,9 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onPlayerError(PlaybackException e) { |     public void onPlayerError(@NonNull PlaybackException e) { | ||||||
|         if (e == null) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         String errorString = "ExoPlaybackException: " + PlaybackException.getErrorCodeName(e.errorCode); |         String errorString = "ExoPlaybackException: " + PlaybackException.getErrorCodeName(e.errorCode); | ||||||
|         String errorCode = "2" + String.valueOf(e.errorCode); |         String errorCode = "2" + String.valueOf(e.errorCode); | ||||||
|         boolean needsReInitialization = false; |  | ||||||
|         switch(e.errorCode) { |         switch(e.errorCode) { | ||||||
|             case PlaybackException.ERROR_CODE_DRM_DEVICE_REVOKED: |             case PlaybackException.ERROR_CODE_DRM_DEVICE_REVOKED: | ||||||
|             case PlaybackException.ERROR_CODE_DRM_LICENSE_ACQUISITION_FAILED: |             case PlaybackException.ERROR_CODE_DRM_LICENSE_ACQUISITION_FAILED: | ||||||
| @@ -1466,9 +1454,6 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|             initializePlayer(); |             initializePlayer(); | ||||||
|         } else { |         } else { | ||||||
|             updateResumePosition(); |             updateResumePosition(); | ||||||
|             if (needsReInitialization) { |  | ||||||
|                 initializePlayer(); |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1489,7 +1474,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public void onMetadata(Metadata metadata) { |     public void onMetadata(@NonNull Metadata metadata) { | ||||||
|         eventEmitter.timedMetadata(metadata); |         eventEmitter.timedMetadata(metadata); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1702,8 +1687,8 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         if (groupIndex == C.INDEX_UNSET && trackType == C.TRACK_TYPE_VIDEO && groups.length != 0) { // Video auto |         if (groupIndex == C.INDEX_UNSET && trackType == C.TRACK_TYPE_VIDEO && groups.length != 0) { // Video auto | ||||||
|             // Add all tracks as valid options for ABR to choose from |             // Add all tracks as valid options for ABR to choose from | ||||||
|             TrackGroup group = groups.get(0); |             TrackGroup group = groups.get(0); | ||||||
|             tracks = new ArrayList<Integer>(group.length); |             tracks = new ArrayList<>(group.length); | ||||||
|             ArrayList<Integer> allTracks = new ArrayList<Integer>(group.length); |             ArrayList<Integer> allTracks = new ArrayList<>(group.length); | ||||||
|             groupIndex = 0; |             groupIndex = 0; | ||||||
|             for (int j = 0; j < group.length; j++) { |             for (int j = 0; j < group.length; j++) { | ||||||
|                 allTracks.add(j); |                 allTracks.add(j); | ||||||
| @@ -1711,7 +1696,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|  |  | ||||||
|             // Valiate list of all tracks and add only supported formats |             // Valiate list of all tracks and add only supported formats | ||||||
|             int supportedFormatLength = 0; |             int supportedFormatLength = 0; | ||||||
|             ArrayList<Integer> supportedTrackList = new ArrayList<Integer>(); |             ArrayList<Integer> supportedTrackList = new ArrayList<>(); | ||||||
|             for (int g = 0; g < allTracks.size(); g++) { |             for (int g = 0; g < allTracks.size(); g++) { | ||||||
|                 Format format = group.getFormat(g); |                 Format format = group.getFormat(g); | ||||||
|                 if (isFormatSupported(format)) { |                 if (isFormatSupported(format)) { | ||||||
| @@ -1757,7 +1742,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|         if (mimeType == null) { |         if (mimeType == null) { | ||||||
|             return true; |             return true; | ||||||
|         } |         } | ||||||
|         boolean isSupported = false; |         boolean isSupported; | ||||||
|         try { |         try { | ||||||
|             MediaCodecInfo codecInfo = MediaCodecUtil.getDecoderInfo(mimeType, false, false); |             MediaCodecInfo codecInfo = MediaCodecUtil.getDecoderInfo(mimeType, false, false); | ||||||
|             isSupported = codecInfo.isVideoSizeAndRateSupportedV21(width, height, frameRate); |             isSupported = codecInfo.isVideoSizeAndRateSupportedV21(width, height, frameRate); | ||||||
| @@ -1913,7 +1898,7 @@ public class ReactExoplayerView extends FrameLayout implements | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void setContentStartTime(int contentStartTime) { |     public void setContentStartTime(int contentStartTime) { | ||||||
|         this.contentStartTime = (long)contentStartTime; |         this.contentStartTime = contentStartTime; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     public void setDisableBuffering(boolean disableBuffering) { |     public void setDisableBuffering(boolean disableBuffering) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user