forked from AuroraMiddleware/gtk
switch: Set PRELIGHT state on widget
This commit is contained in:
parent
3534225c76
commit
d1118071dd
@ -335,6 +335,7 @@ gtk_switch_enter (GtkWidget *widget,
|
|||||||
if (event->window == priv->event_window)
|
if (event->window == priv->event_window)
|
||||||
{
|
{
|
||||||
priv->in_switch = TRUE;
|
priv->in_switch = TRUE;
|
||||||
|
gtk_widget_set_state_flags (widget, GTK_STATE_FLAG_PRELIGHT, FALSE);
|
||||||
gtk_widget_queue_draw (widget);
|
gtk_widget_queue_draw (widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -350,6 +351,7 @@ gtk_switch_leave (GtkWidget *widget,
|
|||||||
if (event->window == priv->event_window)
|
if (event->window == priv->event_window)
|
||||||
{
|
{
|
||||||
priv->in_switch = FALSE;
|
priv->in_switch = FALSE;
|
||||||
|
gtk_widget_unset_state_flags (widget, GTK_STATE_FLAG_PRELIGHT);
|
||||||
gtk_widget_queue_draw (widget);
|
gtk_widget_queue_draw (widget);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -563,14 +565,9 @@ gtk_switch_paint_handle (GtkWidget *widget,
|
|||||||
cairo_t *cr,
|
cairo_t *cr,
|
||||||
GdkRectangle *box)
|
GdkRectangle *box)
|
||||||
{
|
{
|
||||||
GtkSwitchPrivate *priv = GTK_SWITCH (widget)->priv;
|
|
||||||
GtkStyleContext *context = gtk_widget_get_style_context (widget);
|
GtkStyleContext *context = gtk_widget_get_style_context (widget);
|
||||||
GtkStateFlags state = gtk_widget_get_state_flags (widget);
|
|
||||||
|
|
||||||
gtk_style_context_save (context);
|
gtk_style_context_save (context);
|
||||||
if (priv->in_switch)
|
|
||||||
state |= GTK_STATE_FLAG_PRELIGHT;
|
|
||||||
gtk_style_context_set_state (context, state);
|
|
||||||
gtk_style_context_add_class (context, GTK_STYLE_CLASS_SLIDER);
|
gtk_style_context_add_class (context, GTK_STYLE_CLASS_SLIDER);
|
||||||
|
|
||||||
gtk_render_slider (context, cr,
|
gtk_render_slider (context, cr,
|
||||||
|
Loading…
Reference in New Issue
Block a user