Commit 6d04e6c3 authored by Connor McAdams's avatar Connor McAdams Committed by Alexandre Julliard

winex11.drv: Add mutable pixel format awareness.

Add the ability to check if the pixel format on the current window was previously set by wglSetPixelFormatWine(), and if was, allow the application to change it with a regular wglSetPixelFormat call. Signed-off-by: 's avatarConnor McAdams <cmcadams@codeweavers.com> Signed-off-by: 's avatarHenri Verbeet <hverbeet@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 53023c93
...@@ -249,6 +249,7 @@ struct gl_drawable ...@@ -249,6 +249,7 @@ struct gl_drawable
SIZE pixmap_size; /* pixmap size for GLXPixmap drawables */ SIZE pixmap_size; /* pixmap size for GLXPixmap drawables */
int swap_interval; int swap_interval;
BOOL refresh_swap_interval; BOOL refresh_swap_interval;
BOOL mutable_pf;
}; };
enum glx_swap_control_method enum glx_swap_control_method
...@@ -1306,7 +1307,8 @@ static GLXContext create_glxcontext(Display *display, struct wgl_context *contex ...@@ -1306,7 +1307,8 @@ static GLXContext create_glxcontext(Display *display, struct wgl_context *contex
/*********************************************************************** /***********************************************************************
* create_gl_drawable * create_gl_drawable
*/ */
static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel_format *format, BOOL known_child ) static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel_format *format, BOOL known_child,
BOOL mutable_pf )
{ {
struct gl_drawable *gl, *prev; struct gl_drawable *gl, *prev;
XVisualInfo *visual = format->visual; XVisualInfo *visual = format->visual;
...@@ -1326,6 +1328,7 @@ static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel ...@@ -1326,6 +1328,7 @@ static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel
gl->refresh_swap_interval = TRUE; gl->refresh_swap_interval = TRUE;
gl->format = format; gl->format = format;
gl->ref = 1; gl->ref = 1;
gl->mutable_pf = mutable_pf;
if (!known_child && !GetWindow( hwnd, GW_CHILD ) && GetAncestor( hwnd, GA_PARENT ) == GetDesktopWindow()) /* childless top-level window */ if (!known_child && !GetWindow( hwnd, GW_CHILD ) && GetAncestor( hwnd, GA_PARENT ) == GetDesktopWindow()) /* childless top-level window */
{ {
...@@ -1384,13 +1387,13 @@ static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel ...@@ -1384,13 +1387,13 @@ static struct gl_drawable *create_gl_drawable( HWND hwnd, const struct wgl_pixel
/*********************************************************************** /***********************************************************************
* set_win_format * set_win_format
*/ */
static BOOL set_win_format( HWND hwnd, const struct wgl_pixel_format *format ) static BOOL set_win_format( HWND hwnd, const struct wgl_pixel_format *format, BOOL mutable_pf )
{ {
struct gl_drawable *gl; struct gl_drawable *gl;
if (!format->visual) return FALSE; if (!format->visual) return FALSE;
if (!(gl = create_gl_drawable( hwnd, format, FALSE ))) return FALSE; if (!(gl = create_gl_drawable( hwnd, format, FALSE, mutable_pf ))) return FALSE;
TRACE( "created GL drawable %lx for win %p %s\n", TRACE( "created GL drawable %lx for win %p %s\n",
gl->drawable, hwnd, debugstr_fbconfig( format->fbconfig )); gl->drawable, hwnd, debugstr_fbconfig( format->fbconfig ));
...@@ -1437,12 +1440,14 @@ static BOOL set_pixel_format(HDC hdc, int format, BOOL allow_change) ...@@ -1437,12 +1440,14 @@ static BOOL set_pixel_format(HDC hdc, int format, BOOL allow_change)
if ((gl = get_gl_drawable( hwnd, hdc ))) if ((gl = get_gl_drawable( hwnd, hdc )))
{ {
int prev = pixel_format_index( gl->format ); int prev = pixel_format_index( gl->format );
BOOL mutable_pf = gl->mutable_pf;
release_gl_drawable( gl ); release_gl_drawable( gl );
if (!mutable_pf)
return prev == format; /* cannot change it if already set */ return prev == format; /* cannot change it if already set */
} }
} }
return set_win_format( hwnd, fmt ); return set_win_format( hwnd, fmt, allow_change );
} }
...@@ -1461,7 +1466,7 @@ void sync_gl_drawable( HWND hwnd, BOOL known_child ) ...@@ -1461,7 +1466,7 @@ void sync_gl_drawable( HWND hwnd, BOOL known_child )
if (!known_child) break; /* Still a childless top-level window */ if (!known_child) break; /* Still a childless top-level window */
/* fall through */ /* fall through */
case DC_GL_PIXMAP_WIN: case DC_GL_PIXMAP_WIN:
if (!(new = create_gl_drawable( hwnd, old->format, known_child ))) break; if (!(new = create_gl_drawable( hwnd, old->format, known_child, old->mutable_pf ))) break;
mark_drawable_dirty( old, new ); mark_drawable_dirty( old, new );
XFlush( gdi_display ); XFlush( gdi_display );
TRACE( "Recreated GL drawable %lx to replace %lx\n", new->drawable, old->drawable ); TRACE( "Recreated GL drawable %lx to replace %lx\n", new->drawable, old->drawable );
...@@ -1498,7 +1503,7 @@ void set_gl_drawable_parent( HWND hwnd, HWND parent ) ...@@ -1498,7 +1503,7 @@ void set_gl_drawable_parent( HWND hwnd, HWND parent )
return; return;
} }
if ((new = create_gl_drawable( hwnd, old->format, FALSE ))) if ((new = create_gl_drawable( hwnd, old->format, FALSE, old->mutable_pf )))
{ {
mark_drawable_dirty( old, new ); mark_drawable_dirty( old, new );
release_gl_drawable( new ); release_gl_drawable( new );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment