clipboard: Change image convenience APIs

Don't use pixbufs anymore, use textures.
This commit is contained in:
Benjamin Otte 2017-12-02 14:38:57 +01:00
parent a34836f35b
commit 18bf0eb61a
3 changed files with 40 additions and 39 deletions

View File

@ -28,6 +28,7 @@
#include "gdkdisplay.h"
#include "gdkintl.h"
#include "gdkpipeiostreamprivate.h"
#include "gdktexture.h"
typedef struct _GdkClipboardPrivate GdkClipboardPrivate;
@ -859,7 +860,7 @@ gdk_clipboard_read_value_finish (GdkClipboard *clipboard,
}
/**
* gdk_clipboard_read_pixbuf_async:
* gdk_clipboard_read_texture_async:
* @clipboard: a #GdkClipboard
* @cancellable: (nullable): optional #GCancellable object, %NULL to ignore.
* @callback: (scope async): callback to call when the request is satisfied
@ -867,14 +868,14 @@ gdk_clipboard_read_value_finish (GdkClipboard *clipboard,
*
* Asynchronously request the @clipboard contents converted to a #GdkPixbuf.
* When the operation is finished @callback will be called. You can then
* call gdk_clipboard_read_pixbuf_finish() to get the result.
* call gdk_clipboard_read_texture_finish() to get the result.
*
* This is a simple wrapper around gdk_clipboard_read_value_async(). Use
* that function or gdk_clipboard_read_async() directly if you need more
* control over the operation.
**/
void
gdk_clipboard_read_pixbuf_async (GdkClipboard *clipboard,
gdk_clipboard_read_texture_async (GdkClipboard *clipboard,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer user_data)
@ -884,8 +885,8 @@ gdk_clipboard_read_pixbuf_async (GdkClipboard *clipboard,
g_return_if_fail (callback != NULL);
gdk_clipboard_read_value_internal (clipboard,
GDK_TYPE_PIXBUF,
gdk_clipboard_read_pixbuf_async,
GDK_TYPE_TEXTURE,
gdk_clipboard_read_texture_async,
G_PRIORITY_DEFAULT,
cancellable,
callback,
@ -893,26 +894,26 @@ gdk_clipboard_read_pixbuf_async (GdkClipboard *clipboard,
}
/**
* gdk_clipboard_read_pixbuf_finish:
* gdk_clipboard_read_texture_finish:
* @clipboard: a #GdkClipboard
* @result: a #GAsyncResult
* @error: a #GError location to store the error occurring, or %NULL to
* ignore.
*
* Finishes an asynchronous clipboard read started with
* gdk_clipboard_read_pixbuf_async().
* gdk_clipboard_read_texture_async().
*
* Returns: (transfer full) (nullable): a new #GdkPixbuf or %NULL on error.
* Returns: (transfer full) (nullable): a new #GdkTexture or %NULL on error.
**/
GdkPixbuf *
gdk_clipboard_read_pixbuf_finish (GdkClipboard *clipboard,
GdkTexture *
gdk_clipboard_read_texture_finish (GdkClipboard *clipboard,
GAsyncResult *res,
GError **error)
{
const GValue *value;
g_return_val_if_fail (g_task_is_valid (res, clipboard), NULL);
g_return_val_if_fail (g_task_get_source_tag (G_TASK (res)) == gdk_clipboard_read_pixbuf_async, NULL);
g_return_val_if_fail (g_task_get_source_tag (G_TASK (res)) == gdk_clipboard_read_texture_async, NULL);
g_return_val_if_fail (error == NULL || *error == NULL, NULL);
value = g_task_propagate_pointer (G_TASK (res), error);
@ -1234,24 +1235,24 @@ gdk_clipboard_set_text (GdkClipboard *clipboard,
}
/**
* gdk_clipboard_set_pixbuf:
* gdk_clipboard_set_texture:
* @clipboard: a #GdkClipboard
* @pixbuf: a #GdkPixbuf to put into the clipboard
* @texture: a #GdkTexture to put into the clipboard
*
* Puts the given @pixbuf into the clipboard.
* Puts the given @texture into the clipboard.
**/
void
gdk_clipboard_set_pixbuf (GdkClipboard *clipboard,
GdkPixbuf *pixbuf)
gdk_clipboard_set_texture (GdkClipboard *clipboard,
GdkTexture *texture)
{
GdkContentProvider *provider;
GValue value = G_VALUE_INIT;
g_return_if_fail (GDK_IS_CLIPBOARD (clipboard));
g_return_if_fail (GDK_IS_PIXBUF (pixbuf));
g_return_if_fail (GDK_IS_TEXTURE (texture));
g_value_init (&value, GDK_TYPE_PIXBUF);
g_value_set_object (&value, pixbuf);
g_value_init (&value, GDK_TYPE_TEXTURE);
g_value_set_object (&value, texture);
provider = gdk_content_provider_new_for_value (&value);
g_value_unset (&value);

View File

@ -25,7 +25,7 @@
#include <gdk/gdkversionmacros.h>
#include <gdk/gdktypes.h>
#include <gdk-pixbuf/gdk-pixbuf.h>
#include <gio/gio.h>
G_BEGIN_DECLS
@ -81,12 +81,12 @@ const GValue * gdk_clipboard_read_value_finish (GdkClipboard *
GAsyncResult *res,
GError **error);
GDK_AVAILABLE_IN_3_94
void gdk_clipboard_read_pixbuf_async (GdkClipboard *clipboard,
void gdk_clipboard_read_texture_async(GdkClipboard *clipboard,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer user_data);
GDK_AVAILABLE_IN_3_94
GdkPixbuf * gdk_clipboard_read_pixbuf_finish(GdkClipboard *clipboard,
GdkTexture * gdk_clipboard_read_texture_finish (GdkClipboard *clipboard,
GAsyncResult *res,
GError **error);
GDK_AVAILABLE_IN_3_94
@ -106,8 +106,8 @@ GDK_AVAILABLE_IN_3_94
void gdk_clipboard_set_text (GdkClipboard *clipboard,
const char *text);
GDK_AVAILABLE_IN_3_94
void gdk_clipboard_set_pixbuf (GdkClipboard *clipboard,
GdkPixbuf *pixbuf);
void gdk_clipboard_set_texture (GdkClipboard *clipboard,
GdkTexture *texture);
G_END_DECLS

View File

@ -33,23 +33,23 @@ clipboard_changed_cb (GdkClipboard *clipboard,
}
static void
pixbuf_loaded_cb (GObject *clipboard,
texture_loaded_cb (GObject *clipboard,
GAsyncResult *res,
gpointer data)
{
GError *error = NULL;
GdkPixbuf *pixbuf;
GdkTexture *texture;
pixbuf = gdk_clipboard_read_pixbuf_finish (GDK_CLIPBOARD (clipboard), res, &error);
if (pixbuf == NULL)
texture = gdk_clipboard_read_texture_finish (GDK_CLIPBOARD (clipboard), res, &error);
if (texture == NULL)
{
g_print ("%s\n", error->message);
g_error_free (error);
return;
}
gtk_image_set_from_pixbuf (data, pixbuf);
g_object_unref (pixbuf);
gtk_image_set_from_texture (data, texture);
g_object_unref (texture);
}
static void
@ -87,9 +87,9 @@ visible_child_changed_cb (GtkWidget *stack,
{
GtkWidget *image = gtk_stack_get_child_by_name (GTK_STACK (stack), "image");
gdk_clipboard_read_pixbuf_async (clipboard,
gdk_clipboard_read_texture_async (clipboard,
NULL,
pixbuf_loaded_cb,
texture_loaded_cb,
image);
}
else if (g_str_equal (visible_child, "text"))