Fixed GtkCellArea to never activate/start editing insensitive cells.
Included extension to tests/testtreeedit to show this is working properly.
This commit is contained in:
@ -3395,6 +3395,9 @@ gtk_cell_area_activate_cell (GtkCellArea *area,
|
|||||||
|
|
||||||
priv = area->priv;
|
priv = area->priv;
|
||||||
|
|
||||||
|
if (!gtk_cell_renderer_get_sensitive (renderer))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
g_object_get (renderer, "mode", &mode, NULL);
|
g_object_get (renderer, "mode", &mode, NULL);
|
||||||
|
|
||||||
if (mode == GTK_CELL_RENDERER_MODE_ACTIVATABLE)
|
if (mode == GTK_CELL_RENDERER_MODE_ACTIVATABLE)
|
||||||
|
|||||||
@ -24,12 +24,14 @@
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
const gchar *string;
|
const gchar *string;
|
||||||
gboolean is_editable;
|
gboolean is_editable;
|
||||||
|
gboolean is_sensitive;
|
||||||
gint progress;
|
gint progress;
|
||||||
} ListEntry;
|
} ListEntry;
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
STRING_COLUMN,
|
STRING_COLUMN,
|
||||||
IS_EDITABLE_COLUMN,
|
IS_EDITABLE_COLUMN,
|
||||||
|
IS_SENSITIVE_COLUMN,
|
||||||
PIXBUF_COLUMN,
|
PIXBUF_COLUMN,
|
||||||
LAST_PIXBUF_COLUMN,
|
LAST_PIXBUF_COLUMN,
|
||||||
PROGRESS_COLUMN,
|
PROGRESS_COLUMN,
|
||||||
@ -38,11 +40,11 @@ enum {
|
|||||||
|
|
||||||
static ListEntry model_strings[] =
|
static ListEntry model_strings[] =
|
||||||
{
|
{
|
||||||
{"A simple string", TRUE, 0 },
|
{"A simple string", TRUE, TRUE, 0 },
|
||||||
{"Another string!", TRUE, 10 },
|
{"Another string!", TRUE, TRUE, 10 },
|
||||||
{"Guess what, a third string. This one can't be edited", FALSE, 47 },
|
{"Guess what, a third string. This one can't be edited", FALSE, TRUE, 47 },
|
||||||
{"And then a fourth string. Neither can this", FALSE, 48 },
|
{"And then a fourth string. Neither can this", FALSE, TRUE, 48 },
|
||||||
{"Multiline\nFun!", TRUE, 75 },
|
{"Multiline\nFun!", TRUE, FALSE, 75 },
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -63,6 +65,7 @@ create_model (void)
|
|||||||
model = gtk_tree_store_new (NUM_COLUMNS,
|
model = gtk_tree_store_new (NUM_COLUMNS,
|
||||||
G_TYPE_STRING,
|
G_TYPE_STRING,
|
||||||
G_TYPE_BOOLEAN,
|
G_TYPE_BOOLEAN,
|
||||||
|
G_TYPE_BOOLEAN,
|
||||||
GDK_TYPE_PIXBUF,
|
GDK_TYPE_PIXBUF,
|
||||||
GDK_TYPE_PIXBUF,
|
GDK_TYPE_PIXBUF,
|
||||||
G_TYPE_INT);
|
G_TYPE_INT);
|
||||||
@ -74,6 +77,7 @@ create_model (void)
|
|||||||
gtk_tree_store_set (model, &iter,
|
gtk_tree_store_set (model, &iter,
|
||||||
STRING_COLUMN, model_strings[i].string,
|
STRING_COLUMN, model_strings[i].string,
|
||||||
IS_EDITABLE_COLUMN, model_strings[i].is_editable,
|
IS_EDITABLE_COLUMN, model_strings[i].is_editable,
|
||||||
|
IS_SENSITIVE_COLUMN, model_strings[i].is_sensitive,
|
||||||
PIXBUF_COLUMN, foo,
|
PIXBUF_COLUMN, foo,
|
||||||
LAST_PIXBUF_COLUMN, bar,
|
LAST_PIXBUF_COLUMN, bar,
|
||||||
PROGRESS_COLUMN, model_strings[i].progress,
|
PROGRESS_COLUMN, model_strings[i].progress,
|
||||||
@ -84,9 +88,9 @@ create_model (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
toggled (GtkCellRendererToggle *cell,
|
editable_toggled (GtkCellRendererToggle *cell,
|
||||||
gchar *path_string,
|
gchar *path_string,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
GtkTreeModel *model = GTK_TREE_MODEL (data);
|
GtkTreeModel *model = GTK_TREE_MODEL (data);
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
@ -102,6 +106,25 @@ toggled (GtkCellRendererToggle *cell,
|
|||||||
gtk_tree_path_free (path);
|
gtk_tree_path_free (path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sensitive_toggled (GtkCellRendererToggle *cell,
|
||||||
|
gchar *path_string,
|
||||||
|
gpointer data)
|
||||||
|
{
|
||||||
|
GtkTreeModel *model = GTK_TREE_MODEL (data);
|
||||||
|
GtkTreeIter iter;
|
||||||
|
GtkTreePath *path = gtk_tree_path_new_from_string (path_string);
|
||||||
|
gboolean value;
|
||||||
|
|
||||||
|
gtk_tree_model_get_iter (model, &iter, path);
|
||||||
|
gtk_tree_model_get (model, &iter, IS_SENSITIVE_COLUMN, &value, -1);
|
||||||
|
|
||||||
|
value = !value;
|
||||||
|
gtk_tree_store_set (GTK_TREE_STORE (model), &iter, IS_SENSITIVE_COLUMN, value, -1);
|
||||||
|
|
||||||
|
gtk_tree_path_free (path);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
edited (GtkCellRendererText *cell,
|
edited (GtkCellRendererText *cell,
|
||||||
gchar *path_string,
|
gchar *path_string,
|
||||||
@ -247,7 +270,9 @@ main (gint argc, gchar **argv)
|
|||||||
renderer = gtk_cell_renderer_pixbuf_new ();
|
renderer = gtk_cell_renderer_pixbuf_new ();
|
||||||
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
||||||
gtk_tree_view_column_set_attributes (column, renderer,
|
gtk_tree_view_column_set_attributes (column, renderer,
|
||||||
"pixbuf", PIXBUF_COLUMN, NULL);
|
"pixbuf", PIXBUF_COLUMN,
|
||||||
|
"sensitive", IS_SENSITIVE_COLUMN,
|
||||||
|
NULL);
|
||||||
callback[0].area = area;
|
callback[0].area = area;
|
||||||
callback[0].renderer = renderer;
|
callback[0].renderer = renderer;
|
||||||
|
|
||||||
@ -256,6 +281,7 @@ main (gint argc, gchar **argv)
|
|||||||
gtk_tree_view_column_set_attributes (column, renderer,
|
gtk_tree_view_column_set_attributes (column, renderer,
|
||||||
"text", STRING_COLUMN,
|
"text", STRING_COLUMN,
|
||||||
"editable", IS_EDITABLE_COLUMN,
|
"editable", IS_EDITABLE_COLUMN,
|
||||||
|
"sensitive", IS_SENSITIVE_COLUMN,
|
||||||
NULL);
|
NULL);
|
||||||
callback[1].area = area;
|
callback[1].area = area;
|
||||||
callback[1].renderer = renderer;
|
callback[1].renderer = renderer;
|
||||||
@ -267,6 +293,7 @@ main (gint argc, gchar **argv)
|
|||||||
gtk_tree_view_column_set_attributes (column, renderer,
|
gtk_tree_view_column_set_attributes (column, renderer,
|
||||||
"text", STRING_COLUMN,
|
"text", STRING_COLUMN,
|
||||||
"editable", IS_EDITABLE_COLUMN,
|
"editable", IS_EDITABLE_COLUMN,
|
||||||
|
"sensitive", IS_SENSITIVE_COLUMN,
|
||||||
NULL);
|
NULL);
|
||||||
callback[2].area = area;
|
callback[2].area = area;
|
||||||
callback[2].renderer = renderer;
|
callback[2].renderer = renderer;
|
||||||
@ -279,7 +306,9 @@ main (gint argc, gchar **argv)
|
|||||||
NULL);
|
NULL);
|
||||||
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
gtk_tree_view_column_pack_start (column, renderer, FALSE);
|
||||||
gtk_tree_view_column_set_attributes (column, renderer,
|
gtk_tree_view_column_set_attributes (column, renderer,
|
||||||
"pixbuf", LAST_PIXBUF_COLUMN, NULL);
|
"pixbuf", LAST_PIXBUF_COLUMN,
|
||||||
|
"sensitive", IS_SENSITIVE_COLUMN,
|
||||||
|
NULL);
|
||||||
callback[3].area = area;
|
callback[3].area = area;
|
||||||
callback[3].renderer = renderer;
|
callback[3].renderer = renderer;
|
||||||
|
|
||||||
@ -287,7 +316,7 @@ main (gint argc, gchar **argv)
|
|||||||
|
|
||||||
renderer = gtk_cell_renderer_toggle_new ();
|
renderer = gtk_cell_renderer_toggle_new ();
|
||||||
g_signal_connect (renderer, "toggled",
|
g_signal_connect (renderer, "toggled",
|
||||||
G_CALLBACK (toggled), tree_model);
|
G_CALLBACK (editable_toggled), tree_model);
|
||||||
|
|
||||||
g_object_set (renderer,
|
g_object_set (renderer,
|
||||||
"xalign", 0.0,
|
"xalign", 0.0,
|
||||||
@ -298,6 +327,19 @@ main (gint argc, gchar **argv)
|
|||||||
"active", IS_EDITABLE_COLUMN,
|
"active", IS_EDITABLE_COLUMN,
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
|
renderer = gtk_cell_renderer_toggle_new ();
|
||||||
|
g_signal_connect (renderer, "toggled",
|
||||||
|
G_CALLBACK (sensitive_toggled), tree_model);
|
||||||
|
|
||||||
|
g_object_set (renderer,
|
||||||
|
"xalign", 0.0,
|
||||||
|
NULL);
|
||||||
|
gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree_view),
|
||||||
|
-1, "Sensitive",
|
||||||
|
renderer,
|
||||||
|
"active", IS_SENSITIVE_COLUMN,
|
||||||
|
NULL);
|
||||||
|
|
||||||
renderer = gtk_cell_renderer_progress_new ();
|
renderer = gtk_cell_renderer_progress_new ();
|
||||||
gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree_view),
|
gtk_tree_view_insert_column_with_attributes (GTK_TREE_VIEW (tree_view),
|
||||||
-1, "Progress",
|
-1, "Progress",
|
||||||
|
|||||||
Reference in New Issue
Block a user