summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorByteHamster <info@bytehamster.com>2020-03-27 17:58:38 +0100
committerByteHamster <info@bytehamster.com>2020-03-27 17:58:38 +0100
commitfa7e8baea6c3e130e3c6908e6ea1dcb01b7daee9 (patch)
tree694aa90c7cd5da32d8c4994a5109eefe27d3c2cc
parent060cb2c180d9624d39fd8fd64fe5627e4147cfc5 (diff)
downloadAntennaPod-fa7e8baea6c3e130e3c6908e6ea1dcb01b7daee9.zip
Hide the miniplayer if there is no media playing
-rw-r--r--app/src/main/java/de/danoeh/antennapod/activity/MainActivity.java11
-rw-r--r--app/src/main/java/de/danoeh/antennapod/fragment/ExternalPlayerFragment.java96
2 files changed, 44 insertions, 63 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/activity/MainActivity.java b/app/src/main/java/de/danoeh/antennapod/activity/MainActivity.java
index 8b1c7115d..5743cda69 100644
--- a/app/src/main/java/de/danoeh/antennapod/activity/MainActivity.java
+++ b/app/src/main/java/de/danoeh/antennapod/activity/MainActivity.java
@@ -11,6 +11,8 @@ import android.os.Handler;
import android.util.Log;
import android.view.MenuItem;
import android.view.View;
+import android.view.ViewGroup;
+import android.widget.FrameLayout;
import android.widget.Toast;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
@@ -178,6 +180,15 @@ public class MainActivity extends CastEnabledActivity {
return sheetBehavior;
}
+ public void setPlayerVisible(boolean visible) {
+ getBottomSheet().setLocked(!visible);
+ FrameLayout mainView = findViewById(R.id.main_view);
+ ViewGroup.MarginLayoutParams params = (ViewGroup.MarginLayoutParams) mainView.getLayoutParams();
+ params.setMargins(0, 0, 0, visible ? (int) getResources().getDimension(R.dimen.external_player_height) : 0);
+ mainView.setLayoutParams(params);
+ findViewById(R.id.audioplayerFragment).setVisibility(visible ? View.VISIBLE : View.GONE);
+ }
+
public void loadFragment(String tag, Bundle args) {
Log.d(TAG, "loadFragment(tag: " + tag + ", args: " + args + ")");
Fragment fragment;
diff --git a/app/src/main/java/de/danoeh/antennapod/fragment/ExternalPlayerFragment.java b/app/src/main/java/de/danoeh/antennapod/fragment/ExternalPlayerFragment.java
index 2626713c1..5c8b5e03a 100644
--- a/app/src/main/java/de/danoeh/antennapod/fragment/ExternalPlayerFragment.java
+++ b/app/src/main/java/de/danoeh/antennapod/fragment/ExternalPlayerFragment.java
@@ -2,7 +2,6 @@ package de.danoeh.antennapod.fragment;
import android.content.Intent;
import android.os.Bundle;
-import androidx.fragment.app.Fragment;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
@@ -11,18 +10,17 @@ import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.ProgressBar;
import android.widget.TextView;
-
+import androidx.fragment.app.Fragment;
import com.bumptech.glide.Glide;
-
import com.bumptech.glide.request.RequestOptions;
import com.google.android.material.bottomsheet.BottomSheetBehavior;
import de.danoeh.antennapod.R;
import de.danoeh.antennapod.activity.MainActivity;
import de.danoeh.antennapod.core.event.PlaybackPositionEvent;
import de.danoeh.antennapod.core.feed.MediaType;
+import de.danoeh.antennapod.core.feed.util.ImageResourceUtils;
import de.danoeh.antennapod.core.glide.ApGlideSettings;
import de.danoeh.antennapod.core.service.playback.PlaybackService;
-import de.danoeh.antennapod.core.feed.util.ImageResourceUtils;
import de.danoeh.antennapod.core.util.playback.Playable;
import de.danoeh.antennapod.core.util.playback.PlaybackController;
import io.reactivex.Maybe;
@@ -34,8 +32,7 @@ import org.greenrobot.eventbus.Subscribe;
import org.greenrobot.eventbus.ThreadMode;
/**
- * Fragment which is supposed to be displayed outside of the MediaplayerActivity
- * if the PlaybackService is running
+ * Fragment which is supposed to be displayed outside of the MediaplayerActivity.
*/
public class ExternalPlayerFragment extends Fragment {
public static final String TAG = "ExternalPlayerFragment";
@@ -43,8 +40,8 @@ public class ExternalPlayerFragment extends Fragment {
private ImageView imgvCover;
private TextView txtvTitle;
private ImageButton butPlay;
- private TextView mFeedName;
- private ProgressBar mProgressBar;
+ private TextView feedName;
+ private ProgressBar progressBar;
private PlaybackController controller;
private Disposable disposable;
@@ -59,8 +56,8 @@ public class ExternalPlayerFragment extends Fragment {
imgvCover = root.findViewById(R.id.imgvCover);
txtvTitle = root.findViewById(R.id.txtvTitle);
butPlay = root.findViewById(R.id.butPlay);
- mFeedName = root.findViewById(R.id.txtvAuthor);
- mProgressBar = root.findViewById(R.id.episodeProgress);
+ feedName = root.findViewById(R.id.txtvAuthor);
+ progressBar = root.findViewById(R.id.episodeProgress);
root.findViewById(R.id.fragmentLayout).setOnClickListener(v -> {
Log.d(TAG, "layoutInfo was clicked");
@@ -114,12 +111,12 @@ public class ExternalPlayerFragment extends Fragment {
@Override
public void onShutdownNotification() {
- playbackDone();
+ ((MainActivity) getActivity()).setPlayerVisible(false);
}
@Override
public void onPlaybackEnd() {
- playbackDone();
+ ((MainActivity) getActivity()).setPlayerVisible(false);
}
};
}
@@ -171,22 +168,6 @@ public class ExternalPlayerFragment extends Fragment {
}
}
- private void playbackDone() {
- clearUi();
- if (controller != null) {
- controller.release();
- }
- controller = setupPlaybackController();
- if (butPlay != null) {
- butPlay.setOnClickListener(v -> {
- if (controller != null) {
- controller.playPause();
- }
- });
- }
- controller.init();
- }
-
private boolean loadMediaInfo() {
Log.d(TAG, "Loading media info");
if (controller == null) {
@@ -209,47 +190,36 @@ public class ExternalPlayerFragment extends Fragment {
.observeOn(AndroidSchedulers.mainThread())
.subscribe(media -> updateUi((Playable) media),
error -> Log.e(TAG, Log.getStackTraceString(error)),
- this::clearUi);
+ () -> ((MainActivity) getActivity()).setPlayerVisible(false));
return true;
}
- private void clearUi() {
- if (txtvTitle == null || mFeedName == null || mProgressBar == null || butPlay == null) {
+ private void updateUi(Playable media) {
+ if (media == null) {
return;
}
- txtvTitle.setText(R.string.no_media_playing_label);
- mFeedName.setText("");
- butPlay.setVisibility(View.GONE);
- mProgressBar.setProgress(0);
- Glide.with(getActivity()).clear(imgvCover);
- ((MainActivity) getActivity()).getBottomSheet().setLocked(true);
- }
-
- private void updateUi(Playable media) {
- if (media != null) {
- txtvTitle.setText(media.getEpisodeTitle());
- mFeedName.setText(media.getFeedTitle());
- onPositionObserverUpdate();
+ ((MainActivity) getActivity()).setPlayerVisible(true);
+ txtvTitle.setText(media.getEpisodeTitle());
+ feedName.setText(media.getFeedTitle());
+ onPositionObserverUpdate();
- Glide.with(getActivity())
- .load(ImageResourceUtils.getImageLocation(media))
- .apply(new RequestOptions()
- .placeholder(R.color.light_gray)
- .error(R.color.light_gray)
- .diskCacheStrategy(ApGlideSettings.AP_DISK_CACHE_STRATEGY)
- .fitCenter()
- .dontAnimate())
- .into(imgvCover);
- if (controller != null && controller.isPlayingVideoLocally()) {
- butPlay.setVisibility(View.GONE);
- ((MainActivity) getActivity()).getBottomSheet().setLocked(true);
- ((MainActivity) getActivity()).getBottomSheet().setState(BottomSheetBehavior.STATE_COLLAPSED);
- } else {
- butPlay.setVisibility(View.VISIBLE);
- ((MainActivity) getActivity()).getBottomSheet().setLocked(false);
- }
+ Glide.with(getActivity())
+ .load(ImageResourceUtils.getImageLocation(media))
+ .apply(new RequestOptions()
+ .placeholder(R.color.light_gray)
+ .error(R.color.light_gray)
+ .diskCacheStrategy(ApGlideSettings.AP_DISK_CACHE_STRATEGY)
+ .fitCenter()
+ .dontAnimate())
+ .into(imgvCover);
+
+ if (controller != null && controller.isPlayingVideoLocally()) {
+ butPlay.setVisibility(View.GONE);
+ ((MainActivity) getActivity()).getBottomSheet().setLocked(true);
+ ((MainActivity) getActivity()).getBottomSheet().setState(BottomSheetBehavior.STATE_COLLAPSED);
} else {
- Log.w(TAG, "loadMediaInfo was called while the media object of playbackService was null!");
+ butPlay.setVisibility(View.VISIBLE);
+ ((MainActivity) getActivity()).getBottomSheet().setLocked(false);
}
}
@@ -264,7 +234,7 @@ public class ExternalPlayerFragment extends Fragment {
|| controller.getDuration() == PlaybackService.INVALID_TIME) {
return;
}
- mProgressBar.setProgress((int)
+ progressBar.setProgress((int)
((double) controller.getPosition() / controller.getDuration() * 100));
}
}