summaryrefslogtreecommitdiff
path: root/gtk/gtkcssimagepaintable.c
diff options
context:
space:
mode:
authorBenjamin Otte <otte@redhat.com>2018-02-17 20:29:25 +0100
committerBenjamin Otte <otte@redhat.com>2018-03-16 06:04:44 +0100
commit3faa7e04dbc69ec8f5a60f7bcc18c1b701796137 (patch)
treeacce82d2d64898038da8a7f101a1fa3aadb1c6fa /gtk/gtkcssimagepaintable.c
parent4beeb6173b44f4f4d662f79daacffee6569f3136 (diff)
downloadgtk+-3faa7e04dbc69ec8f5a60f7bcc18c1b701796137.tar.gz
cssimage: Add GtkCssImagePaintable
This type can hold any GdkPaintable. Use it to replace GtkCssImageSurface, which used to hold a GdkTexture.
Diffstat (limited to 'gtk/gtkcssimagepaintable.c')
-rw-r--r--gtk/gtkcssimagepaintable.c193
1 files changed, 193 insertions, 0 deletions
diff --git a/gtk/gtkcssimagepaintable.c b/gtk/gtkcssimagepaintable.c
new file mode 100644
index 0000000000..327ca90862
--- /dev/null
+++ b/gtk/gtkcssimagepaintable.c
@@ -0,0 +1,193 @@
+/*
+ * Copyright © 2018 Red Hat Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Authors: Benjamin Otte <otte@gnome.org>
+ */
+
+#include "config.h"
+
+#include "gtkcssimagepaintableprivate.h"
+
+#include "gtkprivate.h"
+
+G_DEFINE_TYPE (GtkCssImagePaintable, gtk_css_image_paintable, GTK_TYPE_CSS_IMAGE)
+
+static inline GdkPaintable *
+get_paintable (GtkCssImagePaintable *paintable)
+{
+ if (paintable->static_paintable)
+ return paintable->static_paintable;
+
+ return paintable->paintable;
+}
+
+static int
+gtk_css_image_paintable_get_width (GtkCssImage *image)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+
+ return gdk_paintable_get_intrinsic_width (get_paintable (paintable));
+}
+
+static int
+gtk_css_image_paintable_get_height (GtkCssImage *image)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+
+ return gdk_paintable_get_intrinsic_height (get_paintable (paintable));
+}
+
+static double
+gtk_css_image_paintable_get_aspect_ratio (GtkCssImage *image)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+
+ return gdk_paintable_get_intrinsic_aspect_ratio (get_paintable (paintable));
+}
+
+static void
+gtk_css_image_paintable_snapshot (GtkCssImage *image,
+ GtkSnapshot *snapshot,
+ double width,
+ double height)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+
+ return gdk_paintable_snapshot (get_paintable (paintable),
+ snapshot,
+ width, height);
+}
+
+static GtkCssImage *
+gtk_css_image_paintable_get_static_image (GtkCssImage *image)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+ GdkPaintable *static_image;
+ GtkCssImage *result;
+
+ static_image = gdk_paintable_get_current_image (paintable->paintable);
+
+ if (paintable->static_paintable == static_image)
+ {
+ result = g_object_ref (image);
+ }
+ else
+ {
+ result = gtk_css_image_paintable_new (paintable->paintable,
+ static_image);
+ }
+
+ g_object_unref (static_image);
+
+ return result;
+}
+
+static GtkCssImage *
+gtk_css_image_paintable_compute (GtkCssImage *image,
+ guint property_id,
+ GtkStyleProvider *provider,
+ GtkCssStyle *style,
+ GtkCssStyle *parent_style)
+{
+ return gtk_css_image_paintable_get_static_image (image);
+}
+
+static gboolean
+gtk_css_image_paintable_equal (GtkCssImage *image1,
+ GtkCssImage *image2)
+{
+ GtkCssImagePaintable *paintable1 = GTK_CSS_IMAGE_PAINTABLE (image1);
+ GtkCssImagePaintable *paintable2 = GTK_CSS_IMAGE_PAINTABLE (image2);
+
+ return paintable1->paintable == paintable2->paintable
+ && paintable1->static_paintable == paintable2->static_paintable;
+}
+
+#define GDK_PAINTABLE_IMMUTABLE (GDK_PAINTABLE_STATIC_SIZE | GDK_PAINTABLE_STATIC_CONTENTS)
+static gboolean
+gtk_css_image_paintable_is_dynamic (GtkCssImage *image)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (image);
+
+ return (gdk_paintable_get_flags (paintable->paintable) & GDK_PAINTABLE_IMMUTABLE) == GDK_PAINTABLE_IMMUTABLE;
+}
+
+static GtkCssImage *
+gtk_css_image_paintable_get_dynamic_image (GtkCssImage *image,
+ gint64 monotonic_time)
+{
+ return gtk_css_image_paintable_get_static_image (image);
+}
+
+static void
+gtk_css_image_paintable_print (GtkCssImage *image,
+ GString *string)
+{
+ g_string_append (string, "none /* FIXME */");
+}
+
+static void
+gtk_css_image_paintable_dispose (GObject *object)
+{
+ GtkCssImagePaintable *paintable = GTK_CSS_IMAGE_PAINTABLE (object);
+
+ g_clear_object (&paintable->paintable);
+ g_clear_object (&paintable->static_paintable);
+
+ G_OBJECT_CLASS (gtk_css_image_paintable_parent_class)->dispose (object);
+}
+
+static void
+gtk_css_image_paintable_class_init (GtkCssImagePaintableClass *klass)
+{
+ GtkCssImageClass *image_class = GTK_CSS_IMAGE_CLASS (klass);
+ GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+ image_class->get_width = gtk_css_image_paintable_get_width;
+ image_class->get_height = gtk_css_image_paintable_get_height;
+ image_class->get_aspect_ratio = gtk_css_image_paintable_get_aspect_ratio;
+ image_class->snapshot = gtk_css_image_paintable_snapshot;
+ image_class->print = gtk_css_image_paintable_print;
+ image_class->compute = gtk_css_image_paintable_compute;
+ image_class->equal = gtk_css_image_paintable_equal;
+ image_class->is_dynamic = gtk_css_image_paintable_is_dynamic;
+ image_class->get_dynamic_image = gtk_css_image_paintable_get_dynamic_image;
+
+ object_class->dispose = gtk_css_image_paintable_dispose;
+}
+
+static void
+gtk_css_image_paintable_init (GtkCssImagePaintable *image_paintable)
+{
+}
+
+GtkCssImage *
+gtk_css_image_paintable_new (GdkPaintable *paintable,
+ GdkPaintable *static_paintable)
+{
+ GtkCssImage *image;
+
+ gtk_internal_return_val_if_fail (GDK_IS_PAINTABLE (paintable), NULL);
+ gtk_internal_return_val_if_fail (static_paintable == NULL || GDK_IS_PAINTABLE (static_paintable), NULL);
+
+ image = g_object_new (GTK_TYPE_CSS_IMAGE_PAINTABLE, NULL);
+
+ GTK_CSS_IMAGE_PAINTABLE (image)->paintable = g_object_ref (paintable);
+ if (static_paintable)
+ GTK_CSS_IMAGE_PAINTABLE (image)->static_paintable = g_object_ref (static_paintable);
+
+ return image;
+}