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:
Matthias Clasen 2019-10-15 19:04:01 -04:00
parent dd5ee87b5b
commit 7197743938
2 changed files with 137 additions and 21 deletions

View File

@ -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,

View File

@ -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,