mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-13 22:10:08 +00:00
Merge branch 'master.win32' into 'master'
Some more fixes for Windows Closes #3157 See merge request GNOME/gtk!2580
This commit is contained in:
commit
e4d29ba9fd
@ -429,7 +429,7 @@ sweeper_game_reveal_cell (SweeperGame *self,
|
|||||||
sweeper_game_check_finished (self);
|
sweeper_game_check_finished (self);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
G_MODULE_EXPORT void
|
||||||
minesweeper_cell_clicked_cb (GtkGridView *gridview,
|
minesweeper_cell_clicked_cb (GtkGridView *gridview,
|
||||||
guint pos,
|
guint pos,
|
||||||
SweeperGame *game)
|
SweeperGame *game)
|
||||||
@ -437,7 +437,7 @@ minesweeper_cell_clicked_cb (GtkGridView *gridview,
|
|||||||
sweeper_game_reveal_cell (game, pos);
|
sweeper_game_reveal_cell (game, pos);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
G_MODULE_EXPORT void
|
||||||
minesweeper_new_game_cb (GtkButton *button,
|
minesweeper_new_game_cb (GtkButton *button,
|
||||||
SweeperGame *game)
|
SweeperGame *game)
|
||||||
{
|
{
|
||||||
|
@ -3276,34 +3276,38 @@ gdk_event_translate (MSG *msg,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (LOWORD (msg->wParam) == WA_INACTIVE && msg->lParam != 0)
|
if (LOWORD (msg->wParam) == WA_INACTIVE)
|
||||||
{
|
{
|
||||||
GdkSurface *other_surface = gdk_win32_handle_table_lookup ((HWND) msg->lParam);
|
if (msg->lParam != 0)
|
||||||
if (other_surface != NULL &&
|
|
||||||
(GDK_IS_POPUP (other_surface) || GDK_IS_DRAG_SURFACE (other_surface)))
|
|
||||||
{
|
{
|
||||||
/* We're being deactivated in favour of some popup or temp window.
|
GdkSurface *other_surface = gdk_win32_handle_table_lookup ((HWND) msg->lParam);
|
||||||
* Since only toplevels can have visual focus, pretend that
|
if (other_surface != NULL &&
|
||||||
* nothing happened.
|
(GDK_IS_POPUP (other_surface) || GDK_IS_DRAG_SURFACE (other_surface)))
|
||||||
*/
|
{
|
||||||
*ret_valp = 0;
|
/* We're being deactivated in favour of some popup or temp window.
|
||||||
return_val = TRUE;
|
* Since only toplevels can have visual focus, pretend that
|
||||||
break;
|
* nothing happened.
|
||||||
|
*/
|
||||||
|
*ret_valp = 0;
|
||||||
|
return_val = TRUE;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gdk_synthesize_surface_state (window, GDK_TOPLEVEL_STATE_FOCUSED, 0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
gdk_synthesize_surface_state (window, 0, GDK_TOPLEVEL_STATE_FOCUSED);
|
||||||
|
|
||||||
|
/* Bring any tablet contexts to the top of the overlap order when
|
||||||
|
* one of our windows is activated.
|
||||||
|
* NOTE: It doesn't seem to work well if it is done in WM_ACTIVATEAPP
|
||||||
|
* instead
|
||||||
|
*/
|
||||||
|
_gdk_input_set_tablet_active ();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (LOWORD (msg->wParam) == WA_INACTIVE)
|
|
||||||
gdk_synthesize_surface_state (window, GDK_TOPLEVEL_STATE_FOCUSED, 0);
|
|
||||||
else
|
|
||||||
gdk_synthesize_surface_state (window, 0, GDK_TOPLEVEL_STATE_FOCUSED);
|
|
||||||
|
|
||||||
/* Bring any tablet contexts to the top of the overlap order when
|
|
||||||
* one of our windows is activated.
|
|
||||||
* NOTE: It doesn't seem to work well if it is done in WM_ACTIVATEAPP
|
|
||||||
* instead
|
|
||||||
*/
|
|
||||||
if (LOWORD(msg->wParam) != WA_INACTIVE)
|
|
||||||
_gdk_input_set_tablet_active ();
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case WM_ACTIVATEAPP:
|
case WM_ACTIVATEAPP:
|
||||||
|
@ -193,8 +193,6 @@ gdk_surface_win32_finalize (GObject *object)
|
|||||||
surface->hicon_small = NULL;
|
surface->hicon_small = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
g_free (surface->decorations);
|
|
||||||
|
|
||||||
if (surface->cache_surface)
|
if (surface->cache_surface)
|
||||||
{
|
{
|
||||||
cairo_surface_destroy (surface->cache_surface);
|
cairo_surface_destroy (surface->cache_surface);
|
||||||
@ -1381,9 +1379,11 @@ get_effective_window_decorations (GdkSurface *window,
|
|||||||
*decoration = 0;
|
*decoration = 0;
|
||||||
|
|
||||||
if (!GDK_IS_TOPLEVEL (window))
|
if (!GDK_IS_TOPLEVEL (window))
|
||||||
{
|
return FALSE;
|
||||||
return FALSE;
|
|
||||||
}
|
/* we want to apply the "no decorations", if decorations are disabled */
|
||||||
|
if (!GDK_WIN32_SURFACE (window)->decorate_all)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
if ((impl->hint_flags & GDK_HINT_MIN_SIZE) &&
|
if ((impl->hint_flags & GDK_HINT_MIN_SIZE) &&
|
||||||
(impl->hint_flags & GDK_HINT_MAX_SIZE) &&
|
(impl->hint_flags & GDK_HINT_MAX_SIZE) &&
|
||||||
@ -1779,8 +1779,7 @@ _gdk_win32_surface_lacks_wm_decorations (GdkSurface *window)
|
|||||||
* even though GdkWMDecoration docs indicate that 0 does NOT mean
|
* even though GdkWMDecoration docs indicate that 0 does NOT mean
|
||||||
* "no decorations".
|
* "no decorations".
|
||||||
*/
|
*/
|
||||||
if (impl->decorations &&
|
if (!impl->decorate_all)
|
||||||
*impl->decorations == 0)
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
if (GDK_SURFACE_HWND (window) == 0)
|
if (GDK_SURFACE_HWND (window) == 0)
|
||||||
@ -1880,6 +1879,7 @@ _gdk_win32_surface_update_style_bits (GdkSurface *window)
|
|||||||
if (get_effective_window_decorations (window, &decorations))
|
if (get_effective_window_decorations (window, &decorations))
|
||||||
{
|
{
|
||||||
all = (decorations & GDK_DECOR_ALL);
|
all = (decorations & GDK_DECOR_ALL);
|
||||||
|
|
||||||
/* Keep this in sync with the test in _gdk_win32_surface_lacks_wm_decorations() */
|
/* Keep this in sync with the test in _gdk_win32_surface_lacks_wm_decorations() */
|
||||||
update_single_bit (&new_style, all, decorations & GDK_DECOR_BORDER, WS_BORDER);
|
update_single_bit (&new_style, all, decorations & GDK_DECOR_BORDER, WS_BORDER);
|
||||||
update_single_bit (&new_style, all, decorations & GDK_DECOR_RESIZEH, WS_THICKFRAME);
|
update_single_bit (&new_style, all, decorations & GDK_DECOR_RESIZEH, WS_THICKFRAME);
|
||||||
@ -4829,6 +4829,7 @@ gdk_win32_toplevel_set_property (GObject *object,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LAST_PROP + GDK_TOPLEVEL_PROP_DECORATED:
|
case LAST_PROP + GDK_TOPLEVEL_PROP_DECORATED:
|
||||||
|
GDK_WIN32_SURFACE (surface)->decorate_all = g_value_get_boolean (value);
|
||||||
_gdk_win32_surface_update_style_bits (surface);
|
_gdk_win32_surface_update_style_bits (surface);
|
||||||
g_object_notify_by_pspec (G_OBJECT (surface), pspec);
|
g_object_notify_by_pspec (G_OBJECT (surface), pspec);
|
||||||
break;
|
break;
|
||||||
@ -4882,10 +4883,7 @@ gdk_win32_toplevel_get_property (GObject *object,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case LAST_PROP + GDK_TOPLEVEL_PROP_DECORATED:
|
case LAST_PROP + GDK_TOPLEVEL_PROP_DECORATED:
|
||||||
{
|
g_value_set_boolean (value, GDK_WIN32_SURFACE (surface)->decorate_all);
|
||||||
GdkWMDecoration decorations = GDK_DECOR_ALL;
|
|
||||||
g_value_set_boolean (value, get_effective_window_decorations (surface, &decorations));
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case LAST_PROP + GDK_TOPLEVEL_PROP_DELETABLE:
|
case LAST_PROP + GDK_TOPLEVEL_PROP_DELETABLE:
|
||||||
|
@ -337,8 +337,8 @@ struct _GdkWin32Surface
|
|||||||
/* Also remember the same position, but in absolute form. */
|
/* Also remember the same position, but in absolute form. */
|
||||||
GdkRectangle *snap_stash_int;
|
GdkRectangle *snap_stash_int;
|
||||||
|
|
||||||
/* Decorations set by gdk_surface_set_decorations() or NULL if unset */
|
/* Enable all decorations? */
|
||||||
GdkWMDecoration* decorations;
|
gboolean decorate_all;
|
||||||
|
|
||||||
/* No. of windows to force layered windows off */
|
/* No. of windows to force layered windows off */
|
||||||
guint suppress_layered;
|
guint suppress_layered;
|
||||||
|
Loading…
Reference in New Issue
Block a user