mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-25 00:28:21 +00:00
d3dvideosink: Release D3D surfaces when shutting down the sink
https://bugzilla.gnome.org/show_bug.cgi?id=726026
This commit is contained in:
parent
aa5f55cebe
commit
f54efc206f
2 changed files with 15 additions and 0 deletions
|
@ -58,6 +58,8 @@ GST_DEBUG_CATEGORY_EXTERN (gst_d3dvideosink_debug);
|
||||||
static gint WM_D3DVIDEO_NOTIFY_DEVICE_LOST = 0;
|
static gint WM_D3DVIDEO_NOTIFY_DEVICE_LOST = 0;
|
||||||
#define IDT_DEVICE_RESET_TIMER 0
|
#define IDT_DEVICE_RESET_TIMER 0
|
||||||
|
|
||||||
|
#define WM_QUIT_THREAD WM_USER+0
|
||||||
|
|
||||||
/** Helpers **/
|
/** Helpers **/
|
||||||
|
|
||||||
#define ERROR_CHECK_HR(hr) \
|
#define ERROR_CHECK_HR(hr) \
|
||||||
|
@ -1083,6 +1085,7 @@ d3d_set_window_handle (GstD3DVideoSink * sink, guintptr window_id,
|
||||||
|
|
||||||
/* Unset current window */
|
/* Unset current window */
|
||||||
if (sink->d3d.window_handle != NULL) {
|
if (sink->d3d.window_handle != NULL) {
|
||||||
|
PostMessage (sink->d3d.window_handle, WM_QUIT_THREAD, NULL, NULL);
|
||||||
GST_DEBUG_OBJECT (sink, "Unsetting window [HWND:%p]",
|
GST_DEBUG_OBJECT (sink, "Unsetting window [HWND:%p]",
|
||||||
sink->d3d.window_handle);
|
sink->d3d.window_handle);
|
||||||
d3d_window_wndproc_unset (sink);
|
d3d_window_wndproc_unset (sink);
|
||||||
|
@ -1096,6 +1099,8 @@ d3d_set_window_handle (GstD3DVideoSink * sink, guintptr window_id,
|
||||||
if (window_id) {
|
if (window_id) {
|
||||||
sink->d3d.window_handle = (HWND) window_id;
|
sink->d3d.window_handle = (HWND) window_id;
|
||||||
sink->d3d.window_is_internal = is_internal;
|
sink->d3d.window_is_internal = is_internal;
|
||||||
|
if (!is_internal)
|
||||||
|
sink->d3d.external_window_handle = sink->d3d.window_handle;
|
||||||
/* If caps have been set.. prepare window */
|
/* If caps have been set.. prepare window */
|
||||||
if (sink->format != 0)
|
if (sink->format != 0)
|
||||||
d3d_prepare_render_window (sink);
|
d3d_prepare_render_window (sink);
|
||||||
|
@ -1131,6 +1136,10 @@ d3d_prepare_window (GstD3DVideoSink * sink)
|
||||||
|
|
||||||
LOCK_SINK (sink);
|
LOCK_SINK (sink);
|
||||||
|
|
||||||
|
/* if we already had an external window, then use it again */
|
||||||
|
if (sink->d3d.external_window_handle)
|
||||||
|
sink->d3d.window_handle = sink->d3d.external_window_handle;
|
||||||
|
|
||||||
/* Give the app a last chance to set a window id */
|
/* Give the app a last chance to set a window id */
|
||||||
if (!sink->d3d.window_handle)
|
if (!sink->d3d.window_handle)
|
||||||
gst_video_overlay_prepare_window_handle (GST_VIDEO_OVERLAY (sink));
|
gst_video_overlay_prepare_window_handle (GST_VIDEO_OVERLAY (sink));
|
||||||
|
@ -2118,6 +2127,7 @@ d3d_internal_window_thread (D3DInternalWindowDat * dat)
|
||||||
GstD3DVideoSink *sink;
|
GstD3DVideoSink *sink;
|
||||||
HWND hWnd;
|
HWND hWnd;
|
||||||
MSG msg;
|
MSG msg;
|
||||||
|
BOOL fGetMsg;
|
||||||
|
|
||||||
g_return_val_if_fail (dat != NULL, NULL);
|
g_return_val_if_fail (dat != NULL, NULL);
|
||||||
|
|
||||||
|
@ -2138,7 +2148,10 @@ d3d_internal_window_thread (D3DInternalWindowDat * dat)
|
||||||
/*
|
/*
|
||||||
* Internal window message loop
|
* Internal window message loop
|
||||||
*/
|
*/
|
||||||
|
|
||||||
while (GetMessage (&msg, NULL, 0, 0)) {
|
while (GetMessage (&msg, NULL, 0, 0)) {
|
||||||
|
if (msg.message == WM_QUIT_THREAD)
|
||||||
|
break;
|
||||||
TranslateMessage (&msg);
|
TranslateMessage (&msg);
|
||||||
DispatchMessage (&msg);
|
DispatchMessage (&msg);
|
||||||
}
|
}
|
||||||
|
@ -2597,6 +2610,7 @@ error:
|
||||||
if (!ret)
|
if (!ret)
|
||||||
klass->d3d.error_exit = TRUE;
|
klass->d3d.error_exit = TRUE;
|
||||||
if (hWnd) {
|
if (hWnd) {
|
||||||
|
PostMessage (hWnd, WM_DESTROY, NULL, NULL);
|
||||||
DestroyWindow (hWnd);
|
DestroyWindow (hWnd);
|
||||||
klass->d3d.hidden_window = 0;
|
klass->d3d.hidden_window = 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,6 +78,7 @@ typedef struct _GstD3DDataClass {
|
||||||
|
|
||||||
typedef struct _GstD3DData {
|
typedef struct _GstD3DData {
|
||||||
/* Window Proc Stuff */
|
/* Window Proc Stuff */
|
||||||
|
HWND external_window_handle;
|
||||||
HWND window_handle;
|
HWND window_handle;
|
||||||
gboolean window_is_internal;
|
gboolean window_is_internal;
|
||||||
WNDPROC orig_wnd_proc;
|
WNDPROC orig_wnd_proc;
|
||||||
|
|
Loading…
Reference in a new issue