mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-12 13:30:19 +00:00
Merge branch 'inspector-trees' into 'main'
inspector: Don't use treeviews in the recorder See merge request GNOME/gtk!5080
This commit is contained in:
commit
aae82d7992
@ -25,11 +25,11 @@
|
||||
#include <gtk/gtkeventcontroller.h>
|
||||
#include <gtk/gtkfilechooserdialog.h>
|
||||
#include <gtk/gtkinscription.h>
|
||||
#include <gtk/gtkimage.h>
|
||||
#include <gtk/gtklabel.h>
|
||||
#include <gtk/gtklistbox.h>
|
||||
#include <gtk/gtklistitem.h>
|
||||
#include <gtk/gtklistview.h>
|
||||
#include <gtk/gtkliststore.h>
|
||||
#include <gtk/gtkmessagedialog.h>
|
||||
#include <gtk/gtkpicture.h>
|
||||
#include <gtk/gtkpopover.h>
|
||||
@ -39,8 +39,10 @@
|
||||
#include <gtk/gtktreeexpander.h>
|
||||
#include <gtk/gtktreelistmodel.h>
|
||||
#include <gtk/gtktreemodel.h>
|
||||
#include <gtk/gtktreeview.h>
|
||||
#include <gtk/gtkstack.h>
|
||||
#include <gtk/gtknoselection.h>
|
||||
#include <gtk/gtkcolumnview.h>
|
||||
#include <gtk/gtkcolumnviewcolumn.h>
|
||||
#include <gsk/gskrendererprivate.h>
|
||||
#include <gsk/gskrendernodeprivate.h>
|
||||
#include <gsk/gskroundedrectprivate.h>
|
||||
@ -58,6 +60,124 @@
|
||||
#include "eventrecording.h"
|
||||
#include "recorderrow.h"
|
||||
|
||||
/* {{{ ObjectProperty object */
|
||||
|
||||
typedef struct _ObjectProperty RenderNodeProperty;
|
||||
|
||||
G_DECLARE_FINAL_TYPE (ObjectProperty, object_property, OBJECT, PROPERTY, GObject);
|
||||
|
||||
struct _ObjectProperty
|
||||
{
|
||||
GObject parent;
|
||||
|
||||
char *name;
|
||||
char *value;
|
||||
GdkTexture *texture;
|
||||
};
|
||||
|
||||
enum {
|
||||
OBJECT_PROPERTY_PROP_NAME = 1,
|
||||
OBJECT_PROPERTY_PROP_VALUE,
|
||||
OBJECT_PROPERTY_PROP_TEXTURE,
|
||||
OBJECT_PROPERTY_NUM_PROPERTIES
|
||||
};
|
||||
|
||||
G_DEFINE_TYPE (ObjectProperty, object_property, G_TYPE_OBJECT);
|
||||
|
||||
static void
|
||||
object_property_init (ObjectProperty *self)
|
||||
{
|
||||
}
|
||||
|
||||
static void
|
||||
object_property_finalize (GObject *object)
|
||||
{
|
||||
ObjectProperty *self = OBJECT_PROPERTY (object);
|
||||
|
||||
g_free (self->name);
|
||||
g_free (self->value);
|
||||
g_object_unref (self->texture);
|
||||
|
||||
G_OBJECT_CLASS (object_property_parent_class)->finalize (object);
|
||||
}
|
||||
|
||||
static void
|
||||
object_property_get_property (GObject *object,
|
||||
guint property_id,
|
||||
GValue *value,
|
||||
GParamSpec *pspec)
|
||||
{
|
||||
ObjectProperty *self = OBJECT_PROPERTY (object);
|
||||
|
||||
switch (property_id)
|
||||
{
|
||||
case OBJECT_PROPERTY_PROP_NAME:
|
||||
g_value_set_string (value, self->name);
|
||||
break;
|
||||
|
||||
case OBJECT_PROPERTY_PROP_VALUE:
|
||||
g_value_set_string (value, self->value);
|
||||
break;
|
||||
|
||||
case OBJECT_PROPERTY_PROP_TEXTURE:
|
||||
g_value_set_object (value, self->value);
|
||||
break;
|
||||
|
||||
default:
|
||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
object_property_class_init (ObjectPropertyClass *class)
|
||||
{
|
||||
GObjectClass *object_class = G_OBJECT_CLASS (class);
|
||||
GParamSpec *pspec;
|
||||
|
||||
object_class->finalize = object_property_finalize;
|
||||
object_class->get_property = object_property_get_property;
|
||||
|
||||
pspec = g_param_spec_string ("name", NULL, NULL,
|
||||
NULL,
|
||||
G_PARAM_READABLE |
|
||||
G_PARAM_STATIC_STRINGS);
|
||||
|
||||
g_object_class_install_property (object_class, OBJECT_PROPERTY_PROP_NAME, pspec);
|
||||
|
||||
pspec = g_param_spec_string ("value", NULL, NULL,
|
||||
NULL,
|
||||
G_PARAM_READABLE |
|
||||
G_PARAM_STATIC_STRINGS);
|
||||
|
||||
g_object_class_install_property (object_class, OBJECT_PROPERTY_PROP_VALUE, pspec);
|
||||
|
||||
pspec = g_param_spec_object ("texture", NULL, NULL,
|
||||
GDK_TYPE_TEXTURE,
|
||||
G_PARAM_READABLE |
|
||||
G_PARAM_STATIC_STRINGS);
|
||||
|
||||
g_object_class_install_property (object_class, OBJECT_PROPERTY_PROP_TEXTURE, pspec);
|
||||
}
|
||||
|
||||
static ObjectProperty *
|
||||
object_property_new (const char *name,
|
||||
const char *value,
|
||||
GdkTexture *texture)
|
||||
{
|
||||
ObjectProperty *self;
|
||||
|
||||
self = g_object_new (object_property_get_type (), NULL);
|
||||
|
||||
self->name = g_strdup (name);
|
||||
self->value = g_strdup (value);
|
||||
g_set_object (&self->texture, texture);
|
||||
|
||||
return self;
|
||||
}
|
||||
|
||||
/* }}} */
|
||||
|
||||
struct _GtkInspectorRecorder
|
||||
{
|
||||
GtkWidget parent;
|
||||
@ -75,8 +195,8 @@ struct _GtkInspectorRecorder
|
||||
GtkWidget *render_node_clip_button;
|
||||
GtkWidget *node_property_tree;
|
||||
GtkWidget *recording_data_stack;
|
||||
GtkTreeModel *render_node_properties;
|
||||
GtkTreeModel *event_properties;
|
||||
GListStore *render_node_properties;
|
||||
GListStore *event_properties;
|
||||
GtkWidget *event_property_tree;
|
||||
GtkWidget *event_view;
|
||||
|
||||
@ -466,6 +586,72 @@ show_render_node (GtkInspectorRecorder *recorder,
|
||||
g_object_unref (paintable);
|
||||
}
|
||||
|
||||
static void
|
||||
setup_label (GtkSignalListItemFactory *factory,
|
||||
GtkListItem *list_item)
|
||||
{
|
||||
GtkWidget *label;
|
||||
|
||||
label = gtk_label_new (NULL);
|
||||
gtk_label_set_xalign (GTK_LABEL (label), 0.);
|
||||
gtk_widget_set_valign (label, GTK_ALIGN_START);
|
||||
gtk_list_item_set_child (list_item, label);
|
||||
}
|
||||
|
||||
static void
|
||||
bind_property_name (GtkSignalListItemFactory *factory,
|
||||
GtkListItem *list_item)
|
||||
{
|
||||
GtkWidget *label;
|
||||
ObjectProperty *property;
|
||||
|
||||
property = gtk_list_item_get_item (list_item);
|
||||
label = gtk_list_item_get_child (list_item);
|
||||
gtk_label_set_text (GTK_LABEL (label), property->name);
|
||||
}
|
||||
|
||||
static void
|
||||
setup_value_widgets (GtkSignalListItemFactory *factory,
|
||||
GtkListItem *list_item)
|
||||
{
|
||||
GtkWidget *label;
|
||||
GtkWidget *picture;
|
||||
GtkWidget *box;
|
||||
|
||||
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 10);
|
||||
label = gtk_label_new (NULL);
|
||||
gtk_label_set_xalign (GTK_LABEL (label), 0.);
|
||||
gtk_box_append (GTK_BOX (box), label);
|
||||
picture = gtk_picture_new ();
|
||||
gtk_picture_set_can_shrink (GTK_PICTURE (picture), TRUE);
|
||||
gtk_picture_set_content_fit (GTK_PICTURE (picture), GTK_CONTENT_FIT_CONTAIN);
|
||||
gtk_box_append (GTK_BOX (box), picture);
|
||||
gtk_list_item_set_child (list_item, box);
|
||||
}
|
||||
|
||||
static void
|
||||
bind_value_widgets (GtkSignalListItemFactory *factory,
|
||||
GtkListItem *list_item)
|
||||
{
|
||||
GtkWidget *box, *label, *picture;
|
||||
ObjectProperty *property;
|
||||
|
||||
property = gtk_list_item_get_item (list_item);
|
||||
box = gtk_list_item_get_child (list_item);
|
||||
label = gtk_widget_get_first_child (box);
|
||||
picture = gtk_widget_get_next_sibling (label);
|
||||
gtk_label_set_text (GTK_LABEL (label), property->value);
|
||||
if (property->texture)
|
||||
{
|
||||
gtk_widget_show (picture);
|
||||
gtk_picture_set_paintable (GTK_PICTURE (picture), GDK_PAINTABLE (property->texture));
|
||||
}
|
||||
else
|
||||
{
|
||||
gtk_widget_hide (picture);
|
||||
}
|
||||
}
|
||||
|
||||
static GskRenderNode *
|
||||
make_dot (double x, double y)
|
||||
{
|
||||
@ -505,8 +691,8 @@ show_event (GtkInspectorRecorder *recorder,
|
||||
gsk_render_node_unref (temp);
|
||||
}
|
||||
|
||||
static void populate_event_properties (GtkListStore *store,
|
||||
GdkEvent *event);
|
||||
static void populate_event_properties (GListStore *store,
|
||||
GdkEvent *event);
|
||||
|
||||
static void
|
||||
recording_selected (GtkSingleSelection *selection,
|
||||
@ -556,7 +742,7 @@ recording_selected (GtkSingleSelection *selection,
|
||||
}
|
||||
}
|
||||
|
||||
populate_event_properties (GTK_LIST_STORE (recorder->event_properties), event);
|
||||
populate_event_properties (recorder->event_properties, event);
|
||||
|
||||
if (recorder->highlight_sequences)
|
||||
selected_sequence = gdk_event_get_event_sequence (event);
|
||||
@ -641,20 +827,15 @@ get_linear_gradient_texture (gsize n_stops, const GskColorStop *stops)
|
||||
}
|
||||
|
||||
static void
|
||||
add_text_row (GtkListStore *store,
|
||||
const char *name,
|
||||
const char *text)
|
||||
add_text_row (GListStore *store,
|
||||
const char *name,
|
||||
const char *text)
|
||||
{
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, name,
|
||||
1, text,
|
||||
2, FALSE,
|
||||
3, NULL,
|
||||
-1);
|
||||
g_list_store_append (store, object_property_new (name, text, NULL));
|
||||
}
|
||||
|
||||
static void
|
||||
add_color_row (GtkListStore *store,
|
||||
add_color_row (GListStore *store,
|
||||
const char *name,
|
||||
const GdkRGBA *color)
|
||||
{
|
||||
@ -663,20 +844,15 @@ add_color_row (GtkListStore *store,
|
||||
|
||||
text = gdk_rgba_to_string (color);
|
||||
texture = get_color_texture (color);
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, name,
|
||||
1, text,
|
||||
2, TRUE,
|
||||
3, texture,
|
||||
-1);
|
||||
g_list_store_append (store, object_property_new (name, text, texture));
|
||||
g_free (text);
|
||||
g_object_unref (texture);
|
||||
}
|
||||
|
||||
static void
|
||||
add_int_row (GtkListStore *store,
|
||||
const char *name,
|
||||
int value)
|
||||
add_int_row (GListStore *store,
|
||||
const char *name,
|
||||
int value)
|
||||
{
|
||||
char *text = g_strdup_printf ("%d", value);
|
||||
add_text_row (store, name, text);
|
||||
@ -684,9 +860,9 @@ add_int_row (GtkListStore *store,
|
||||
}
|
||||
|
||||
static void
|
||||
add_uint_row (GtkListStore *store,
|
||||
const char *name,
|
||||
guint value)
|
||||
add_uint_row (GListStore *store,
|
||||
const char *name,
|
||||
guint value)
|
||||
{
|
||||
char *text = g_strdup_printf ("%u", value);
|
||||
add_text_row (store, name, text);
|
||||
@ -694,17 +870,17 @@ add_uint_row (GtkListStore *store,
|
||||
}
|
||||
|
||||
static void
|
||||
add_boolean_row (GtkListStore *store,
|
||||
const char *name,
|
||||
gboolean value)
|
||||
add_boolean_row (GListStore *store,
|
||||
const char *name,
|
||||
gboolean value)
|
||||
{
|
||||
add_text_row (store, name, value ? "TRUE" : "FALSE");
|
||||
}
|
||||
|
||||
static void
|
||||
add_float_row (GtkListStore *store,
|
||||
const char *name,
|
||||
float value)
|
||||
add_float_row (GListStore *store,
|
||||
const char *name,
|
||||
float value)
|
||||
{
|
||||
char *text = g_strdup_printf ("%.2f", value);
|
||||
add_text_row (store, name, text);
|
||||
@ -712,13 +888,13 @@ add_float_row (GtkListStore *store,
|
||||
}
|
||||
|
||||
static void
|
||||
populate_render_node_properties (GtkListStore *store,
|
||||
populate_render_node_properties (GListStore *store,
|
||||
GskRenderNode *node)
|
||||
{
|
||||
graphene_rect_t bounds;
|
||||
char *tmp;
|
||||
|
||||
gtk_list_store_clear (store);
|
||||
g_list_store_remove_all (store);
|
||||
|
||||
gsk_render_node_get_bounds (node, &bounds);
|
||||
|
||||
@ -739,7 +915,6 @@ populate_render_node_properties (GtkListStore *store,
|
||||
GdkTexture *texture;
|
||||
cairo_surface_t *drawn_surface;
|
||||
cairo_t *cr;
|
||||
gboolean show_inline;
|
||||
|
||||
drawn_surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32,
|
||||
ceilf (node->bounds.size.width),
|
||||
@ -755,32 +930,14 @@ populate_render_node_properties (GtkListStore *store,
|
||||
texture = gdk_texture_new_for_surface (drawn_surface);
|
||||
cairo_surface_destroy (drawn_surface);
|
||||
|
||||
show_inline = gdk_texture_get_height (texture) <= 40 &&
|
||||
gdk_texture_get_width (texture) <= 100;
|
||||
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, "Surface",
|
||||
1, show_inline ? "" : "Yes (click to show)",
|
||||
2, show_inline,
|
||||
3, texture,
|
||||
-1);
|
||||
g_list_store_append (store, object_property_new ("Surface", "", texture));
|
||||
}
|
||||
break;
|
||||
|
||||
case GSK_TEXTURE_NODE:
|
||||
{
|
||||
GdkTexture *texture = g_object_ref (gsk_texture_node_get_texture (node));
|
||||
gboolean show_inline;
|
||||
|
||||
show_inline = gdk_texture_get_height (texture) <= 40 &&
|
||||
gdk_texture_get_width (texture) <= 100;
|
||||
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, "Texture",
|
||||
1, show_inline ? "" : "Yes (click to show)",
|
||||
2, show_inline,
|
||||
3, texture,
|
||||
-1);
|
||||
g_list_store_append (store, object_property_new ("Texture", "", texture));
|
||||
}
|
||||
break;
|
||||
|
||||
@ -812,14 +969,10 @@ populate_render_node_properties (GtkListStore *store,
|
||||
}
|
||||
|
||||
texture = get_linear_gradient_texture (n_stops, stops);
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, "Color Stops",
|
||||
1, s->str,
|
||||
2, TRUE,
|
||||
3, texture,
|
||||
-1);
|
||||
g_string_free (s, TRUE);
|
||||
g_list_store_append (store, object_property_new ("Color Stops", s->str, texture));
|
||||
g_object_unref (texture);
|
||||
|
||||
g_string_free (s, TRUE);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -858,14 +1011,10 @@ populate_render_node_properties (GtkListStore *store,
|
||||
}
|
||||
|
||||
texture = get_linear_gradient_texture (n_stops, stops);
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, "Color Stops",
|
||||
1, s->str,
|
||||
2, TRUE,
|
||||
3, texture,
|
||||
-1);
|
||||
g_string_free (s, TRUE);
|
||||
g_list_store_append (store, object_property_new ("Color Stops", s->str, texture));
|
||||
g_object_unref (texture);
|
||||
|
||||
g_string_free (s, TRUE);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -896,14 +1045,10 @@ populate_render_node_properties (GtkListStore *store,
|
||||
}
|
||||
|
||||
texture = get_linear_gradient_texture (n_stops, stops);
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, "Color Stops",
|
||||
1, s->str,
|
||||
2, TRUE,
|
||||
3, texture,
|
||||
-1);
|
||||
g_string_free (s, TRUE);
|
||||
g_list_store_append (store, object_property_new ("Color Stops", s->str, texture));
|
||||
g_object_unref (texture);
|
||||
|
||||
g_string_free (s, TRUE);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -946,18 +1091,14 @@ populate_render_node_properties (GtkListStore *store,
|
||||
GdkTexture *texture;
|
||||
char *text;
|
||||
|
||||
texture = get_color_texture (&colors[i]);
|
||||
text = gdk_rgba_to_string (&colors[i]);
|
||||
tmp = g_strdup_printf ("%.2f, %s", widths[i], text);
|
||||
gtk_list_store_insert_with_values (store, NULL, -1,
|
||||
0, name[i],
|
||||
1, tmp,
|
||||
2, TRUE,
|
||||
3, texture,
|
||||
-1);
|
||||
texture = get_color_texture (&colors[i]);
|
||||
g_list_store_append (store, object_property_new (name[i], tmp, texture));
|
||||
g_object_unref (texture);
|
||||
|
||||
g_free (text);
|
||||
g_free (tmp);
|
||||
g_object_unref (texture);
|
||||
}
|
||||
}
|
||||
break;
|
||||
@ -1437,8 +1578,8 @@ scroll_unit_name (GdkScrollUnit unit)
|
||||
}
|
||||
|
||||
static void
|
||||
populate_event_properties (GtkListStore *store,
|
||||
GdkEvent *event)
|
||||
populate_event_properties (GListStore *store,
|
||||
GdkEvent *event)
|
||||
{
|
||||
GdkEventType type;
|
||||
GdkDevice *device;
|
||||
@ -1449,7 +1590,7 @@ populate_event_properties (GtkListStore *store,
|
||||
GdkModifierType state;
|
||||
GdkScrollUnit scroll_unit;
|
||||
|
||||
gtk_list_store_clear (store);
|
||||
g_list_store_remove_all (store);
|
||||
|
||||
type = gdk_event_get_event_type (event);
|
||||
|
||||
@ -1658,7 +1799,7 @@ render_node_list_selection_changed (GtkListBox *list,
|
||||
|
||||
gtk_picture_set_paintable (GTK_PICTURE (recorder->render_node_view), paintable);
|
||||
node = gtk_render_node_paintable_get_render_node (GTK_RENDER_NODE_PAINTABLE (paintable));
|
||||
populate_render_node_properties (GTK_LIST_STORE (recorder->render_node_properties), node);
|
||||
populate_render_node_properties (recorder->render_node_properties, node);
|
||||
|
||||
g_object_unref (paintable);
|
||||
}
|
||||
@ -1929,47 +2070,6 @@ bind_widget_for_recording (GtkListItemFactory *factory,
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
node_property_activated (GtkTreeView *tv,
|
||||
GtkTreePath *path,
|
||||
GtkTreeViewColumn *col,
|
||||
GtkInspectorRecorder *recorder)
|
||||
{
|
||||
GtkTreeIter iter;
|
||||
GdkRectangle rect;
|
||||
GdkTexture *texture;
|
||||
gboolean visible;
|
||||
GtkWidget *popover;
|
||||
GtkWidget *image;
|
||||
|
||||
gtk_tree_model_get_iter (GTK_TREE_MODEL (recorder->render_node_properties), &iter, path);
|
||||
gtk_tree_model_get (GTK_TREE_MODEL (recorder->render_node_properties), &iter,
|
||||
2, &visible,
|
||||
3, &texture,
|
||||
-1);
|
||||
gtk_tree_view_get_cell_area (tv, path, col, &rect);
|
||||
gtk_tree_view_convert_bin_window_to_widget_coords (tv, rect.x, rect.y, &rect.x, &rect.y);
|
||||
|
||||
if (texture == NULL || visible)
|
||||
return;
|
||||
|
||||
popover = gtk_popover_new ();
|
||||
gtk_widget_set_parent (popover, GTK_WIDGET (tv));
|
||||
gtk_popover_set_pointing_to (GTK_POPOVER (popover), &rect);
|
||||
|
||||
image = gtk_image_new_from_paintable (GDK_PAINTABLE (texture));
|
||||
gtk_widget_set_margin_start (image, 20);
|
||||
gtk_widget_set_margin_end (image, 20);
|
||||
gtk_widget_set_margin_top (image, 20);
|
||||
gtk_widget_set_margin_bottom (image, 20);
|
||||
gtk_popover_set_child (GTK_POPOVER (popover), image);
|
||||
gtk_popover_popup (GTK_POPOVER (popover));
|
||||
|
||||
g_signal_connect (popover, "unmap", G_CALLBACK (gtk_widget_unparent), NULL);
|
||||
|
||||
g_object_unref (texture);
|
||||
}
|
||||
|
||||
static void
|
||||
gtk_inspector_recorder_get_property (GObject *object,
|
||||
guint param_id,
|
||||
@ -2090,7 +2190,7 @@ gtk_inspector_recorder_class_init (GtkInspectorRecorderClass *klass)
|
||||
gtk_widget_class_bind_template_callback (widget_class, recording_selected);
|
||||
gtk_widget_class_bind_template_callback (widget_class, render_node_save);
|
||||
gtk_widget_class_bind_template_callback (widget_class, render_node_clip);
|
||||
gtk_widget_class_bind_template_callback (widget_class, node_property_activated);
|
||||
//gtk_widget_class_bind_template_callback (widget_class, node_property_activated);
|
||||
gtk_widget_class_bind_template_callback (widget_class, toggle_dark_mode);
|
||||
|
||||
gtk_widget_class_set_layout_manager_type (widget_class, GTK_TYPE_BIN_LAYOUT);
|
||||
@ -2100,6 +2200,8 @@ static void
|
||||
gtk_inspector_recorder_init (GtkInspectorRecorder *recorder)
|
||||
{
|
||||
GtkListItemFactory *factory;
|
||||
GtkSelectionModel *model;
|
||||
GtkColumnViewColumn *column;
|
||||
|
||||
gtk_widget_init_template (GTK_WIDGET (recorder));
|
||||
|
||||
@ -2127,13 +2229,55 @@ gtk_inspector_recorder_init (GtkInspectorRecorder *recorder)
|
||||
gtk_list_view_set_model (GTK_LIST_VIEW (recorder->render_node_list),
|
||||
GTK_SELECTION_MODEL (recorder->render_node_selection));
|
||||
|
||||
recorder->render_node_properties = GTK_TREE_MODEL (gtk_list_store_new (4, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_BOOLEAN, GDK_TYPE_TEXTURE));
|
||||
gtk_tree_view_set_model (GTK_TREE_VIEW (recorder->node_property_tree), recorder->render_node_properties);
|
||||
g_object_unref (recorder->render_node_properties);
|
||||
recorder->render_node_properties = g_list_store_new (object_property_get_type ());
|
||||
model = GTK_SELECTION_MODEL (gtk_no_selection_new (G_LIST_MODEL (recorder->render_node_properties)));
|
||||
gtk_column_view_set_model (GTK_COLUMN_VIEW (recorder->node_property_tree), model);
|
||||
g_object_unref (model);
|
||||
|
||||
recorder->event_properties = GTK_TREE_MODEL (gtk_list_store_new (4, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_BOOLEAN, GDK_TYPE_TEXTURE));
|
||||
gtk_tree_view_set_model (GTK_TREE_VIEW (recorder->event_property_tree), recorder->event_properties);
|
||||
g_object_unref (recorder->event_properties);
|
||||
column = g_list_model_get_item (gtk_column_view_get_columns (GTK_COLUMN_VIEW (recorder->node_property_tree)), 0);
|
||||
|
||||
factory = gtk_signal_list_item_factory_new ();
|
||||
g_signal_connect (factory, "setup", G_CALLBACK (setup_label), NULL);
|
||||
g_signal_connect (factory, "bind", G_CALLBACK (bind_property_name), NULL);
|
||||
|
||||
gtk_column_view_column_set_factory (column, factory);
|
||||
g_object_unref (factory);
|
||||
g_object_unref (column);
|
||||
|
||||
column = g_list_model_get_item (gtk_column_view_get_columns (GTK_COLUMN_VIEW (recorder->node_property_tree)), 1);
|
||||
|
||||
factory = gtk_signal_list_item_factory_new ();
|
||||
g_signal_connect (factory, "setup", G_CALLBACK (setup_value_widgets), NULL);
|
||||
g_signal_connect (factory, "bind", G_CALLBACK (bind_value_widgets), NULL);
|
||||
|
||||
gtk_column_view_column_set_factory (column, factory);
|
||||
g_object_unref (factory);
|
||||
g_object_unref (column);
|
||||
|
||||
recorder->event_properties = g_list_store_new (object_property_get_type ());
|
||||
model = GTK_SELECTION_MODEL (gtk_no_selection_new (G_LIST_MODEL (recorder->event_properties)));
|
||||
gtk_column_view_set_model (GTK_COLUMN_VIEW (recorder->event_property_tree), model);
|
||||
g_object_unref (model);
|
||||
|
||||
column = g_list_model_get_item (gtk_column_view_get_columns (GTK_COLUMN_VIEW (recorder->event_property_tree)), 0);
|
||||
|
||||
factory = gtk_signal_list_item_factory_new ();
|
||||
g_signal_connect (factory, "setup", G_CALLBACK (setup_label), NULL);
|
||||
g_signal_connect (factory, "bind", G_CALLBACK (bind_property_name), NULL);
|
||||
|
||||
gtk_column_view_column_set_factory (column, factory);
|
||||
g_object_unref (factory);
|
||||
g_object_unref (column);
|
||||
|
||||
column = g_list_model_get_item (gtk_column_view_get_columns (GTK_COLUMN_VIEW (recorder->event_property_tree)), 1);
|
||||
|
||||
factory = gtk_signal_list_item_factory_new ();
|
||||
g_signal_connect (factory, "setup", G_CALLBACK (setup_value_widgets), NULL);
|
||||
g_signal_connect (factory, "bind", G_CALLBACK (bind_value_widgets), NULL);
|
||||
|
||||
gtk_column_view_column_set_factory (column, factory);
|
||||
g_object_unref (factory);
|
||||
g_object_unref (column);
|
||||
}
|
||||
|
||||
static void
|
||||
@ -2306,4 +2450,5 @@ gtk_inspector_recorder_set_selected_sequence (GtkInspectorRecorder *recorder,
|
||||
g_object_notify_by_pspec (G_OBJECT (recorder), props[PROP_SELECTED_SEQUENCE]);
|
||||
}
|
||||
|
||||
/* vim:set foldmethod=marker expandtab: */
|
||||
|
||||
|
@ -134,44 +134,16 @@
|
||||
<object class="GtkScrolledWindow">
|
||||
<property name="propagate-natural-width">1</property>
|
||||
<child>
|
||||
<object class="GtkTreeView" id="node_property_tree">
|
||||
<property name="activate-on-single-click">1</property>
|
||||
<signal name="row-activated" handler="node_property_activated"/>
|
||||
<object class="GtkColumnView" id="node_property_tree">
|
||||
<child>
|
||||
<object class="GtkTreeViewColumn">
|
||||
<object class="GtkColumnViewColumn">
|
||||
<property name="title" translatable="yes">Property</property>
|
||||
<child>
|
||||
<object class="GtkCellRendererText">
|
||||
<property name="yalign">0</property>
|
||||
</object>
|
||||
<attributes>
|
||||
<attribute name="text">0</attribute>
|
||||
</attributes>
|
||||
</child>
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkTreeViewColumn">
|
||||
<object class="GtkColumnViewColumn">
|
||||
<property name="title" translatable="yes">Value</property>
|
||||
<child>
|
||||
<object class="GtkCellRendererText">
|
||||
<property name="yalign">0</property>
|
||||
<property name="wrap-mode">word</property>
|
||||
<property name="max-width-chars">50</property>
|
||||
</object>
|
||||
<attributes>
|
||||
<attribute name="text">1</attribute>
|
||||
</attributes>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkCellRendererPixbuf">
|
||||
<property name="xalign">0</property>
|
||||
</object>
|
||||
<attributes>
|
||||
<attribute name="visible">2</attribute>
|
||||
<attribute name="texture">3</attribute>
|
||||
</attributes>
|
||||
</child>
|
||||
<property name="expand">1</property>
|
||||
</object>
|
||||
</child>
|
||||
</object>
|
||||
@ -201,34 +173,16 @@
|
||||
<object class="GtkScrolledWindow">
|
||||
<property name="propagate-natural-width">1</property>
|
||||
<child>
|
||||
<object class="GtkTreeView" id="event_property_tree">
|
||||
<property name="activate-on-single-click">1</property>
|
||||
<object class="GtkColumnView" id="event_property_tree">
|
||||
<child>
|
||||
<object class="GtkTreeViewColumn">
|
||||
<object class="GtkColumnViewColumn">
|
||||
<property name="title" translatable="yes">Property</property>
|
||||
<child>
|
||||
<object class="GtkCellRendererText">
|
||||
<property name="yalign">0</property>
|
||||
</object>
|
||||
<attributes>
|
||||
<attribute name="text">0</attribute>
|
||||
</attributes>
|
||||
</child>
|
||||
</object>
|
||||
</child>
|
||||
<child>
|
||||
<object class="GtkTreeViewColumn">
|
||||
<object class="GtkColumnViewColumn">
|
||||
<property name="title" translatable="yes">Value</property>
|
||||
<child>
|
||||
<object class="GtkCellRendererText">
|
||||
<property name="yalign">0</property>
|
||||
<property name="wrap-mode">word</property>
|
||||
<property name="max-width-chars">50</property>
|
||||
</object>
|
||||
<attributes>
|
||||
<attribute name="text">1</attribute>
|
||||
</attributes>
|
||||
</child>
|
||||
<property name="expand">1</property>
|
||||
</object>
|
||||
</child>
|
||||
</object>
|
||||
|
Loading…
Reference in New Issue
Block a user