Port StTable to StThemeNode

Convert the StTable code from StStylable to StThemeNode. The
:row-spacing and :col-spacing GObject properties are converted
into spacing-rows and spacing-columns style properties.

A new interactive test is added for StTable.

https://bugzilla.gnome.org/show_bug.cgi?id=596811
This commit is contained in:
Owen W. Taylor 2009-09-25 19:16:12 -04:00
parent 45b4d0384c
commit 3abe92d15d
3 changed files with 108 additions and 184 deletions

View File

@ -48,17 +48,11 @@
#include "st-private.h"
#include "st-table-child.h"
#include "st-table-private.h"
#include "st-stylable.h"
enum
{
PROP_0,
PROP_PADDING,
PROP_COL_SPACING,
PROP_ROW_SPACING,
PROP_HOMOGENEOUS,
PROP_ROW_COUNT,
@ -211,14 +205,6 @@ st_table_set_property (GObject *gobject,
switch (prop_id)
{
case PROP_COL_SPACING:
st_table_set_col_spacing (table, g_value_get_int (value));
break;
case PROP_ROW_SPACING:
st_table_set_row_spacing (table, g_value_get_int (value));
break;
case PROP_HOMOGENEOUS:
if (table->priv->homogeneous != g_value_get_boolean (value))
{
@ -243,14 +229,6 @@ st_table_get_property (GObject *gobject,
switch (prop_id)
{
case PROP_COL_SPACING:
g_value_set_int (value, priv->col_spacing);
break;
case PROP_ROW_SPACING:
g_value_set_int (value, priv->row_spacing);
break;
case PROP_HOMOGENEOUS:
g_value_set_boolean (value, priv->homogeneous);
break;
@ -405,26 +383,21 @@ st_table_allocate_fill (ClutterActor *child,
static void
st_table_homogeneous_allocate (ClutterActor *self,
const ClutterActorBox *box,
const ClutterActorBox *content_box,
gboolean flags)
{
GSList *list;
gfloat col_width, row_height;
gint row_spacing, col_spacing;
StTablePrivate *priv = ST_TABLE (self)->priv;
StPadding padding;
st_widget_get_padding (ST_WIDGET (self), &padding);
col_spacing = priv->col_spacing;
row_spacing = priv->row_spacing;
col_width = (box->x2 - box->x1
- padding.left - padding.right
col_width = (content_box->x2 - content_box->x1
- (col_spacing * (priv->n_cols - 1)))
/ priv->n_cols;
row_height = (box->y2 - box->y1
- padding.top - padding.bottom
row_height = (content_box->y2 - content_box->y1
- (row_spacing * (priv->n_rows - 1)))
/ priv->n_rows;
@ -454,10 +427,10 @@ st_table_homogeneous_allocate (ClutterActor *self,
x_fill = meta->x_fill;
y_fill = meta->y_fill;
childbox.x1 = padding.left + (col_width + col_spacing) * col;
childbox.x1 = content_box->x1 + (col_width + col_spacing) * col;
childbox.x2 = childbox.x1 + (col_width * col_span) + (col_spacing * (col_span - 1));
childbox.y1 = padding.top + (row_height + row_spacing) * row;
childbox.y1 = content_box->y1 + (row_height + row_spacing) * row;
childbox.y2 = childbox.y1 + (row_height * row_span) + (row_spacing * (row_span - 1));
st_table_allocate_fill (child, &childbox, x_align, y_align, x_fill, y_fill);
@ -478,7 +451,6 @@ st_table_calculate_col_widths (StTable *table,
gint extra_col_width, n_expanded_cols = 0, expanded_cols = 0;
gint *pref_widths, *min_widths;
GSList *list;
StPadding padding;
g_array_set_size (priv->is_expand_col, 0);
g_array_set_size (priv->is_expand_col, priv->n_cols);
@ -492,12 +464,6 @@ st_table_calculate_col_widths (StTable *table,
g_array_set_size (priv->min_widths, priv->n_cols);
min_widths = (gint *) priv->min_widths->data;
/* take off the padding values to calculate the allocatable width */
st_widget_get_padding (ST_WIDGET (table), &padding);
for_width -= (int)(padding.left + padding.right);
for (list = priv->children; list; list = g_slist_next (list))
{
gint row, col;
@ -591,12 +557,6 @@ st_table_calculate_row_heights (StTable *table,
gint i, total_min_height;
gint expanded_rows = 0;
gint n_expanded_rows = 0;
StPadding padding;
st_widget_get_padding (ST_WIDGET (table), &padding);
/* take padding off available height */
for_height -= (int)(padding.top + padding.bottom);
g_array_set_size (priv->row_heights, 0);
g_array_set_size (priv->row_heights, priv->n_rows);
@ -762,40 +722,29 @@ st_table_calculate_row_heights (StTable *table,
static void
st_table_preferred_allocate (ClutterActor *self,
const ClutterActorBox *box,
const ClutterActorBox *content_box,
gboolean flags)
{
GSList *list;
gint row_spacing, col_spacing;
gint i, table_width, table_height;
gint i;
gint *col_widths, *row_heights;
StTable *table;
StTablePrivate *priv;
StPadding padding;
table = ST_TABLE (self);
priv = ST_TABLE (self)->priv;
st_widget_get_padding (ST_WIDGET (self), &padding);
col_spacing = (priv->col_spacing);
row_spacing = (priv->row_spacing);
table_height = (int)(box->y2 - box->y1
- padding.top
- padding.bottom);
table_width = (int)(box->x2 - box->x1
- padding.right
- padding.left);
col_widths =
st_table_calculate_col_widths (table,
(int)(box->x2 - box->x1));
(int) (content_box->x2 - content_box->x1));
row_heights =
st_table_calculate_row_heights (table,
(int)(box->y2 - box->y1),
(int) (content_box->y2 - content_box->y1),
col_widths);
@ -865,13 +814,13 @@ st_table_preferred_allocate (ClutterActor *self,
}
/* calculate child x */
child_x = (int) padding.left
child_x = (int) content_box->x1
+ col_spacing * col;
for (i = 0; i < col; i++)
child_x += col_widths[i];
/* calculate child y */
child_y = (int) padding.top
child_y = (int) content_box->y1
+ row_spacing * row;
for (i = 0; i < row; i++)
child_y += row_heights[i];
@ -896,6 +845,8 @@ st_table_allocate (ClutterActor *self,
ClutterAllocationFlags flags)
{
StTablePrivate *priv = ST_TABLE (self)->priv;
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (self));
ClutterActorBox content_box;
CLUTTER_ACTOR_CLASS (st_table_parent_class)->allocate (self, box, flags);
@ -904,10 +855,12 @@ st_table_allocate (ClutterActor *self,
return;
};
st_theme_node_get_content_box (theme_node, box, &content_box);
if (priv->homogeneous)
st_table_homogeneous_allocate (self, box, flags);
st_table_homogeneous_allocate (self, &content_box, flags);
else
st_table_preferred_allocate (self, box, flags);
st_table_preferred_allocate (self, &content_box, flags);
}
static void
@ -919,11 +872,9 @@ st_table_get_preferred_width (ClutterActor *self,
gint *min_widths, *pref_widths;
gfloat total_min_width, total_pref_width;
StTablePrivate *priv = ST_TABLE (self)->priv;
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (self));
GSList *list;
gint i;
StPadding padding;
st_widget_get_padding (ST_WIDGET (self), &padding);
if (priv->n_cols < 1)
{
@ -970,10 +921,7 @@ st_table_get_preferred_width (ClutterActor *self,
pref_widths[col] = w_pref;
}
total_min_width = padding.left
+ padding.right
+ (priv->n_cols - 1)
* (float) priv->col_spacing;
total_min_width = (priv->n_cols - 1) * (float) priv->col_spacing;
total_pref_width = total_min_width;
for (i = 0; i < priv->n_cols; i++)
@ -986,6 +934,8 @@ st_table_get_preferred_width (ClutterActor *self,
*min_width_p = total_min_width;
if (natural_width_p)
*natural_width_p = total_pref_width;
st_theme_node_adjust_preferred_width (theme_node, min_width_p, natural_width_p);
}
static void
@ -997,10 +947,10 @@ st_table_get_preferred_height (ClutterActor *self,
gint *min_heights, *pref_heights;
gfloat total_min_height, total_pref_height;
StTablePrivate *priv = ST_TABLE (self)->priv;
StThemeNode *theme_node = st_widget_get_theme_node (ST_WIDGET (self));
GSList *list;
gint i;
gint *min_widths;
StPadding padding;
if (priv->n_rows < 1)
{
@ -1009,6 +959,8 @@ st_table_get_preferred_height (ClutterActor *self,
return;
}
st_theme_node_adjust_for_width (theme_node, &for_width);
/* Setting size to zero and then what we want it to be causes a clear if
* clear flag is set (which it should be.)
*/
@ -1057,12 +1009,8 @@ st_table_get_preferred_height (ClutterActor *self,
pref_heights[row] = pref;
}
st_widget_get_padding (ST_WIDGET (self), &padding);
/* start off with padding plus row spacing */
total_min_height = padding.top + padding.bottom + (priv->n_rows - 1) *
(float)(priv->row_spacing);
/* start off with row spacing */
total_min_height = (priv->n_rows - 1) * (float) (priv->row_spacing);
total_pref_height = total_min_height;
for (i = 0; i < priv->n_rows; i++)
@ -1075,6 +1023,8 @@ st_table_get_preferred_height (ClutterActor *self,
*min_height_p = total_min_height;
if (natural_height_p)
*natural_height_p = total_pref_height;
st_theme_node_adjust_preferred_height (theme_node, min_height_p, natural_height_p);
}
static void
@ -1135,6 +1085,27 @@ st_table_hide_all (ClutterActor *table)
clutter_actor_hide_all (CLUTTER_ACTOR (l->data));
}
static void
st_table_style_changed (StWidget *self)
{
StTablePrivate *priv = ST_TABLE (self)->priv;
StThemeNode *theme_node = st_widget_get_theme_node (self);
int old_row_spacing = priv->row_spacing;
int old_col_spacing = priv->col_spacing;
double row_spacing = 0., col_spacing = 0.;
st_theme_node_get_length (theme_node, "spacing-rows", FALSE, &row_spacing);
priv->row_spacing = (int)(row_spacing + 0.5);
st_theme_node_get_length (theme_node, "spacing-columns", FALSE, &col_spacing);
priv->col_spacing = (int)(col_spacing + 0.5);
if (priv->row_spacing != old_row_spacing ||
priv->col_spacing != old_col_spacing)
clutter_actor_queue_relayout (CLUTTER_ACTOR (self));
ST_WIDGET_CLASS (st_table_parent_class)->style_changed (self);
}
static void
st_table_class_init (StTableClass *klass)
{
@ -1142,7 +1113,7 @@ st_table_class_init (StTableClass *klass)
GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
ClutterActorClass *actor_class = CLUTTER_ACTOR_CLASS (klass);
/* StWidgetClass *st_widget_class = ST_WIDGET_CLASS (klass); */
StWidgetClass *widget_class = ST_WIDGET_CLASS (klass);
g_type_class_add_private (klass, sizeof (StTablePrivate));
@ -1159,6 +1130,8 @@ st_table_class_init (StTableClass *klass)
actor_class->show_all = st_table_show_all;
actor_class->hide_all = st_table_hide_all;
widget_class->style_changed = st_table_style_changed;
pspec = g_param_spec_boolean ("homogeneous",
"Homogeneous",
"Homogeneous rows and columns",
@ -1168,24 +1141,6 @@ st_table_class_init (StTableClass *klass)
PROP_HOMOGENEOUS,
pspec);
pspec = g_param_spec_int ("col-spacing",
"Column Spacing",
"Spacing between columns",
0, G_MAXINT, 0,
ST_PARAM_READWRITE);
g_object_class_install_property (gobject_class,
PROP_COL_SPACING,
pspec);
pspec = g_param_spec_int ("row-spacing",
"Row Spacing",
"Spacing between row",
0, G_MAXINT, 0,
ST_PARAM_READWRITE);
g_object_class_install_property (gobject_class,
PROP_ROW_SPACING,
pspec);
pspec = g_param_spec_int ("row-count",
"Row Count",
"The number of rows in the table",
@ -1269,86 +1224,6 @@ st_table_new (void)
return g_object_new (ST_TYPE_TABLE, NULL);
}
/**
* st_table_set_col_spacing
* @table: a #StTable
* @spacing: spacing in pixels
*
* Sets the amount of spacing between columns.
*/
void
st_table_set_col_spacing (StTable *table,
gint spacing)
{
StTablePrivate *priv;
g_return_if_fail (ST_IS_TABLE (table));
g_return_if_fail (spacing >= 0);
priv = ST_TABLE (table)->priv;
priv->col_spacing = spacing;
}
/**
* st_table_set_row_spacing
* @table: a #StTable
* @spacing: spacing in pixels
*
* Sets the amount of spacing between rows.
*/
void
st_table_set_row_spacing (StTable *table,
gint spacing)
{
StTablePrivate *priv;
g_return_if_fail (ST_IS_TABLE (table));
g_return_if_fail (spacing >= 0);
priv = ST_TABLE (table)->priv;
priv->row_spacing = spacing;
}
/**
* st_table_get_row_spacing
* @table: a #StTable
*
* Gets the amount of spacing between rows.
*
* Returns: the spacing between rows in device units
*/
gint
st_table_get_row_spacing (StTable *table)
{
StTablePrivate *priv;
g_return_val_if_fail (ST_IS_TABLE (table), -1);
priv = ST_TABLE (table)->priv;
return priv->row_spacing;
}
/**
* st_table_get_col_spacing
* @table: a #StTable
*
* Gets the amount of spacing between columns.
*
* Returns: the spacing between columns in device units
*/
gint
st_table_get_col_spacing (StTable *table)
{
StTablePrivate *priv;
g_return_val_if_fail (ST_IS_TABLE (table), -1);
priv = ST_TABLE (table)->priv;
return priv->col_spacing;
}
/**
* st_table_get_row_count:
* @table: A #StTable

View File

@ -87,13 +87,6 @@ GType st_table_get_type (void) G_GNUC_CONST;
StWidget* st_table_new (void);
void st_table_set_col_spacing (StTable *table,
gint spacing);
void st_table_set_row_spacing (StTable *table,
gint spacing);
gint st_table_get_col_spacing (StTable *table);
gint st_table_get_row_spacing (StTable *table);
gint st_table_get_row_count (StTable *table);
gint st_table_get_column_count (StTable *table);

View File

@ -0,0 +1,56 @@
/* -*- mode: js2; js2-basic-offset: 4; indent-tabs-mode: nil -*- */
const Clutter = imports.gi.Clutter;
const St = imports.gi.St;
const UI = imports.testcommon.ui;
UI.init();
let stage = Clutter.Stage.get_default();
stage.width = stage.height = 600;
let vbox = new St.BoxLayout({ vertical: true,
width: stage.width,
height: stage.height,
style: 'padding: 10px; '
+ 'spacing: 10px;'
+ 'font: 15px sans-serif;' });
stage.add_actor(vbox);
function L(text, color) {
return new St.Label({ text: text,
style: "background: " + color + ";"
+ "border: 1px solid rgba(0,0,0,0.5);"
+ "padding: 1em;" });
}
////////////////////////////////////////////////////////////////////////////////
let table = new St.Table({ style: "border: 10px solid #888888;"
+ "padding: 10px;"
+ "spacing-rows: 5px;"
+ "spacing-columns: 15px;" });
vbox.add(table, { expand: true });
table.add(L("1", "#ff0000"),
{ row: 0, col: 0, col_span: 3 });
table.add(L("2", "#00ff00"),
{ row: 1, col: 0, row_span: 2 });
table.add(L("3", "#0000ff"),
{ row: 1, col: 1,
x_expand: 0 });
table.add(L("4", "#ffff00"),
{ row: 1, col: 2,
y_expand: 0, y_fill: 0
});
table.add(L("5", "#ff00ff"),
{ row: 2, col: 1, x_expand: 0 });
table.add(L("6", "#00ffff"),
{ row: 2, col: 2,
x_expand: 0, x_fill: 0, x_align: 1.0,
y_expand: 0, y_fill: 0, y_align: 1.0 });
////////////////////////////////////////////////////////////////////////////////
stage.show();
Clutter.main();