mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-14 06:10:21 +00:00
Make fractional scaling for GL opt-in
Fractional scaling with the GL renderer is experimental for now, so we disable it unless GDK_DEBUG=gl-fractional is set. This will give us time to work out the kinks.
This commit is contained in:
parent
fa58dd9256
commit
4746ffc4eb
@ -121,6 +121,7 @@ static const GdkDebugKey gdk_debug_keys[] = {
|
|||||||
{ "portals", GDK_DEBUG_PORTALS, "Force use of portals", TRUE },
|
{ "portals", GDK_DEBUG_PORTALS, "Force use of portals", TRUE },
|
||||||
{ "no-portals", GDK_DEBUG_NO_PORTALS, "Disable use of portals", TRUE },
|
{ "no-portals", GDK_DEBUG_NO_PORTALS, "Disable use of portals", TRUE },
|
||||||
{ "gl-disable", GDK_DEBUG_GL_DISABLE, "Disable OpenGL support", TRUE },
|
{ "gl-disable", GDK_DEBUG_GL_DISABLE, "Disable OpenGL support", TRUE },
|
||||||
|
{ "gl-fractional", GDK_DEBUG_GL_FRACTIONAL, "Enable fractional scaling for OpenGL (experimental)", TRUE },
|
||||||
{ "gl-debug", GDK_DEBUG_GL_DEBUG, "Insert debugging information in OpenGL", TRUE },
|
{ "gl-debug", GDK_DEBUG_GL_DEBUG, "Insert debugging information in OpenGL", TRUE },
|
||||||
{ "gl-legacy", GDK_DEBUG_GL_LEGACY, "Use a legacy OpenGL context", TRUE },
|
{ "gl-legacy", GDK_DEBUG_GL_LEGACY, "Use a legacy OpenGL context", TRUE },
|
||||||
{ "gl-gles", GDK_DEBUG_GL_GLES, "Only allow OpenGL GLES API", TRUE },
|
{ "gl-gles", GDK_DEBUG_GL_GLES, "Only allow OpenGL GLES API", TRUE },
|
||||||
|
@ -41,6 +41,7 @@ typedef enum {
|
|||||||
GDK_DEBUG_PORTALS = 1 << 12,
|
GDK_DEBUG_PORTALS = 1 << 12,
|
||||||
GDK_DEBUG_NO_PORTALS = 1 << 13,
|
GDK_DEBUG_NO_PORTALS = 1 << 13,
|
||||||
GDK_DEBUG_GL_DISABLE = 1 << 14,
|
GDK_DEBUG_GL_DISABLE = 1 << 14,
|
||||||
|
GDK_DEBUG_GL_FRACTIONAL = 1 << 15,
|
||||||
GDK_DEBUG_GL_LEGACY = 1 << 16,
|
GDK_DEBUG_GL_LEGACY = 1 << 16,
|
||||||
GDK_DEBUG_GL_GLES = 1 << 17,
|
GDK_DEBUG_GL_GLES = 1 << 17,
|
||||||
GDK_DEBUG_GL_DEBUG = 1 << 18,
|
GDK_DEBUG_GL_DEBUG = 1 << 18,
|
||||||
|
@ -560,6 +560,23 @@ gdk_gl_context_real_make_current (GdkGLContext *context,
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
double
|
||||||
|
gdk_gl_context_get_scale (GdkGLContext *self)
|
||||||
|
{
|
||||||
|
GdkDisplay *display;
|
||||||
|
GdkSurface *surface;
|
||||||
|
double scale;
|
||||||
|
|
||||||
|
surface = gdk_draw_context_get_surface (GDK_DRAW_CONTEXT (self));
|
||||||
|
scale = gdk_surface_get_scale (surface);
|
||||||
|
|
||||||
|
display = gdk_gl_context_get_display (self);
|
||||||
|
if (!(gdk_display_get_debug_flags (display) & GDK_DEBUG_GL_FRACTIONAL))
|
||||||
|
scale = ceil (scale);
|
||||||
|
|
||||||
|
return scale;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gdk_gl_context_real_begin_frame (GdkDrawContext *draw_context,
|
gdk_gl_context_real_begin_frame (GdkDrawContext *draw_context,
|
||||||
gboolean prefers_high_depth,
|
gboolean prefers_high_depth,
|
||||||
@ -569,9 +586,11 @@ gdk_gl_context_real_begin_frame (GdkDrawContext *draw_context,
|
|||||||
G_GNUC_UNUSED GdkGLContextPrivate *priv = gdk_gl_context_get_instance_private (context);
|
G_GNUC_UNUSED GdkGLContextPrivate *priv = gdk_gl_context_get_instance_private (context);
|
||||||
GdkSurface *surface;
|
GdkSurface *surface;
|
||||||
cairo_region_t *damage;
|
cairo_region_t *damage;
|
||||||
|
double scale;
|
||||||
int ww, wh;
|
int ww, wh;
|
||||||
|
|
||||||
surface = gdk_draw_context_get_surface (draw_context);
|
surface = gdk_draw_context_get_surface (draw_context);
|
||||||
|
scale = gdk_gl_context_get_scale (context);
|
||||||
|
|
||||||
#ifdef HAVE_EGL
|
#ifdef HAVE_EGL
|
||||||
if (priv->egl_context)
|
if (priv->egl_context)
|
||||||
@ -588,8 +607,8 @@ gdk_gl_context_real_begin_frame (GdkDrawContext *draw_context,
|
|||||||
cairo_region_union (region, damage);
|
cairo_region_union (region, damage);
|
||||||
cairo_region_destroy (damage);
|
cairo_region_destroy (damage);
|
||||||
|
|
||||||
ww = (int) ceil (gdk_surface_get_width (surface) * gdk_surface_get_scale (surface));
|
ww = (int) ceil (gdk_surface_get_width (surface) * scale);
|
||||||
wh = (int) ceil (gdk_surface_get_height (surface) * gdk_surface_get_scale (surface));
|
wh = (int) ceil (gdk_surface_get_height (surface) * scale);
|
||||||
|
|
||||||
gdk_gl_context_make_current (context);
|
gdk_gl_context_make_current (context);
|
||||||
|
|
||||||
@ -633,7 +652,7 @@ gdk_gl_context_real_end_frame (GdkDrawContext *draw_context,
|
|||||||
EGLint *heap_rects = NULL;
|
EGLint *heap_rects = NULL;
|
||||||
int i, j, n_rects = cairo_region_num_rectangles (painted);
|
int i, j, n_rects = cairo_region_num_rectangles (painted);
|
||||||
int surface_height = gdk_surface_get_height (surface);
|
int surface_height = gdk_surface_get_height (surface);
|
||||||
double scale = gdk_surface_get_scale (surface);
|
double scale = gdk_gl_context_get_scale (context);
|
||||||
EGLint *rects;
|
EGLint *rects;
|
||||||
|
|
||||||
if (n_rects < G_N_ELEMENTS (stack_rects) / 4)
|
if (n_rects < G_N_ELEMENTS (stack_rects) / 4)
|
||||||
|
@ -167,5 +167,7 @@ gboolean gdk_gl_context_use_es_bgra (GdkGLContext
|
|||||||
|
|
||||||
gboolean gdk_gl_context_has_vertex_half_float (GdkGLContext *self) G_GNUC_PURE;
|
gboolean gdk_gl_context_has_vertex_half_float (GdkGLContext *self) G_GNUC_PURE;
|
||||||
|
|
||||||
|
double gdk_gl_context_get_scale (GdkGLContext *self);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
|
@ -230,6 +230,30 @@ gdk_wayland_surface_maybe_resize (GdkSurface *surface,
|
|||||||
gdk_wayland_surface_create_wl_surface (surface);
|
gdk_wayland_surface_create_wl_surface (surface);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void
|
||||||
|
get_egl_window_size (GdkSurface *surface,
|
||||||
|
int *width,
|
||||||
|
int *height)
|
||||||
|
{
|
||||||
|
GdkDisplay *display = gdk_surface_get_display (surface);
|
||||||
|
GdkWaylandSurface *impl = GDK_WAYLAND_SURFACE (surface);
|
||||||
|
|
||||||
|
if (gdk_display_get_debug_flags (display) & GDK_DEBUG_GL_FRACTIONAL)
|
||||||
|
{
|
||||||
|
GDK_DISPLAY_DEBUG (display, OPENGL, "Using fractional scale %g for EGL window", gdk_fractional_scale_to_double (&impl->scale));
|
||||||
|
|
||||||
|
*width = gdk_fractional_scale_scale (&impl->scale, surface->width),
|
||||||
|
*height = gdk_fractional_scale_scale (&impl->scale, surface->height);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GDK_DISPLAY_DEBUG (display, OPENGL, "Using integer scale %d for EGL window", gdk_fractional_scale_to_int (&impl->scale));
|
||||||
|
|
||||||
|
*width = surface->width * gdk_fractional_scale_to_int (&impl->scale);
|
||||||
|
*height = surface->height * gdk_fractional_scale_to_int (&impl->scale);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gdk_wayland_surface_update_size (GdkSurface *surface,
|
gdk_wayland_surface_update_size (GdkSurface *surface,
|
||||||
int32_t width,
|
int32_t width,
|
||||||
@ -258,10 +282,11 @@ gdk_wayland_surface_update_size (GdkSurface *surface,
|
|||||||
impl->viewport_dirty = TRUE;
|
impl->viewport_dirty = TRUE;
|
||||||
|
|
||||||
if (impl->display_server.egl_window)
|
if (impl->display_server.egl_window)
|
||||||
wl_egl_window_resize (impl->display_server.egl_window,
|
{
|
||||||
gdk_fractional_scale_scale (scale, width),
|
int w, h;
|
||||||
gdk_fractional_scale_scale (scale, height),
|
get_egl_window_size (surface, &w, &h);
|
||||||
0, 0);
|
wl_egl_window_resize (impl->display_server.egl_window, w, h, 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
gdk_surface_invalidate_rect (surface, NULL);
|
gdk_surface_invalidate_rect (surface, NULL);
|
||||||
|
|
||||||
@ -1363,10 +1388,11 @@ gdk_wayland_surface_ensure_wl_egl_window (GdkSurface *surface)
|
|||||||
|
|
||||||
if (impl->display_server.egl_window == NULL)
|
if (impl->display_server.egl_window == NULL)
|
||||||
{
|
{
|
||||||
|
int width, height;
|
||||||
|
|
||||||
|
get_egl_window_size (surface, &width, &height);
|
||||||
impl->display_server.egl_window =
|
impl->display_server.egl_window =
|
||||||
wl_egl_window_create (impl->display_server.wl_surface,
|
wl_egl_window_create (impl->display_server.wl_surface, width, height);
|
||||||
gdk_fractional_scale_scale (&impl->scale, surface->width),
|
|
||||||
gdk_fractional_scale_scale (&impl->scale, surface->height));
|
|
||||||
gdk_surface_set_egl_native_window (surface, impl->display_server.egl_window);
|
gdk_surface_set_egl_native_window (surface, impl->display_server.egl_window);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -288,7 +288,7 @@ gsk_gl_renderer_render (GskRenderer *renderer,
|
|||||||
g_assert (root != NULL);
|
g_assert (root != NULL);
|
||||||
|
|
||||||
surface = gdk_draw_context_get_surface (GDK_DRAW_CONTEXT (self->context));
|
surface = gdk_draw_context_get_surface (GDK_DRAW_CONTEXT (self->context));
|
||||||
scale = gdk_surface_get_scale (surface);
|
scale = gdk_gl_context_get_scale (self->context);
|
||||||
|
|
||||||
viewport.origin.x = 0;
|
viewport.origin.x = 0;
|
||||||
viewport.origin.y = 0;
|
viewport.origin.y = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user