diff options
-rw-r--r-- | app/src/main/java/de/danoeh/antennapod/view/viewholder/HorizontalItemViewHolder.java | 21 | ||||
-rw-r--r-- | app/src/main/res/layout/horizontal_itemlist_item.xml | 10 |
2 files changed, 26 insertions, 5 deletions
diff --git a/app/src/main/java/de/danoeh/antennapod/view/viewholder/HorizontalItemViewHolder.java b/app/src/main/java/de/danoeh/antennapod/view/viewholder/HorizontalItemViewHolder.java index 42b0cb57c..83d589518 100644 --- a/app/src/main/java/de/danoeh/antennapod/view/viewholder/HorizontalItemViewHolder.java +++ b/app/src/main/java/de/danoeh/antennapod/view/viewholder/HorizontalItemViewHolder.java @@ -1,6 +1,7 @@ package de.danoeh.antennapod.view.viewholder; import android.view.LayoutInflater; +import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.widget.ProgressBar; @@ -31,6 +32,7 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { private final TextView date; private final ProgressBar progressBar; private final CircularProgressBar circularProgressBar; + private final View progressBarReplacementSpacer; private final MainActivity activity; private FeedItem item; @@ -46,6 +48,7 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { secondaryActionIcon = itemView.findViewById(R.id.secondaryActionIcon); circularProgressBar = itemView.findViewById(R.id.circularProgressBar); progressBar = itemView.findViewById(R.id.progressBar); + progressBarReplacementSpacer = itemView.findViewById(R.id.progressBarReplacementSpacer); itemView.setTag(this); } @@ -67,6 +70,7 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { FeedMedia media = item.getMedia(); if (media == null) { circularProgressBar.setPercentage(0, item); + setProgressBar(false, 0); } else { if (PlaybackStatus.isCurrentlyPlaying(media)) { card.setCardBackgroundColor(ThemeUtils.getColorFromAttr(activity, R.attr.card_background_playing)); @@ -74,9 +78,12 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { card.setCardBackgroundColor(ThemeUtils.getColorFromAttr(activity, R.attr.card_background)); } - if (item.getMedia().getDuration() > 0) { - progressBar.setProgress(100 * item.getMedia().getPosition() / item.getMedia().getDuration()); + if (item.getMedia().getDuration() > 0 && item.getMedia().getPosition() > 0) { + setProgressBar(true, 100.0f * item.getMedia().getPosition() / item.getMedia().getDuration()); + } else { + setProgressBar(false, 0); } + if (DownloadService.isDownloadingFile(media.getDownload_url())) { final DownloadRequest downloadRequest = DownloadService.findRequest(media.getDownload_url()); float percent = 0.01f * downloadRequest.getProgressPercent(); @@ -99,7 +106,7 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { date.setText("███"); secondaryActionIcon.setImageDrawable(null); circularProgressBar.setPercentage(0, null); - progressBar.setProgress(50); + setProgressBar(true, 50); } public boolean isCurrentlyPlayingItem() { @@ -107,6 +114,12 @@ public class HorizontalItemViewHolder extends RecyclerView.ViewHolder { } public void notifyPlaybackPositionUpdated(PlaybackPositionEvent event) { - progressBar.setProgress((int) (100.0 * event.getPosition() / event.getDuration())); + setProgressBar(true, 100.0f * event.getPosition() / event.getDuration()); + } + + private void setProgressBar(boolean visible, float progress) { + progressBar.setVisibility(visible ? ViewGroup.VISIBLE : ViewGroup.GONE); + progressBarReplacementSpacer.setVisibility(visible ? View.GONE : ViewGroup.VISIBLE); + progressBar.setProgress(Math.max(5, (int) progress)); // otherwise invisible below the edge radius } } diff --git a/app/src/main/res/layout/horizontal_itemlist_item.xml b/app/src/main/res/layout/horizontal_itemlist_item.xml index b69a3f445..bb45d0ca1 100644 --- a/app/src/main/res/layout/horizontal_itemlist_item.xml +++ b/app/src/main/res/layout/horizontal_itemlist_item.xml @@ -93,6 +93,12 @@ </androidx.cardview.widget.CardView> + <View + android:id="@+id/progressBarReplacementSpacer" + android:layout_width="match_parent" + android:layout_height="4dp" + android:visibility="gone" /> + <TextView android:id="@+id/titleLabel" android:layout_width="128dp" @@ -103,7 +109,8 @@ android:paddingHorizontal="4dp" android:singleLine="false" android:textColor="?android:attr/textColorPrimary" - android:textSize="14sp" /> + android:textSize="14sp" + tools:text="@sample/episodes.json/data/title" /> <TextView android:id="@+id/dateLabel" @@ -114,6 +121,7 @@ android:singleLine="true" android:textAlignment="textStart" android:textSize="14sp" + tools:text="@sample/episodes.json/data/published_at" style="@style/AntennaPod.TextView.ListItemSecondaryTitle" /> </LinearLayout> |