[gnome-music/wip/mschraal/rework-art-widget: 20/26] coverpaintable: Add icon-type property
- From: Marinus Schraal <mschraal src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-music/wip/mschraal/rework-art-widget: 20/26] coverpaintable: Add icon-type property
- Date: Thu, 7 Apr 2022 22:46:09 +0000 (UTC)
commit d8ba070e46c8a2d0b7d5417affde4ef2016201aa
Author: Marinus Schraal <mschraal gnome org>
Date: Sat Apr 2 13:40:13 2022 +0200
coverpaintable: Add icon-type property
gnomemusic/coverpaintable.py | 20 ++++++++++++++++++++
gnomemusic/widgets/artstack.py | 14 +++++---------
2 files changed, 25 insertions(+), 9 deletions(-)
---
diff --git a/gnomemusic/coverpaintable.py b/gnomemusic/coverpaintable.py
index e5a64df45..d6661622f 100644
--- a/gnomemusic/coverpaintable.py
+++ b/gnomemusic/coverpaintable.py
@@ -117,6 +117,26 @@ class CoverPaintable(GObject.GObject, Gdk.Paintable):
self.invalidate_contents()
+ @GObject.Property(type=object, flags=GObject.ParamFlags.READWRITE)
+ def icon_type(self) -> DefaultIconType:
+ """Icon type of the cover
+
+ :returns: The type of the default icon
+ :rtype: DefaultIconType
+ """
+ return self._icon_type
+
+ @icon_type.setter # type: ignore
+ def icon_type(self, value: DefaultIconType) -> None:
+ """Set the cover icon type
+
+ :param DefaultIconType value: The default icon type for the
+ cover
+ """
+ self._icon_type = value
+
+ self.invalidate_contents()
+
def do_get_flags(self) -> Gdk.PaintableFlags:
return Gdk.PaintableFlags.SIZE
diff --git a/gnomemusic/widgets/artstack.py b/gnomemusic/widgets/artstack.py
index 93a6aa89c..116760eff 100644
--- a/gnomemusic/widgets/artstack.py
+++ b/gnomemusic/widgets/artstack.py
@@ -65,6 +65,8 @@ class ArtStack(Gtk.Stack):
self._art_loading_id = 0
self._art_type = DefaultIconType.ALBUM
self._coreobject: Optional[CoreObject] = None
+ self._default_icon = CoverPaintable(
+ size, self, icon_type=self._art_type)
self._size = size
self._texture = None
self._thumbnail_id = 0
@@ -118,9 +120,7 @@ class ArtStack(Gtk.Stack):
"""
self._art_type = value
- default_icon = CoverPaintable(
- self._size, self, icon_type=self._art_type)
- self._cover.props.paintable = default_icon
+ self._default_icon.props.icon_type = self._art_type
@GObject.Property(type=object, default=None)
def coreobject(self) -> Optional[CoreObject]:
@@ -131,9 +131,7 @@ class ArtStack(Gtk.Stack):
if coreobject is self._coreobject:
return
- default_icon = CoverPaintable(
- self._size, self, icon_type=self._art_type)
- self._cover.props.paintable = default_icon
+ self._cover.props.paintable = self._default_icon
if self._thumbnail_id != 0:
self._coreobject.disconnect(self._thumbnail_id)
@@ -155,9 +153,7 @@ class ArtStack(Gtk.Stack):
self._art_loading_id = 0
if thumbnail_uri == "generic":
- default_icon = CoverPaintable(
- self._size, self, icon_type=self._art_type)
- self._cover.props.paintable = default_icon
+ self._cover.props.paintable = self._default_icon
return
self._art_loader = MediaArtLoader()
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]