[gnome-games/simplify-thumbnail: 6/6] game-thumbnail: Unify draw call
- From: Abhinav Singh <abhinavsingh src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-games/simplify-thumbnail: 6/6] game-thumbnail: Unify draw call
- Date: Mon, 8 Oct 2018 22:24:00 +0000 (UTC)
commit 1ac3ea7acb14812c0da1658ac7e28e7c52ea181b
Author: theawless <theawless gmail com>
Date: Tue Oct 2 20:44:27 2018 +0530
game-thumbnail: Unify draw call
This will help create an async flow in a subsequent commmit.
src/ui/game-thumbnail.vala | 63 +++++++++++++++-------------------------------
1 file changed, 20 insertions(+), 43 deletions(-)
---
diff --git a/src/ui/game-thumbnail.vala b/src/ui/game-thumbnail.vala
index 76094e47..9f384354 100644
--- a/src/ui/game-thumbnail.vala
+++ b/src/ui/game-thumbnail.vala
@@ -98,56 +98,26 @@ private class Games.GameThumbnail: Gtk.DrawingArea {
tried_loading_cover = false;
}
- var drawn = false;
+ load_cache (context.width, context.height);
- drawn = draw_cover (context);
-
- if (!drawn)
- drawn = draw_icon (context);
-
- // Draw the default thumbnail if no thumbnail have been drawn
- if (!drawn)
- draw_emblem (context);
-
- return true;
- }
-
- public bool draw_icon (DrawingContext context) {
- var pixbuf = get_icon_cache (context.width, context.height);
- if (pixbuf == null)
- return false;
-
- draw_background (context);
- draw_pixbuf (context, pixbuf);
draw_border (context);
+ if (cover_cache != null)
+ draw_black_background (context);
+ else
+ draw_background (context);
- return true;
- }
-
- public bool draw_cover (DrawingContext context) {
- var pixbuf = get_cover_cache (context.width, context.height);
- if (pixbuf == null)
- return false;
-
- var border_radius = (int) context.style.get_property (Gtk.STYLE_PROPERTY_BORDER_RADIUS,
context.state);
-
- context.cr.set_source_rgb (0, 0, 0);
- rounded_rectangle (context.cr, 0.5, 0.5, context.width - 1, context.height - 1,
border_radius);
- context.cr.fill ();
- draw_pixbuf (context, pixbuf);
- draw_border (context);
+ var thumbnail = cover_cache ?? icon_cache ?? get_emblem (context);
+ if (thumbnail != null)
+ draw_pixbuf (context, thumbnail);
return true;
}
- public void draw_emblem (DrawingContext context) {
- var pixbuf = get_emblem (context);
- if (pixbuf == null)
- return;
-
- draw_background (context);
- draw_pixbuf (context, pixbuf);
- draw_border (context);
+ private void load_cache (int width, int height) {
+ if (cover_cache == null && icon_cache == null)
+ cover_cache = get_cover_cache (width, height);
+ if (cover_cache == null && icon_cache == null)
+ icon_cache = get_icon_cache (width, height);
}
private Gdk.Pixbuf? get_emblem (DrawingContext context) {
@@ -309,6 +279,13 @@ private class Games.GameThumbnail: Gtk.DrawingArea {
return mask;
}
+ private void draw_black_background (DrawingContext context) {
+ var border_radius = (int) context.style.get_property (Gtk.STYLE_PROPERTY_BORDER_RADIUS,
context.state);
+ context.cr.set_source_rgb (0, 0, 0);
+ rounded_rectangle (context.cr, 0.5, 0.5, context.width - 1, context.height - 1,
border_radius);
+ context.cr.fill ();
+ }
+
private void draw_background (DrawingContext context) {
context.style.render_background (context.cr, 0.0, 0.0, context.width, context.height);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]