[PATCH] wined3d: Restore the Topmost state upon exiting fullscreen, when used from DXGI.
Gabriel Ivăncescu
gabrielopcode at gmail.com
Thu Jul 2 11:06:09 CDT 2020
On 02/07/2020 18:44, Henri Verbeet wrote:
> On Thu, 2 Jul 2020 at 19:50, Gabriel Ivăncescu <gabrielopcode at gmail.com> wrote:
>>>> diff --git a/include/wine/wined3d.h b/include/wine/wined3d.h
>>>> index 346d1d0..cee46d3 100644
>>>> --- a/include/wine/wined3d.h
>>>> +++ b/include/wine/wined3d.h
>>>> @@ -905,6 +905,7 @@ enum wined3d_shader_type
>>>> #define WINED3D_SWAPCHAIN_GDI_COMPATIBLE 0x00008000u
>>>> #define WINED3D_SWAPCHAIN_IMPLICIT 0x00010000u
>>>> #define WINED3D_SWAPCHAIN_HOOK 0x00020000u
>>>> +#define WINED3D_SWAPCHAIN_TOPMOST_RESTORE 0x00040000u
>>>>
>>> Ideally WINED3D_SWAPCHAIN_TOPMOST_RESTORE would simply be merged with
>>> WINED3D_SWAPCHAIN_RESTORE_WINDOW_RECT, but the naming should at least
>>> be consistent.
>>>
>>
>> So in that case I'd simply check to see if the rect is NULL or not, to
>> restore TOPMOST, within the function that restores it, right?
>>
> No, you'd rename WINED3D_SWAPCHAIN_RESTORE_WINDOW_RECT to something
> like WINED3D_SWAPCHAIN_RESTORE_GEOMETRY (although it's perhaps a bit
> of a stretch to include the stacking order in "geometry"), and then
> check for that flag the same way the current patch checks for
> WINED3D_SWAPCHAIN_TOPMOST_RESTORE.
>
>> As for the name, how about WINED3D_SWAPCHAIN_RESTORE_WINDOW_STATE? (I'll
>> of course send it as a separate patch)
>>
> I could live with it, but "state" is very broad.
>
Yeah, I was basing it off Rémi's patch series to ease it later when he
rebases them. From that perspective, I think it's better if I add a new
flag, since it will be needed later by his patches anyway (for ddraw,
d3d9 and dxgi different behaviors).
Currently I'm thinking of something like
WINED3D_SWAPCHAIN_RESTORE_ZORDER. I'll do some more testing to see if it
works with his patches, though, otherwise there's not much point to it.
Unless that's not desirable then I'll go with the
WINED3D_SWAPCHAIN_RESTORE_GEOMETRY thing (which only applies to dxgi).
More information about the wine-devel
mailing list