diff --git a/demo/src/main/java/com/devbrackets/android/exomediademo/FullScreenVideoPlayerActivity.java b/demo/src/main/java/com/devbrackets/android/exomediademo/FullScreenVideoPlayerActivity.java index 13002a57..6174725c 100644 --- a/demo/src/main/java/com/devbrackets/android/exomediademo/FullScreenVideoPlayerActivity.java +++ b/demo/src/main/java/com/devbrackets/android/exomediademo/FullScreenVideoPlayerActivity.java @@ -9,7 +9,7 @@ /** * A simple example of making a fullscreen video player activity. - *
+ ** NOTE: the EMVideoView setup is done in the {@link VideoPlayerActivity} */ public class FullScreenVideoPlayerActivity extends VideoPlayerActivity { diff --git a/library/build.gradle b/library/build.gradle index f2f80319..17d8e2e5 100644 --- a/library/build.gradle +++ b/library/build.gradle @@ -35,6 +35,10 @@ android { targetCompatibility JavaVersion.VERSION_1_7 } + lintOptions { + abortOnError false + } + packagingOptions { exclude 'META-INF/LICENSE' exclude 'META-INF/LICENSE.txt' diff --git a/library/src/main/java/com/devbrackets/android/exomedia/DefaultControls.java b/library/src/main/java/com/devbrackets/android/exomedia/DefaultControls.java index 56ab1c2c..324dc2db 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/DefaultControls.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/DefaultControls.java @@ -285,7 +285,7 @@ public void updatePlayPauseImage(boolean isPlaying) { * Sets the button state for the Previous button. This will just * change the images specified with {@link #setPreviousImageResource(int)}, * or use the defaults if they haven't been set, and block any click events. - *
+ ** This method will NOT re-add buttons that have previously been removed with * {@link #setNextButtonRemoved(boolean)}. * @@ -299,7 +299,7 @@ public void setPreviousButtonEnabled(boolean enabled) { * Sets the button state for the Next button. This will just * change the images specified with {@link #setNextImageResource(int)}, * or use the defaults if they haven't been set, and block any click events. - *
+ ** This method will NOT re-add buttons that have previously been removed with * {@link #setPreviousButtonRemoved(boolean)}. * diff --git a/library/src/main/java/com/devbrackets/android/exomedia/EMAudioPlayer.java b/library/src/main/java/com/devbrackets/android/exomedia/EMAudioPlayer.java index 959e1106..b8709df1 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/EMAudioPlayer.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/EMAudioPlayer.java @@ -41,7 +41,7 @@ * An AudioPlayer that uses the ExoPlayer as the backing architecture. If the current device * does NOT pass the Android Compatibility Test Suite (CTS) then the backing architecture * will fall back to using the default Android MediaPlayer. - *
+ ** To help with quick conversions from the Android MediaPlayer this class follows the APIs * the MediaPlayer provides. */ @@ -476,7 +476,7 @@ public long getDuration() { * only be used when the item doesn't return the correct duration such as with audio streams. * This only overrides the current audio item. * - * @param duration The duration for the current media item or < 0 to disable + * @param duration The duration for the current media item or < 0 to disable */ public void overrideDuration(int duration) { overriddenDuration = duration; diff --git a/library/src/main/java/com/devbrackets/android/exomedia/EMVideoView.java b/library/src/main/java/com/devbrackets/android/exomedia/EMVideoView.java index 40a65c68..8561bbd9 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/EMVideoView.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/EMVideoView.java @@ -57,7 +57,7 @@ * JellyBean. On devices with JellyBean and up we will use the ExoPlayer in order to * better support HLS streaming and full 1080p video resolutions which the VideoView * struggles with, and in some cases crashes. - *
+ ** To an external user this view should have the same APIs used with the standard VideoView * to help with quick implementations. */ @@ -497,10 +497,10 @@ public void showDefaultControls() { * Sets the button state for the Previous button on the default controls; see * {@link #setDefaultControlsEnabled(boolean)}. * {@link #setDefaultControlsEnabled(boolean)} must be called prior to this. - *
+ ** This will just change the images specified with {@link #setPreviousImageResource(int)}, * or use the defaults if they haven't been set, and block any click events. - *
+ ** This method will NOT re-add buttons that have previously been removed with * {@link #setPreviousButtonRemoved(boolean)}. * @@ -516,10 +516,10 @@ public void setPreviousButtonEnabled(boolean enabled) { * Sets the button state for the Next button on the default controls; see * {@link #setDefaultControlsEnabled(boolean)}. * {@link #setDefaultControlsEnabled(boolean)} must be called prior to this. - *
+ ** This will just change the images specified with {@link #setNextImageResource(int)}, * or use the defaults if they haven't been set, and block any click events. - *
+ ** This method will NOT re-add buttons that have previously been removed with * {@link #setNextButtonRemoved(boolean)}. * @@ -834,7 +834,7 @@ public long getDuration() { * only be used when the item doesn't return the correct duration such as with audio streams. * This only overrides the current audio item. * - * @param duration The duration for the current media item or < 0 to disable + * @param duration The duration for the current media item or < 0 to disable */ public void overrideDuration(int duration) { overriddenDuration = duration; diff --git a/library/src/main/java/com/devbrackets/android/exomedia/listener/InternalErrorListener.java b/library/src/main/java/com/devbrackets/android/exomedia/listener/InternalErrorListener.java index 2664d3da..f886824b 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/listener/InternalErrorListener.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/listener/InternalErrorListener.java @@ -25,7 +25,7 @@ /** * A listener for internal errors. - *
+ ** These errors are not visible to the user, and hence this listener is provided for * informational purposes only. Note however that an internal error may cause a fatal * error if the player fails to recover. If this happens, {@link ExoPlayerListener#onError(Exception)} diff --git a/library/src/main/java/com/devbrackets/android/exomedia/manager/EMPlaylistManager.java b/library/src/main/java/com/devbrackets/android/exomedia/manager/EMPlaylistManager.java index d22fc413..16c618c7 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/manager/EMPlaylistManager.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/manager/EMPlaylistManager.java @@ -57,15 +57,25 @@ public enum MediaType { public interface PlaylistItem { long getId(); + long getPlaylistId(); + boolean isAudio(); + boolean isVideo(); + String getMediaUrl(); + String getDownloadedMediaUri(); + String getThumbnailUrl(); + String getArtworkUrl(); + String getTitle(); + String getAlbum(); + String getArtist(); } @@ -86,6 +96,7 @@ public interface PlaylistItem { private Intent seekEndedIntent, allowedTypeChangedIntent; protected abstract Application getApplication(); + protected abstract Class extends Service> getMediaServiceClass(); /** @@ -224,9 +235,9 @@ public void unRegisterServiceCallbacks(EMPlaylistServiceCallback callback) { * item as specified by the passed parameters. * * @param playListItems The list of items to play - * @param startIndex The index in the playlistItems to start playback - * @param seekPosition The position in the startIndex item to start at (in milliseconds) - * @param startPaused True if the media item should start paused instead of playing + * @param startIndex The index in the playlistItems to start playback + * @param seekPosition The position in the startIndex item to start at (in milliseconds) + * @param startPaused True if the media item should start paused instead of playing */ public void play(List playListItems, int startIndex, int seekPosition, boolean startPaused) { setParameters(playListItems, startIndex); @@ -257,7 +268,7 @@ public void play(int seekPosition, boolean startPaused) { * and video items. * * @param playListItems The List of items to play - * @param startIndex The index in the list to start playback with + * @param startIndex The index in the list to start playback with */ public void setParameters(List playListItems, int startIndex) { playList = playListItems; @@ -576,7 +587,7 @@ public void invokeSeekEnded(int seekPosition) { * Creates the Intents that will be used to interact with the playlist service * * @param mediaServiceClass The class to inform of any media playback controls - * @param application The application to use when constructing the intents used to inform the playlist service of invocations + * @param application The application to use when constructing the intents used to inform the playlist service of invocations */ protected void constructControlIntents(Class extends Service> mediaServiceClass, Application application) { //Creates the pending intents @@ -681,9 +692,9 @@ private boolean isAllowedType(I item) { /** * Creates a PendingIntent for the given action to the specified service * - * @param application The application to use when creating the pending intent + * @param application The application to use when creating the pending intent * @param serviceClass The service class to notify of intents - * @param action The action to use + * @param action The action to use * @return The resulting PendingIntent */ private PendingIntent createPendingIntent(Application application, Class extends Service> serviceClass, String action) { diff --git a/library/src/main/java/com/devbrackets/android/exomedia/service/EMPlaylistService.java b/library/src/main/java/com/devbrackets/android/exomedia/service/EMPlaylistService.java index e64161f6..e825654c 100644 --- a/library/src/main/java/com/devbrackets/android/exomedia/service/EMPlaylistService.java +++ b/library/src/main/java/com/devbrackets/android/exomedia/service/EMPlaylistService.java @@ -54,7 +54,7 @@ /** * NOTE: This service will request a wifi wakelock if the item * being played isn't downloaded (see {@link #isDownloaded(EMPlaylistManager.PlaylistItem)}). - *
+ *
* This requires the manifest permission <uses-permission android:name="android.permission.WAKE_LOCK" />
*/
@SuppressWarnings("unused")
@@ -103,10 +103,15 @@ public enum MediaState {
protected List
* This will be called any time the notification is updated
*
* @return The image to display in the secondary position
@@ -265,7 +270,7 @@ protected Bitmap getDefaultLargeNotificationSecondaryImage() {
/**
* Called when the image in the notification needs to be updated.
*
- * @param size The square size for the image to display
+ * @param size The square size for the image to display
* @param playlistItem The media item to get the image for
*/
protected void updateLargeNotificationImage(int size, I playlistItem) {
@@ -787,7 +792,7 @@ protected void onLockScreenArtworkUpdated() {
/**
* Starts the actual item playback, correctly determining if the
* item is a video or an audio item.
- *
+ *
* NOTE: In order to play videos you will need to specify the
* VideoView with {@link EMPlaylistManager#setVideoView(EMVideoView)}
*/
@@ -959,14 +964,14 @@ protected void seekToNextPlayableItem() {
}
//Only iterate through the list if we aren't connected to the internet
- if(!isNetworkAvailable()) {
- while(currentItem != null && !isDownloaded(currentItem)) {
+ if (!isNetworkAvailable()) {
+ while (currentItem != null && !isDownloaded(currentItem)) {
currentItem = getMediaPlaylistManager().next();
}
}
//If we are unable to get a next playable item, post a network error
- if(currentItem == null) {
+ if (currentItem == null) {
onNoNonNetworkItemsAvailable();
}