summaryrefslogtreecommitdiffstats
path: root/test/control.c
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-08 12:03:14 +0100
committerMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-08 12:03:14 +0100
commit3804fd2355997cc5d2b811ffcbc546a367aa2b48 (patch)
tree68245e0ad10636ba78258a50bdfc9b10fa7bbcd9 /test/control.c
parent923dab046564bdfcd7267281b99462f6d866d311 (diff)
downloadlibuca-3804fd2355997cc5d2b811ffcbc546a367aa2b48.tar.gz
libuca-3804fd2355997cc5d2b811ffcbc546a367aa2b48.tar.bz2
libuca-3804fd2355997cc5d2b811ffcbc546a367aa2b48.tar.xz
libuca-3804fd2355997cc5d2b811ffcbc546a367aa2b48.zip
Add r/w access for each property
Diffstat (limited to 'test/control.c')
-rw-r--r--test/control.c42
1 files changed, 36 insertions, 6 deletions
diff --git a/test/control.c b/test/control.c
index 2c08308..baf6ee2 100644
--- a/test/control.c
+++ b/test/control.c
@@ -15,12 +15,19 @@ struct ThreadData {
struct uca_camera_t *cam;
};
+enum {
+ COLUMN_NAME = 0,
+ COLUMN_VALUE,
+ COLUMN_UNIT,
+ COLUMN_UCA_ID,
+ NUM_COLUMNS
+};
+
static gboolean delete_event(GtkWidget *widget, GdkEvent *event, gpointer data)
{
return FALSE;
}
-/* Another callback */
static void destroy(GtkWidget *widget, gpointer data)
{
struct uca_t *uca = (struct uca_t *) data;
@@ -123,8 +130,7 @@ void find_recursively(GtkTreeStore *store, GtkTreeIter *root, GtkTreeIter *resul
g_free(str);
gtk_tree_store_append(store, &iter, root);
- gtk_tree_store_set(store, &iter, 0, current_token, -1);
- //*result = iter;
+ gtk_tree_store_set(store, &iter, COLUMN_NAME, current_token, -1);
find_recursively(store, &iter, result, tokens, depth+1);
}
@@ -163,9 +169,10 @@ void fill_tree_store(GtkTreeStore *tree_store, struct uca_camera_t *cam)
while (tokens[count++] != NULL);
gtk_tree_store_set(tree_store, &child,
- 0, tokens[count-2],
- 1, value_string,
- 2, uca_unit_map[property->unit],
+ COLUMN_NAME, tokens[count-2],
+ COLUMN_VALUE, value_string,
+ COLUMN_UNIT, uca_unit_map[property->unit],
+ COLUMN_UCA_ID, prop_id,
-1);
g_strfreev(tokens);
@@ -174,6 +181,24 @@ void fill_tree_store(GtkTreeStore *tree_store, struct uca_camera_t *cam)
g_free(value_string);
}
+void value_cell_data_func(GtkTreeViewColumn *column, GtkCellRenderer *cell, GtkTreeModel *model, GtkTreeIter *iter, gpointer data)
+{
+ uint32_t prop_id;
+
+ gtk_tree_model_get(model, iter, COLUMN_UCA_ID, &prop_id, -1);
+ struct uca_property_t *property = uca_get_full_property(prop_id);
+ if (property->access & uca_write) {
+ g_object_set(cell, "mode", GTK_CELL_RENDERER_MODE_EDITABLE, NULL);
+ g_object_set(GTK_CELL_RENDERER_TEXT(cell), "editable", TRUE, NULL);
+ g_object_set(GTK_CELL_RENDERER_TEXT(cell), "style", PANGO_STYLE_NORMAL, NULL);
+ }
+ else {
+ g_object_set(cell, "mode", GTK_CELL_RENDERER_MODE_INERT, NULL);
+ g_object_set(GTK_CELL_RENDERER_TEXT(cell), "editable", FALSE, NULL);
+ g_object_set(GTK_CELL_RENDERER_TEXT(cell), "style", PANGO_STYLE_ITALIC, NULL);
+ }
+}
+
int main(int argc, char *argv[])
{
struct uca_t *uca = uca_init();
@@ -203,9 +228,14 @@ int main(int argc, char *argv[])
GtkWidget *window = GTK_WIDGET(gtk_builder_get_object(builder, "window"));
GtkWidget *image = GTK_WIDGET(gtk_builder_get_object(builder, "image"));
+
GtkTreeStore *tree_store = GTK_TREE_STORE(gtk_builder_get_object(builder, "cameraproperties"));
+ GtkTreeViewColumn *value_column = GTK_TREE_VIEW_COLUMN(gtk_builder_get_object(builder, "valuecolumn"));
+ GtkCellRendererText *value_renderer = GTK_CELL_RENDERER_TEXT(gtk_builder_get_object(builder, "valuecell"));
fill_tree_store(tree_store, cam);
+ gtk_tree_view_column_set_cell_data_func(value_column, GTK_CELL_RENDERER(value_renderer), value_cell_data_func, NULL, NULL);
+
g_signal_connect (window, "delete-event",
G_CALLBACK (delete_event), NULL);