GList *children;
GtkMyShadowType shadow_type;
- guint m_width;
- guint m_height;
-
guint m_xoffset;
guint m_yoffset;
+
+ gint m_width;
GdkWindow *bin_window;
/* accessors */
-WXDLLIMPEXP_CORE
-gint gtk_pizza_get_width (GtkPizza *pizza);
-WXDLLIMPEXP_CORE
-gint gtk_pizza_get_height (GtkPizza *pizza);
WXDLLIMPEXP_CORE
gint gtk_pizza_get_xoffset (GtkPizza *pizza);
WXDLLIMPEXP_CORE
justify = GTK_JUSTIFY_RIGHT;
else // wxALIGN_LEFT is 0
justify = GTK_JUSTIFY_LEFT;
+
+ if (GetLayoutDirection() == wxLayout_RightToLeft)
+ {
+ if (justify == GTK_JUSTIFY_RIGHT)
+ justify = GTK_JUSTIFY_LEFT;
+ if (justify == GTK_JUSTIFY_LEFT)
+ justify = GTK_JUSTIFY_RIGHT;
+ }
+
gtk_label_set_justify(GTK_LABEL(m_widget), justify);
// GTK_JUSTIFY_LEFT is 0, RIGHT 1 and CENTER 2
(int)alloc->height );
*/
+ // Tell the wxWindow class about the new size
win->m_width = alloc->width;
win->m_height = alloc->height;
+
+ if (win->m_mainWidget)
+ GTK_PIZZA(win->m_mainWidget)->m_width = win->m_width;
+
win->GtkUpdateSize();
}
}
GTK_WIDGET_UNSET_FLAGS( m_mainWidget, GTK_CAN_FOCUS );
gtk_container_add( GTK_CONTAINER(m_widget), m_mainWidget );
+ GTK_PIZZA(m_mainWidget)->m_width = m_width;
+
if (m_miniEdge == 0) // wxMiniFrame has its own version.
{
// For m_mainWidget themes
}
if (width != -1) m_width = width;
if (height != -1) m_height = height;
+
+ if (m_mainWidget)
+ GTK_PIZZA(m_mainWidget)->m_width = m_width;
/*
if ((sizeFlags & wxSIZE_AUTO_WIDTH) == wxSIZE_AUTO_WIDTH)
if (client_h < 0)
client_h = 0;
+ // Let the parent perform the resize
gtk_pizza_set_size( GTK_PIZZA(m_mainWidget),
m_wxwindow,
client_x, client_y, client_w, client_h );
pizza->children = NULL;
- pizza->m_width = 20;
- pizza->m_height = 20;
-
pizza->bin_window = NULL;
pizza->m_xoffset = 0;
pizza->m_yoffset = 0;
+
+ pizza->m_width = -1;
pizza->external_expose = FALSE;
}
return GTK_WIDGET (pizza);
}
-gint gtk_pizza_get_width (GtkPizza *pizza)
-{
- g_return_val_if_fail ( (pizza != NULL), -1 );
- g_return_val_if_fail ( (GTK_IS_PIZZA (pizza)), -1 );
-
- return pizza->m_width;
-}
-
-gint gtk_pizza_get_height (GtkPizza *pizza)
-{
- g_return_val_if_fail ( (pizza != NULL), -1 );
- g_return_val_if_fail ( (GTK_IS_PIZZA (pizza)), -1 );
-
- return pizza->m_height;
-}
-
gint gtk_pizza_get_xoffset (GtkPizza *pizza)
{
g_return_val_if_fail ( (pizza != NULL), -1 );
g_return_if_fail (GTK_IS_PIZZA (pizza));
g_return_if_fail (widget != NULL);
+ if (gtk_widget_get_direction( GTK_WIDGET(pizza) ) == GTK_TEXT_DIR_RTL)
+ {
+ // reverse horizontal placement
+ x = pizza->m_width - x - width;
+ }
+
child_info = g_new (GtkPizzaChild, 1);
child_info->widget = widget;
child_info->width = width;
child_info->height = height;
+ if (GTK_IS_PIZZA(widget))
+ GTK_PIZZA(widget)->m_width = width;
+
pizza->children = g_list_append (pizza->children, child_info);
if (GTK_WIDGET_REALIZED (pizza))
if (child->widget == widget)
{
- if ((child->x == x) &&
+ gint new_x = x;
+ if (gtk_widget_get_direction( GTK_WIDGET(pizza) ) == GTK_TEXT_DIR_RTL)
+ {
+ // reverse horizontal placement
+ new_x = pizza->m_width - new_x - width;
+ }
+
+ if ((child->x == new_x) &&
(child->y == y) &&
(child->width == width) &&
(child->height == height)) return;
- child->x = x;
+ child->x = new_x;
child->y = y;
child->width = width;
child->height = height;
+
+ if (GTK_IS_PIZZA(widget))
+ GTK_PIZZA(widget)->m_width = width;
gtk_widget_set_size_request (widget, width, height);
static
void gtk_window_size_callback( GtkWidget *WXUNUSED(widget),
- GtkAllocation *WXUNUSED(alloc),
+ GtkAllocation *alloc,
wxWindow *win )
{
if (g_isIdle)
if ((client_width == win->m_oldClientWidth) && (client_height == win->m_oldClientHeight))
return;
+ GTK_PIZZA(win->m_wxwindow)->m_width = alloc->width;
+
win->m_oldClientWidth = client_width;
win->m_oldClientHeight = client_height;
void wxWindowGTK::DoMoveWindow(int x, int y, int width, int height)
{
+ // inform the parent to perform the move
gtk_pizza_set_size( GTK_PIZZA(m_parent->m_wxwindow), m_widget, x, y, width, height );
+
}
void wxWindowGTK::DoSetSize( int x, int y, int width, int height, int sizeFlags )
GTKSetLayout(m_widget, dir);
if (m_wxwindow)
- GTKSetLayout(m_widget, dir);
+ GTKSetLayout(m_wxwindow, dir);
+}
+
+wxCoord
+wxWindowGTK::AdjustForLayoutDirection(wxCoord x,
+ wxCoord WXUNUSED(width),
+ wxCoord WXUNUSED(widthTotal)) const
+{
+ // We now mirrors the coordinates of RTL windows in GtkPizza
+ return x;
}
void wxWindowGTK::DoMoveInTabOrder(wxWindow *win, MoveKind move)