mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-08 03:30:17 +00:00
pixbuf utils: Preserve format information
When we are loading themed icons, we know if we deal with an svg or png file, so it is entirely unnecessarily to have gdk-pixbuf use g_content_type guess to rediscover that information. Change the pixbuf utils apis we have to allow passing format information down to where we can use it when creating the pixbuf loader.
This commit is contained in:
parent
dd5ee87b5b
commit
7197743938
@ -22,12 +22,34 @@
|
|||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GdkPixbuf *_gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
GdkPixbuf *_gdk_pixbuf_new_from_stream (GInputStream *stream,
|
||||||
gdouble scale,
|
const char *format,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GError **error);
|
GError **error);
|
||||||
GdkPixbuf *_gdk_pixbuf_new_from_resource_scaled (const gchar *resource_path,
|
GdkPixbuf *_gdk_pixbuf_new_from_stream_at_scale (GInputStream *stream,
|
||||||
gdouble scale,
|
const char *format,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
gboolean aspect,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error);
|
||||||
|
GdkPixbuf *_gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
||||||
|
const char *format,
|
||||||
|
double scale,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error);
|
||||||
|
GdkPixbuf *_gdk_pixbuf_new_from_resource (const char *resource_path,
|
||||||
|
const char *format,
|
||||||
|
GError **error);
|
||||||
|
GdkPixbuf *_gdk_pixbuf_new_from_resource_at_scale (const char *resource_path,
|
||||||
|
const char *format,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
gboolean preserve_aspect,
|
||||||
|
GError **error);
|
||||||
|
GdkPixbuf *_gdk_pixbuf_new_from_resource_scaled (const char *resource_path,
|
||||||
|
const char *format,
|
||||||
|
double scale,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
|
||||||
GdkPixbuf *gtk_make_symbolic_pixbuf_from_data (const char *data,
|
GdkPixbuf *gtk_make_symbolic_pixbuf_from_data (const char *data,
|
||||||
|
@ -90,6 +90,7 @@ size_prepared_cb (GdkPixbufLoader *loader,
|
|||||||
*/
|
*/
|
||||||
GdkPixbuf *
|
GdkPixbuf *
|
||||||
_gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
_gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
||||||
|
const char *format,
|
||||||
gdouble scale,
|
gdouble scale,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
GError **error)
|
GError **error)
|
||||||
@ -97,8 +98,16 @@ _gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
|||||||
GdkPixbufLoader *loader;
|
GdkPixbufLoader *loader;
|
||||||
GdkPixbuf *pixbuf;
|
GdkPixbuf *pixbuf;
|
||||||
|
|
||||||
|
if (format)
|
||||||
|
{
|
||||||
|
loader = gdk_pixbuf_loader_new_with_type (format, error);
|
||||||
|
if (!loader)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
loader = gdk_pixbuf_loader_new ();
|
loader = gdk_pixbuf_loader_new ();
|
||||||
|
|
||||||
|
if (scale != 0)
|
||||||
g_signal_connect (loader, "size-prepared",
|
g_signal_connect (loader, "size-prepared",
|
||||||
G_CALLBACK (size_prepared_cb), &scale);
|
G_CALLBACK (size_prepared_cb), &scale);
|
||||||
|
|
||||||
@ -109,13 +118,68 @@ _gdk_pixbuf_new_from_stream_scaled (GInputStream *stream,
|
|||||||
return pixbuf;
|
return pixbuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
size_prepared_cb2 (GdkPixbufLoader *loader,
|
||||||
|
gint width,
|
||||||
|
gint height,
|
||||||
|
gpointer data)
|
||||||
|
{
|
||||||
|
int *scales = data;
|
||||||
|
|
||||||
|
gdk_pixbuf_loader_set_size (loader, scales[0], scales[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
GdkPixbuf *
|
||||||
|
_gdk_pixbuf_new_from_stream_at_scale (GInputStream *stream,
|
||||||
|
const char *format,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
gboolean aspect,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
GdkPixbufLoader *loader;
|
||||||
|
GdkPixbuf *pixbuf;
|
||||||
|
int scales[2];
|
||||||
|
|
||||||
|
if (format)
|
||||||
|
{
|
||||||
|
loader = gdk_pixbuf_loader_new_with_type (format, error);
|
||||||
|
if (!loader)
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
loader = gdk_pixbuf_loader_new ();
|
||||||
|
|
||||||
|
scales[0] = width;
|
||||||
|
scales[1] = height;
|
||||||
|
g_signal_connect (loader, "size-prepared",
|
||||||
|
G_CALLBACK (size_prepared_cb2), scales);
|
||||||
|
|
||||||
|
pixbuf = load_from_stream (loader, stream, cancellable, error);
|
||||||
|
|
||||||
|
g_object_unref (loader);
|
||||||
|
|
||||||
|
return pixbuf;
|
||||||
|
}
|
||||||
|
|
||||||
|
GdkPixbuf *
|
||||||
|
_gdk_pixbuf_new_from_stream (GInputStream *stream,
|
||||||
|
const char *format,
|
||||||
|
GCancellable *cancellable,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
return _gdk_pixbuf_new_from_stream_scaled (stream, format, 0, cancellable, error);
|
||||||
|
}
|
||||||
|
|
||||||
/* Like gdk_pixbuf_new_from_resource_at_scale, but
|
/* Like gdk_pixbuf_new_from_resource_at_scale, but
|
||||||
* load the image at its original size times the
|
* load the image at its original size times the
|
||||||
* given scale.
|
* given scale.
|
||||||
*/
|
*/
|
||||||
GdkPixbuf *
|
GdkPixbuf *
|
||||||
_gdk_pixbuf_new_from_resource_scaled (const gchar *resource_path,
|
_gdk_pixbuf_new_from_resource_scaled (const char *resource_path,
|
||||||
gdouble scale,
|
const char *format,
|
||||||
|
double scale,
|
||||||
GError **error)
|
GError **error)
|
||||||
{
|
{
|
||||||
GInputStream *stream;
|
GInputStream *stream;
|
||||||
@ -125,12 +189,42 @@ _gdk_pixbuf_new_from_resource_scaled (const gchar *resource_path,
|
|||||||
if (stream == NULL)
|
if (stream == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
pixbuf = _gdk_pixbuf_new_from_stream_scaled (stream, scale, NULL, error);
|
pixbuf = _gdk_pixbuf_new_from_stream_scaled (stream, format, scale, NULL, error);
|
||||||
g_object_unref (stream);
|
g_object_unref (stream);
|
||||||
|
|
||||||
return pixbuf;
|
return pixbuf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GdkPixbuf *
|
||||||
|
_gdk_pixbuf_new_from_resource (const char *resource_path,
|
||||||
|
const char *format,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
return _gdk_pixbuf_new_from_resource_scaled (resource_path, format, 0, error);
|
||||||
|
}
|
||||||
|
|
||||||
|
GdkPixbuf *
|
||||||
|
_gdk_pixbuf_new_from_resource_at_scale (const char *resource_path,
|
||||||
|
const char *format,
|
||||||
|
int width,
|
||||||
|
int height,
|
||||||
|
gboolean preserve_aspect,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
GInputStream *stream;
|
||||||
|
GdkPixbuf *pixbuf;
|
||||||
|
|
||||||
|
stream = g_resources_open_stream (resource_path, 0, error);
|
||||||
|
if (stream == NULL)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
pixbuf = _gdk_pixbuf_new_from_stream_at_scale (stream, format, width, height, preserve_aspect, NULL, error);
|
||||||
|
g_object_unref (stream);
|
||||||
|
|
||||||
|
return pixbuf;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static GdkPixbuf *
|
static GdkPixbuf *
|
||||||
load_symbolic_svg (const char *escaped_file_data,
|
load_symbolic_svg (const char *escaped_file_data,
|
||||||
int width,
|
int width,
|
||||||
|
Loading…
Reference in New Issue
Block a user