mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2024-12-28 22:41:43 +00:00
9a7e721181
This is an automatic rename of various things related to the window->surface rename. Public symbols changed by this is: GDK_MODE_WINDOW gdk_device_get_window_at_position gdk_device_get_window_at_position_double gdk_device_get_last_event_window gdk_display_get_monitor_at_window gdk_drag_context_get_source_window gdk_drag_context_get_dest_window gdk_drag_context_get_drag_window gdk_draw_context_get_window gdk_drawing_context_get_window gdk_gl_context_get_window gdk_synthesize_window_state gdk_surface_get_window_type gdk_x11_display_set_window_scale gsk_renderer_new_for_window gsk_renderer_get_window gtk_text_view_buffer_to_window_coords gtk_tree_view_convert_widget_to_bin_window_coords gtk_tree_view_convert_tree_to_bin_window_coords The commands that generated this are: git sed -f g "GDK window" "GDK surface" git sed -f g window_impl surface_impl (cd gdk; git sed -f g impl_window impl_surface) git sed -f g WINDOW_IMPL SURFACE_IMPL git sed -f g GDK_MODE_WINDOW GDK_MODE_SURFACE git sed -f g gdk_draw_context_get_window gdk_draw_context_get_surface git sed -f g gdk_drawing_context_get_window gdk_drawing_context_get_surface git sed -f g gdk_gl_context_get_window gdk_gl_context_get_surface git sed -f g gsk_renderer_get_window gsk_renderer_get_surface git sed -f g gsk_renderer_new_for_window gsk_renderer_new_for_surface (cd gdk; git sed -f g window_type surface_type) git sed -f g gdk_surface_get_window_type gdk_surface_get_surface_type git sed -f g window_at_position surface_at_position git sed -f g event_window event_surface git sed -f g window_coord surface_coord git sed -f g window_state surface_state git sed -f g window_cursor surface_cursor git sed -f g window_scale surface_scale git sed -f g window_events surface_events git sed -f g monitor_at_window monitor_at_surface git sed -f g window_under_pointer surface_under_pointer (cd gdk; git sed -f g for_window for_surface) git sed -f g window_anchor surface_anchor git sed -f g WINDOW_IS_TOPLEVEL SURFACE_IS_TOPLEVEL git sed -f g native_window native_surface git sed -f g source_window source_surface git sed -f g dest_window dest_surface git sed -f g drag_window drag_surface git sed -f g input_window input_surface git checkout NEWS* po-properties po docs/reference/gtk/migrating-3to4.xml
181 lines
5.3 KiB
C
181 lines
5.3 KiB
C
/* GDK - The GIMP Drawing Kit
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* gdkgeometry-win32.c: emulation of 32 bit coordinates within the
|
|
* limits of Win32 GDI. The idea of big window emulation is more or less
|
|
* a copy of the X11 version, and the equvalent of guffaw scrolling
|
|
* is ScrollWindowEx(). While we determine the invalidated region
|
|
* ourself during scrolling, we do not pass SW_INVALIDATE to
|
|
* ScrollWindowEx() to avoid a unnecessary WM_PAINT.
|
|
*
|
|
* Bits are always scrolled correctly by ScrollWindowEx(), but
|
|
* some big children may hit the coordinate boundary (i.e.
|
|
* win32_x/win32_y < -16383) after scrolling. They needed to be moved
|
|
* back to the real position determined by gdk_surface_compute_position().
|
|
* This is handled in gdk_surface_postmove().
|
|
*
|
|
* The X11 version by Owen Taylor <otaylor@redhat.com>
|
|
* Copyright Red Hat, Inc. 2000
|
|
* Win32 hack by Tor Lillqvist <tml@iki.fi>
|
|
* and Hans Breuer <hans@breuer.org>
|
|
* Modified by Ivan, Wong Yat Cheung <email@ivanwong.info>
|
|
* so that big window emulation finally works.
|
|
*/
|
|
|
|
#include "config.h"
|
|
#include "gdk.h" /* For gdk_rectangle_intersect */
|
|
#include "gdkinternals.h"
|
|
#include "gdkprivate-win32.h"
|
|
#include "gdkwin32.h"
|
|
|
|
#define SIZE_LIMIT 32767
|
|
|
|
typedef struct _GdkSurfaceParentPos GdkSurfaceParentPos;
|
|
|
|
static void
|
|
tmp_unset_bg (GdkSurface *window)
|
|
{
|
|
GdkSurfaceImplWin32 *impl;
|
|
|
|
impl = GDK_SURFACE_IMPL_WIN32 (window->impl);
|
|
|
|
impl->no_bg = TRUE;
|
|
}
|
|
|
|
static void
|
|
tmp_reset_bg (GdkSurface *window)
|
|
{
|
|
GdkSurfaceImplWin32 *impl;
|
|
|
|
impl = GDK_SURFACE_IMPL_WIN32 (window->impl);
|
|
|
|
impl->no_bg = FALSE;
|
|
}
|
|
|
|
void
|
|
_gdk_surface_move_resize_child (GdkSurface *window,
|
|
gint x,
|
|
gint y,
|
|
gint width,
|
|
gint height)
|
|
{
|
|
GdkSurfaceImplWin32 *impl;
|
|
|
|
g_return_if_fail (window != NULL);
|
|
g_return_if_fail (GDK_IS_SURFACE (window));
|
|
|
|
impl = GDK_SURFACE_IMPL_WIN32 (window->impl);
|
|
GDK_NOTE (MISC, g_print ("_gdk_surface_move_resize_child: %s@%+d%+d %dx%d@%+d%+d\n",
|
|
_gdk_win32_surface_description (window),
|
|
window->x, window->y, width, height, x, y));
|
|
|
|
if (width * impl->surface_scale > 65535 || height * impl->surface_scale > 65535)
|
|
{
|
|
g_warning ("Native children wider or taller than 65535 pixels are not supported.");
|
|
|
|
if (width * impl->surface_scale > 65535)
|
|
width = 65535 / impl->surface_scale;
|
|
if (height * impl->surface_scale > 65535)
|
|
height = 65535 /impl->surface_scale;
|
|
}
|
|
|
|
window->x = x;
|
|
window->y = y;
|
|
window->width = width;
|
|
window->height = height;
|
|
impl->unscaled_width = width * impl->surface_scale;
|
|
impl->unscaled_height = height * impl->surface_scale;
|
|
|
|
_gdk_win32_surface_tmp_unset_parent_bg (window);
|
|
_gdk_win32_surface_tmp_unset_bg (window, TRUE);
|
|
|
|
GDK_NOTE (MISC, g_print ("... SetWindowPos(%p,NULL,%d,%d,%d,%d,"
|
|
"NOACTIVATE|NOZORDER)\n",
|
|
GDK_SURFACE_HWND (window),
|
|
(window->x + window->parent->abs_x) * impl->surface_scale,
|
|
(window->y + window->parent->abs_y) * impl->surface_scale,
|
|
impl->unscaled_width,
|
|
impl->unscaled_height));
|
|
|
|
API_CALL (SetWindowPos, (GDK_SURFACE_HWND (window), NULL,
|
|
(window->x + window->parent->abs_x) * impl->surface_scale,
|
|
(window->y + window->parent->abs_y) * impl->surface_scale,
|
|
impl->unscaled_width,
|
|
impl->unscaled_height,
|
|
SWP_NOACTIVATE | SWP_NOZORDER));
|
|
|
|
_gdk_win32_surface_tmp_reset_bg (window, TRUE);
|
|
}
|
|
|
|
void
|
|
_gdk_win32_surface_tmp_unset_bg (GdkSurface *window,
|
|
gboolean recurse)
|
|
{
|
|
g_return_if_fail (GDK_IS_SURFACE (window));
|
|
|
|
if (window->input_only || window->destroyed || !GDK_SURFACE_IS_MAPPED (window))
|
|
return;
|
|
|
|
if (_gdk_surface_has_impl (window) &&
|
|
GDK_SURFACE_IS_WIN32 (window) &&
|
|
window->surface_type != GDK_SURFACE_FOREIGN)
|
|
tmp_unset_bg (window);
|
|
|
|
if (recurse)
|
|
{
|
|
GList *l;
|
|
|
|
for (l = window->children; l != NULL; l = l->next)
|
|
_gdk_win32_surface_tmp_unset_bg (l->data, TRUE);
|
|
}
|
|
}
|
|
|
|
void
|
|
_gdk_win32_surface_tmp_unset_parent_bg (GdkSurface *window)
|
|
{
|
|
if (window->parent == NULL)
|
|
return;
|
|
|
|
window = _gdk_surface_get_impl_surface (window->parent);
|
|
_gdk_win32_surface_tmp_unset_bg (window, FALSE);
|
|
}
|
|
|
|
void
|
|
_gdk_win32_surface_tmp_reset_bg (GdkSurface *window,
|
|
gboolean recurse)
|
|
{
|
|
g_return_if_fail (GDK_IS_SURFACE (window));
|
|
|
|
if (window->input_only || window->destroyed || !GDK_SURFACE_IS_MAPPED (window))
|
|
return;
|
|
|
|
if (_gdk_surface_has_impl (window) &&
|
|
GDK_SURFACE_IS_WIN32 (window) &&
|
|
window->surface_type != GDK_SURFACE_FOREIGN)
|
|
{
|
|
tmp_reset_bg (window);
|
|
}
|
|
|
|
if (recurse)
|
|
{
|
|
GList *l;
|
|
|
|
for (l = window->children; l != NULL; l = l->next)
|
|
_gdk_win32_surface_tmp_reset_bg (l->data, TRUE);
|
|
}
|
|
}
|