diff options
-rw-r--r-- | core/src/main/java/de/danoeh/antennapod/core/service/PlayerWidgetJobService.java | 21 | ||||
-rw-r--r-- | core/src/main/res/drawable-hdpi/ic_widget_preview.png | bin | 8210 -> 19686 bytes | |||
-rw-r--r-- | core/src/main/res/drawable-xxhdpi/ic_stat_antenna_default.png | bin | 0 -> 1603 bytes | |||
-rw-r--r-- | core/src/main/res/drawable-xxxhdpi/ic_stat_antenna_default.png | bin | 0 -> 2254 bytes | |||
-rw-r--r-- | core/src/main/res/layout/player_widget.xml | 59 |
5 files changed, 59 insertions, 21 deletions
diff --git a/core/src/main/java/de/danoeh/antennapod/core/service/PlayerWidgetJobService.java b/core/src/main/java/de/danoeh/antennapod/core/service/PlayerWidgetJobService.java index 6dab9a561..dbf80cf37 100644 --- a/core/src/main/java/de/danoeh/antennapod/core/service/PlayerWidgetJobService.java +++ b/core/src/main/java/de/danoeh/antennapod/core/service/PlayerWidgetJobService.java @@ -6,6 +6,7 @@ import android.content.ComponentName; import android.content.Context; import android.content.Intent; import android.content.ServiceConnection; +import android.graphics.Bitmap; import android.os.Build; import android.os.IBinder; import android.support.annotation.NonNull; @@ -15,7 +16,10 @@ import android.view.KeyEvent; import android.view.View; import android.widget.RemoteViews; +import com.bumptech.glide.Glide; + import de.danoeh.antennapod.core.R; +import de.danoeh.antennapod.core.glide.ApGlideSettings; import de.danoeh.antennapod.core.receiver.MediaButtonReceiver; import de.danoeh.antennapod.core.receiver.PlayerWidget; import de.danoeh.antennapod.core.service.playback.PlaybackService; @@ -95,6 +99,22 @@ public class PlayerWidgetJobService extends SafeJobIntentService { if (media != null) { views.setOnClickPendingIntent(R.id.layout_left, startMediaplayer); + try { + Bitmap icon = null; + int iconSize = getResources().getDimensionPixelSize( + android.R.dimen.app_icon_size); + icon = Glide.with(PlayerWidgetJobService.this) + .load(media.getImageLocation()) + .asBitmap() + .diskCacheStrategy(ApGlideSettings.AP_DISK_CACHE_STRATEGY) + .centerCrop() + .into(iconSize, iconSize) + .get(); + views.setImageViewBitmap(R.id.imgvCover, icon); + } catch (Throwable tr) { + Log.e(TAG, "Error loading the media icon for the widget", tr); + } + views.setTextViewText(R.id.txtvTitle, media.getEpisodeTitle()); String progressString; @@ -130,6 +150,7 @@ public class PlayerWidgetJobService extends SafeJobIntentService { views.setOnClickPendingIntent(R.id.layout_left, startAppPending); views.setOnClickPendingIntent(R.id.butPlay, startAppPending); views.setViewVisibility(R.id.txtvProgress, View.INVISIBLE); + views.setImageViewResource(R.id.imgvCover, R.drawable.ic_stat_antenna_default); views.setTextViewText(R.id.txtvTitle, this.getString(R.string.no_media_playing_label)); views.setImageViewResource(R.id.butPlay, R.drawable.ic_play_arrow_white_24dp); diff --git a/core/src/main/res/drawable-hdpi/ic_widget_preview.png b/core/src/main/res/drawable-hdpi/ic_widget_preview.png Binary files differindex 85a537154..3c1e08a31 100644 --- a/core/src/main/res/drawable-hdpi/ic_widget_preview.png +++ b/core/src/main/res/drawable-hdpi/ic_widget_preview.png diff --git a/core/src/main/res/drawable-xxhdpi/ic_stat_antenna_default.png b/core/src/main/res/drawable-xxhdpi/ic_stat_antenna_default.png Binary files differnew file mode 100644 index 000000000..7d400b75c --- /dev/null +++ b/core/src/main/res/drawable-xxhdpi/ic_stat_antenna_default.png diff --git a/core/src/main/res/drawable-xxxhdpi/ic_stat_antenna_default.png b/core/src/main/res/drawable-xxxhdpi/ic_stat_antenna_default.png Binary files differnew file mode 100644 index 000000000..87dd56e2c --- /dev/null +++ b/core/src/main/res/drawable-xxxhdpi/ic_stat_antenna_default.png diff --git a/core/src/main/res/layout/player_widget.xml b/core/src/main/res/layout/player_widget.xml index 4c98895a0..cabebc83f 100644 --- a/core/src/main/res/layout/player_widget.xml +++ b/core/src/main/res/layout/player_widget.xml @@ -12,7 +12,7 @@ <ImageButton android:id="@+id/butPlay" android:contentDescription="@string/play_label" - android:layout_width="56dp" + android:layout_width="72dp" android:layout_height="match_parent" android:layout_alignParentRight="true" android:layout_margin="12dp" @@ -26,26 +26,43 @@ android:layout_alignParentLeft="true" android:layout_toLeftOf="@id/butPlay" android:background="@drawable/borderless_button_dark" - android:gravity="center_vertical" - android:orientation="vertical" > - - <TextView - android:id="@+id/txtvTitle" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:layout_margin="8dp" - android:maxLines="1" - android:text="@string/no_media_playing_label" - android:textColor="@color/white" - android:textSize="@dimen/text_size_medium" - android:textStyle="bold" /> - - <TextView - android:id="@+id/txtvProgress" - android:layout_width="wrap_content" - android:layout_height="wrap_content" - android:layout_margin="8dp" - android:textColor="@color/white" /> + android:gravity="fill_horizontal" + android:orientation="horizontal" > + + <ImageView + android:id="@+id/imgvCover" + android:layout_width="72dp" + android:layout_height="match_parent" + android:layout_alignParentLeft="true" + android:layout_toLeftOf="@id/layout_center" + android:layout_margin="12dp" /> + + <LinearLayout + android:id="@+id/layout_center" + android:layout_width="match_parent" + android:layout_height="match_parent" + android:layout_alignParentRight="true" + android:gravity="center_vertical" + android:orientation="vertical" > + + <TextView + android:id="@+id/txtvTitle" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_marginVertical="8dp" + android:maxLines="1" + android:text="@string/no_media_playing_label" + android:textColor="@color/white" + android:textSize="@dimen/text_size_medium" + android:textStyle="bold" /> + + <TextView + android:id="@+id/txtvProgress" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:layout_marginVertical="8dp" + android:textColor="@color/white" /> + </LinearLayout> </LinearLayout> </RelativeLayout> |