user-accounts: hidpi support for user's icons in tree view
This patch adds UmCellRendererUserImage object which respect scale factor. https://bugzilla.gnome.org/show_bug.cgi?id=742395
This commit is contained in:
parent
5c30530271
commit
dba7bf76c4
4 changed files with 196 additions and 12 deletions
|
@ -58,6 +58,8 @@ libuser_accounts_la_SOURCES = \
|
|||
um-history-dialog.c \
|
||||
um-user-image.h \
|
||||
um-user-image.c \
|
||||
um-cell-renderer-user-image.h \
|
||||
um-cell-renderer-user-image.c \
|
||||
$(BUILT_SOURCES)
|
||||
|
||||
libuser_accounts_la_LIBADD = \
|
||||
|
|
137
panels/user-accounts/um-cell-renderer-user-image.c
Normal file
137
panels/user-accounts/um-cell-renderer-user-image.c
Normal file
|
@ -0,0 +1,137 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program 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 General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* (C) Copyright 2015 Red Hat, Inc.
|
||||
*/
|
||||
|
||||
#include "um-cell-renderer-user-image.h"
|
||||
|
||||
#include <gtk/gtk.h>
|
||||
#include <act/act.h>
|
||||
|
||||
#include "um-utils.h"
|
||||
|
||||
struct _UmCellRendererUserImagePrivate {
|
||||
GtkWidget *parent;
|
||||
ActUser *user;
|
||||
};
|
||||
|
||||
#define UM_CELL_RENDERER_USER_IMAGE_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), UM_TYPE_CELL_RENDERER_USER_IMAGE, UmCellRendererUserImagePrivate))
|
||||
|
||||
enum {
|
||||
PROP_0,
|
||||
PROP_PARENT,
|
||||
PROP_USER
|
||||
};
|
||||
|
||||
G_DEFINE_TYPE_WITH_CODE (UmCellRendererUserImage, um_cell_renderer_user_image, GTK_TYPE_CELL_RENDERER_PIXBUF, G_ADD_PRIVATE (UmCellRendererUserImage));
|
||||
|
||||
static void
|
||||
render_user_image (UmCellRendererUserImage *cell_renderer)
|
||||
{
|
||||
cairo_surface_t *surface;
|
||||
gint scale;
|
||||
|
||||
if (cell_renderer->priv->user != NULL) {
|
||||
scale = gtk_widget_get_scale_factor (cell_renderer->priv->parent);
|
||||
surface = render_user_icon (cell_renderer->priv->user, UM_ICON_STYLE_FRAME | UM_ICON_STYLE_STATUS, 48, scale);
|
||||
g_object_set (GTK_CELL_RENDERER_PIXBUF (cell_renderer), "surface", surface, NULL);
|
||||
cairo_surface_destroy (surface);
|
||||
} else {
|
||||
g_object_set (GTK_CELL_RENDERER_PIXBUF (cell_renderer), "surface", NULL, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
on_scale_factor_changed (GObject *object,
|
||||
GParamSpec *pspec,
|
||||
gpointer data)
|
||||
{
|
||||
UmCellRendererUserImage *cell_renderer = UM_CELL_RENDERER_USER_IMAGE (data);
|
||||
|
||||
render_user_image (cell_renderer);
|
||||
}
|
||||
|
||||
static void
|
||||
um_cell_renderer_user_image_set_property (GObject *object,
|
||||
guint prop_id,
|
||||
const GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
UmCellRendererUserImage *cell_renderer = UM_CELL_RENDERER_USER_IMAGE (object);
|
||||
|
||||
switch (prop_id) {
|
||||
case PROP_PARENT:
|
||||
cell_renderer->priv->parent = g_value_dup_object (value);
|
||||
g_signal_connect (cell_renderer->priv->parent, "notify::scale-factor", G_CALLBACK (on_scale_factor_changed), cell_renderer);
|
||||
break;
|
||||
case PROP_USER:
|
||||
g_clear_object (&cell_renderer->priv->user);
|
||||
cell_renderer->priv->user = g_value_dup_object (value);
|
||||
render_user_image (cell_renderer);
|
||||
break;
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
um_cell_renderer_user_image_finalize (GObject *object)
|
||||
{
|
||||
UmCellRendererUserImage *cell_renderer = UM_CELL_RENDERER_USER_IMAGE (object);
|
||||
|
||||
g_clear_object (&cell_renderer->priv->parent);
|
||||
g_clear_object (&cell_renderer->priv->user);
|
||||
|
||||
G_OBJECT_CLASS (um_cell_renderer_user_image_parent_class)->finalize (object);
|
||||
}
|
||||
|
||||
static void
|
||||
um_cell_renderer_user_image_class_init (UmCellRendererUserImageClass *class)
|
||||
{
|
||||
GObjectClass *object_class;
|
||||
|
||||
object_class = G_OBJECT_CLASS (class);
|
||||
|
||||
object_class->set_property = um_cell_renderer_user_image_set_property;
|
||||
object_class->finalize = um_cell_renderer_user_image_finalize;
|
||||
|
||||
g_object_class_install_property (object_class, PROP_PARENT,
|
||||
g_param_spec_object ("parent",
|
||||
"Parent",
|
||||
"Tree view aprent widget",
|
||||
GTK_TYPE_WIDGET,
|
||||
G_PARAM_WRITABLE | G_PARAM_CONSTRUCT_ONLY));
|
||||
|
||||
g_object_class_install_property (object_class, PROP_USER,
|
||||
g_param_spec_object ("user",
|
||||
"User",
|
||||
"Accountsservice user used to generate image",
|
||||
ACT_TYPE_USER,
|
||||
G_PARAM_WRITABLE));
|
||||
}
|
||||
|
||||
static void
|
||||
um_cell_renderer_user_image_init (UmCellRendererUserImage *cell_renderer)
|
||||
{
|
||||
cell_renderer->priv = UM_CELL_RENDERER_USER_IMAGE_GET_PRIVATE (cell_renderer);
|
||||
}
|
||||
|
||||
GtkCellRenderer *
|
||||
um_cell_renderer_user_image_new (GtkWidget *parent)
|
||||
{
|
||||
return g_object_new (UM_TYPE_CELL_RENDERER_USER_IMAGE, "parent", parent, NULL);
|
||||
}
|
53
panels/user-accounts/um-cell-renderer-user-image.h
Normal file
53
panels/user-accounts/um-cell-renderer-user-image.h
Normal file
|
@ -0,0 +1,53 @@
|
|||
/*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program 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 General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*
|
||||
* (C) Copyright 2015 Red Hat, Inc.
|
||||
*/
|
||||
|
||||
#ifndef _UM_CELL_RENDERER_USER_IMAGE_H
|
||||
#define _UM_CELL_RENDERER_USER_IMAGE_H
|
||||
|
||||
#include <gtk/gtk.h>
|
||||
|
||||
G_BEGIN_DECLS
|
||||
|
||||
#define UM_TYPE_CELL_RENDERER_USER_IMAGE um_cell_renderer_user_image_get_type()
|
||||
|
||||
#define UM_CELL_RENDERER_USER_IMAGE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), UM_TYPE_CELL_RENDERER_USER_IMAGE, UmCellRendererUserImage))
|
||||
#define UM_CELL_RENDERER_USER_IMAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), UM_TYPE_CELL_RENDERER_USER_IMAGE, UmCellRendererUserImageClass))
|
||||
#define UM_IS_CELL_RENDERER_USER_IMAGE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), UM_TYPE_CELL_RENDERER_USER_IMAGE))
|
||||
#define UM_IS_CELL_RENDERER_USER_IMAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), UM_TYPE_CELL_RENDERER_USER_IMAGE))
|
||||
#define UM_CELL_RENDERER_USER_IMAGE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), UM_TYPE_CELL_RENDERER_USER_IMAGE, UmCellRendererUserImageClass))
|
||||
|
||||
typedef struct _UmCellRendererUserImage UmCellRendererUserImage;
|
||||
typedef struct _UmCellRendererUserImageClass UmCellRendererUserImageClass;
|
||||
typedef struct _UmCellRendererUserImagePrivate UmCellRendererUserImagePrivate;
|
||||
|
||||
struct _UmCellRendererUserImage {
|
||||
GtkCellRendererPixbuf parent;
|
||||
|
||||
UmCellRendererUserImagePrivate *priv;
|
||||
};
|
||||
|
||||
struct _UmCellRendererUserImageClass {
|
||||
GtkCellRendererPixbufClass parent_class;
|
||||
};
|
||||
|
||||
GType um_cell_renderer_user_image_get_type (void) G_GNUC_CONST;
|
||||
GtkCellRenderer *um_cell_renderer_user_image_new (GtkWidget *parent);
|
||||
|
||||
G_END_DECLS
|
||||
|
||||
#endif /* _UM_CELL_RENDERER_USER_IMAGE_H */
|
|
@ -48,6 +48,7 @@
|
|||
#include "um-editable-button.h"
|
||||
#include "um-editable-combo.h"
|
||||
#include "um-user-image.h"
|
||||
#include "um-cell-renderer-user-image.h"
|
||||
|
||||
#include "um-account-dialog.h"
|
||||
#include "cc-language-chooser.h"
|
||||
|
@ -97,7 +98,6 @@ get_widget (CcUserPanelPrivate *d, const char *name)
|
|||
|
||||
enum {
|
||||
USER_COL,
|
||||
FACE_COL,
|
||||
NAME_COL,
|
||||
USER_ROW_COL,
|
||||
TITLE_COL,
|
||||
|
@ -192,7 +192,6 @@ user_added (ActUserManager *um, ActUser *user, CcUserPanelPrivate *d)
|
|||
GtkListStore *store;
|
||||
GtkTreeIter iter;
|
||||
GtkTreeIter dummy;
|
||||
cairo_surface_t *surface;
|
||||
gchar *text, *title;
|
||||
GtkTreeSelection *selection;
|
||||
gint sort_key;
|
||||
|
@ -207,7 +206,6 @@ user_added (ActUserManager *um, ActUser *user, CcUserPanelPrivate *d)
|
|||
store = GTK_LIST_STORE (model);
|
||||
selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (widget));
|
||||
|
||||
surface = render_user_icon (user, UM_ICON_STYLE_FRAME | UM_ICON_STYLE_STATUS, 48, 1);
|
||||
text = get_name_col_str (user);
|
||||
|
||||
if (act_user_get_uid (user) == getuid ()) {
|
||||
|
@ -221,14 +219,12 @@ user_added (ActUserManager *um, ActUser *user, CcUserPanelPrivate *d)
|
|||
|
||||
gtk_list_store_set (store, &iter,
|
||||
USER_COL, user,
|
||||
FACE_COL, surface,
|
||||
NAME_COL, text,
|
||||
USER_ROW_COL, TRUE,
|
||||
TITLE_COL, NULL,
|
||||
HEADING_ROW_COL, FALSE,
|
||||
SORT_KEY_COL, sort_key,
|
||||
-1);
|
||||
cairo_surface_destroy (surface);
|
||||
g_free (text);
|
||||
|
||||
if (sort_key == 1 &&
|
||||
|
@ -344,7 +340,6 @@ user_changed (ActUserManager *um, ActUser *user, CcUserPanelPrivate *d)
|
|||
GtkTreeModel *model;
|
||||
GtkTreeIter iter;
|
||||
ActUser *current;
|
||||
cairo_surface_t *surface;
|
||||
char *text;
|
||||
|
||||
tv = (GtkTreeView *)get_widget (d, "list-treeview");
|
||||
|
@ -355,15 +350,12 @@ user_changed (ActUserManager *um, ActUser *user, CcUserPanelPrivate *d)
|
|||
do {
|
||||
gtk_tree_model_get (model, &iter, USER_COL, ¤t, -1);
|
||||
if (current == user) {
|
||||
surface = render_user_icon (user, UM_ICON_STYLE_FRAME | UM_ICON_STYLE_STATUS, 48, 1);
|
||||
text = get_name_col_str (user);
|
||||
|
||||
gtk_list_store_set (GTK_LIST_STORE (model), &iter,
|
||||
USER_COL, user,
|
||||
FACE_COL, surface,
|
||||
NAME_COL, text,
|
||||
-1);
|
||||
cairo_surface_destroy (surface);
|
||||
g_free (text);
|
||||
g_object_unref (current);
|
||||
|
||||
|
@ -1568,7 +1560,6 @@ setup_main_window (CcUserPanel *self)
|
|||
userlist = get_widget (d, "list-treeview");
|
||||
store = gtk_list_store_new (NUM_USER_LIST_COLS,
|
||||
ACT_TYPE_USER,
|
||||
CAIRO_GOBJECT_TYPE_SURFACE,
|
||||
G_TYPE_STRING,
|
||||
G_TYPE_BOOLEAN,
|
||||
G_TYPE_STRING,
|
||||
|
@ -1599,9 +1590,9 @@ setup_main_window (CcUserPanel *self)
|
|||
d->other_iter = NULL;
|
||||
|
||||
column = gtk_tree_view_column_new ();
|
||||
cell = gtk_cell_renderer_pixbuf_new ();
|
||||
cell = um_cell_renderer_user_image_new (userlist);
|
||||
gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (column), cell, FALSE);
|
||||
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (column), cell, "surface", FACE_COL);
|
||||
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (column), cell, "user", USER_COL);
|
||||
gtk_cell_layout_add_attribute (GTK_CELL_LAYOUT (column), cell, "visible", USER_ROW_COL);
|
||||
cell = gtk_cell_renderer_text_new ();
|
||||
g_object_set (cell, "ellipsize", PANGO_ELLIPSIZE_END, NULL);
|
||||
|
@ -1706,6 +1697,7 @@ cc_user_panel_init (CcUserPanel *self)
|
|||
type = cc_editable_entry_get_type ();
|
||||
type = um_editable_combo_get_type ();
|
||||
type = um_user_image_get_type ();
|
||||
type = um_cell_renderer_user_image_get_type ();
|
||||
|
||||
gtk_widget_set_size_request (GTK_WIDGET (self), -1, 350);
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue