mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-04 22:48:49 +00:00
glwindow: make showing a window explicit
Also fixes the cgl context always displaying a window to render to for every GstGLContextCocoa created
This commit is contained in:
parent
71e4c485f0
commit
6cf97eb221
6 changed files with 135 additions and 72 deletions
|
@ -1439,13 +1439,15 @@ gst_glimage_sink_redisplay (GstGLImageSink * gl_sink)
|
||||||
gst_object_unref (window);
|
gst_object_unref (window);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
gst_gl_window_set_preferred_size (window, GST_VIDEO_SINK_WIDTH (gl_sink),
|
||||||
|
GST_VIDEO_SINK_HEIGHT (gl_sink));
|
||||||
|
gst_gl_window_show (window);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Drawing is asynchronous: gst_gl_window_draw is not blocking
|
/* Drawing is asynchronous: gst_gl_window_draw is not blocking
|
||||||
* It means that it does not wait for stuff to be executed in other threads
|
* It means that it does not wait for stuff to be executed in other threads
|
||||||
*/
|
*/
|
||||||
gst_gl_window_set_preferred_size (window, GST_VIDEO_SINK_WIDTH (gl_sink),
|
|
||||||
GST_VIDEO_SINK_HEIGHT (gl_sink));
|
|
||||||
gst_gl_window_draw (window);
|
gst_gl_window_draw (window);
|
||||||
}
|
}
|
||||||
alive = gst_gl_window_is_running (window);
|
alive = gst_gl_window_is_running (window);
|
||||||
|
|
|
@ -77,6 +77,7 @@ static void gst_gl_window_cocoa_send_message_async (GstGLWindow * window,
|
||||||
GstGLWindowCB callback, gpointer data, GDestroyNotify destroy);
|
GstGLWindowCB callback, gpointer data, GDestroyNotify destroy);
|
||||||
static void gst_gl_window_cocoa_set_preferred_size (GstGLWindow * window,
|
static void gst_gl_window_cocoa_set_preferred_size (GstGLWindow * window,
|
||||||
gint width, gint height);
|
gint width, gint height);
|
||||||
|
static void gst_gl_window_cocoa_show (GstGLWindow * window);
|
||||||
|
|
||||||
struct _GstGLWindowCocoaPrivate
|
struct _GstGLWindowCocoaPrivate
|
||||||
{
|
{
|
||||||
|
@ -114,6 +115,7 @@ gst_gl_window_cocoa_class_init (GstGLWindowCocoaClass * klass)
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_cocoa_send_message_async);
|
GST_DEBUG_FUNCPTR (gst_gl_window_cocoa_send_message_async);
|
||||||
window_class->set_preferred_size =
|
window_class->set_preferred_size =
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_cocoa_set_preferred_size);
|
GST_DEBUG_FUNCPTR (gst_gl_window_cocoa_set_preferred_size);
|
||||||
|
window_class->show = GST_DEBUG_FUNCPTR (gst_gl_window_cocoa_show);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -220,6 +222,56 @@ gst_gl_window_cocoa_set_window_handle (GstGLWindow * window, guintptr handle)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_gl_window_cocoa_show (GstGLWindow * window)
|
||||||
|
{
|
||||||
|
GstGLWindowCocoa *window_cocoa = GST_GL_WINDOW_COCOA (window);
|
||||||
|
GstGLWindowCocoaPrivate *priv = window_cocoa->priv;
|
||||||
|
|
||||||
|
if (!priv->visible) {
|
||||||
|
/* useful when set_window_handle is called before
|
||||||
|
* the internal NSWindow */
|
||||||
|
if (priv->external_view) {
|
||||||
|
gst_gl_window_cocoa_set_window_handle (window, (guintptr) priv->external_view);
|
||||||
|
priv->visible = TRUE;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatch_sync (dispatch_get_main_queue(), ^{
|
||||||
|
if (!priv->external_view && !priv->visible) {
|
||||||
|
NSRect mainRect = [[NSScreen mainScreen] visibleFrame];
|
||||||
|
NSRect windowRect = [priv->internal_win_id frame];
|
||||||
|
gint x = 0;
|
||||||
|
gint y = 0;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (window_cocoa, "main screen rect: %d %d %d %d\n", (int) mainRect.origin.x,
|
||||||
|
(int) mainRect.origin.y, (int) mainRect.size.width,
|
||||||
|
(int) mainRect.size.height);
|
||||||
|
|
||||||
|
windowRect.origin.x += x;
|
||||||
|
windowRect.origin.y += mainRect.size.height > y ? (mainRect.size.height - y) * 0.5 : y;
|
||||||
|
windowRect.size.width = window_cocoa->priv->preferred_width;
|
||||||
|
windowRect.size.height = window_cocoa->priv->preferred_height;
|
||||||
|
|
||||||
|
GST_DEBUG_OBJECT (window_cocoa, "window rect: %d %d %d %d\n", (int) windowRect.origin.x,
|
||||||
|
(int) windowRect.origin.y, (int) windowRect.size.width,
|
||||||
|
(int) windowRect.size.height);
|
||||||
|
|
||||||
|
x += 20;
|
||||||
|
y += 20;
|
||||||
|
|
||||||
|
[priv->internal_win_id setFrame:windowRect display:NO];
|
||||||
|
GST_DEBUG_OBJECT (window_cocoa, "make the window available\n");
|
||||||
|
|
||||||
|
[priv->internal_win_id makeMainWindow];
|
||||||
|
[priv->internal_win_id orderFrontRegardless];
|
||||||
|
[priv->internal_win_id setViewsNeedDisplay:YES];
|
||||||
|
|
||||||
|
priv->visible = TRUE;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_gl_window_cocoa_draw (GstGLWindow * window)
|
gst_gl_window_cocoa_draw (GstGLWindow * window)
|
||||||
|
@ -313,45 +365,6 @@ gst_gl_cocoa_draw_cb (GstGLWindowCocoa *window_cocoa)
|
||||||
{
|
{
|
||||||
GstGLWindowCocoaPrivate *priv = window_cocoa->priv;
|
GstGLWindowCocoaPrivate *priv = window_cocoa->priv;
|
||||||
|
|
||||||
/* useful when set_window_handle is called before
|
|
||||||
* the internal NSWindow */
|
|
||||||
if (priv->external_view && !priv->visible) {
|
|
||||||
gst_gl_window_cocoa_set_window_handle (GST_GL_WINDOW (window_cocoa), (guintptr) priv->external_view);
|
|
||||||
priv->visible = TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!priv->external_view && !priv->visible) {
|
|
||||||
NSRect mainRect = [[NSScreen mainScreen] visibleFrame];
|
|
||||||
NSRect windowRect = [priv->internal_win_id frame];
|
|
||||||
gint x = 0;
|
|
||||||
gint y = 0;
|
|
||||||
|
|
||||||
GST_DEBUG ("main screen rect: %d %d %d %d\n", (int) mainRect.origin.x,
|
|
||||||
(int) mainRect.origin.y, (int) mainRect.size.width,
|
|
||||||
(int) mainRect.size.height);
|
|
||||||
|
|
||||||
windowRect.origin.x += x;
|
|
||||||
windowRect.origin.y += mainRect.size.height > y ? (mainRect.size.height - y) * 0.5 : y;
|
|
||||||
windowRect.size.width = window_cocoa->priv->preferred_width;
|
|
||||||
windowRect.size.height = window_cocoa->priv->preferred_height;
|
|
||||||
|
|
||||||
GST_DEBUG ("window rect: %d %d %d %d\n", (int) windowRect.origin.x,
|
|
||||||
(int) windowRect.origin.y, (int) windowRect.size.width,
|
|
||||||
(int) windowRect.size.height);
|
|
||||||
|
|
||||||
x += 20;
|
|
||||||
y += 20;
|
|
||||||
|
|
||||||
[priv->internal_win_id setFrame:windowRect display:NO];
|
|
||||||
GST_DEBUG ("make the window available\n");
|
|
||||||
|
|
||||||
[priv->internal_win_id makeMainWindow];
|
|
||||||
[priv->internal_win_id orderFrontRegardless];
|
|
||||||
[priv->internal_win_id setViewsNeedDisplay:YES];
|
|
||||||
|
|
||||||
priv->visible = TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (g_main_loop_is_running (priv->loop)) {
|
if (g_main_loop_is_running (priv->loop)) {
|
||||||
if (![priv->internal_win_id isClosed]) {
|
if (![priv->internal_win_id isClosed]) {
|
||||||
GstGLWindow *window = GST_GL_WINDOW (window_cocoa);
|
GstGLWindow *window = GST_GL_WINDOW (window_cocoa);
|
||||||
|
|
|
@ -381,6 +381,27 @@ gst_gl_window_set_preferred_size (GstGLWindow * window, gint width, gint height)
|
||||||
window_class->set_preferred_size (window, width, height);
|
window_class->set_preferred_size (window, width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_gl_window_show:
|
||||||
|
* @window: a #GstGLWindow
|
||||||
|
*
|
||||||
|
* Present the window to the screen.
|
||||||
|
*
|
||||||
|
* Since: 1.6
|
||||||
|
*/
|
||||||
|
void
|
||||||
|
gst_gl_window_show (GstGLWindow * window)
|
||||||
|
{
|
||||||
|
GstGLWindowClass *window_class;
|
||||||
|
|
||||||
|
g_return_if_fail (GST_GL_IS_WINDOW (window));
|
||||||
|
window_class = GST_GL_WINDOW_GET_CLASS (window);
|
||||||
|
g_return_if_fail (window_class->show != NULL);
|
||||||
|
|
||||||
|
if (window_class->show)
|
||||||
|
window_class->show (window);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_gl_window_run:
|
* gst_gl_window_run:
|
||||||
* @window: a #GstGLWindow
|
* @window: a #GstGLWindow
|
||||||
|
|
|
@ -141,6 +141,7 @@ struct _GstGLWindowClass {
|
||||||
void (*get_surface_dimensions) (GstGLWindow *window, guint *width, guint *height);
|
void (*get_surface_dimensions) (GstGLWindow *window, guint *width, guint *height);
|
||||||
void (*handle_events) (GstGLWindow *window, gboolean handle_events);
|
void (*handle_events) (GstGLWindow *window, gboolean handle_events);
|
||||||
void (*set_preferred_size) (GstGLWindow *window, gint width, gint height);
|
void (*set_preferred_size) (GstGLWindow *window, gint width, gint height);
|
||||||
|
void (*show) (GstGLWindow *window);
|
||||||
|
|
||||||
/*< private >*/
|
/*< private >*/
|
||||||
gpointer _reserved[GST_PADDING];
|
gpointer _reserved[GST_PADDING];
|
||||||
|
@ -213,6 +214,7 @@ void gst_gl_window_send_mouse_event (GstGLWindow * window,
|
||||||
/* surfaces/rendering */
|
/* surfaces/rendering */
|
||||||
void gst_gl_window_draw_unlocked (GstGLWindow *window);
|
void gst_gl_window_draw_unlocked (GstGLWindow *window);
|
||||||
void gst_gl_window_draw (GstGLWindow *window);
|
void gst_gl_window_draw (GstGLWindow *window);
|
||||||
|
void gst_gl_window_show (GstGLWindow *window);
|
||||||
void gst_gl_window_set_preferred_size (GstGLWindow * window,
|
void gst_gl_window_set_preferred_size (GstGLWindow * window,
|
||||||
gint width,
|
gint width,
|
||||||
gint height);
|
gint height);
|
||||||
|
|
|
@ -63,6 +63,7 @@ static void gst_gl_window_win32_set_window_handle (GstGLWindow * window,
|
||||||
static guintptr gst_gl_window_win32_get_display (GstGLWindow * window);
|
static guintptr gst_gl_window_win32_get_display (GstGLWindow * window);
|
||||||
static void gst_gl_window_win32_set_preferred_size (GstGLWindow * window,
|
static void gst_gl_window_win32_set_preferred_size (GstGLWindow * window,
|
||||||
gint width, gint height);
|
gint width, gint height);
|
||||||
|
static void gst_gl_window_win32_show (GstGLWindow * window);
|
||||||
static void gst_gl_window_win32_draw (GstGLWindow * window);
|
static void gst_gl_window_win32_draw (GstGLWindow * window);
|
||||||
static void gst_gl_window_win32_run (GstGLWindow * window);
|
static void gst_gl_window_win32_run (GstGLWindow * window);
|
||||||
static void gst_gl_window_win32_quit (GstGLWindow * window);
|
static void gst_gl_window_win32_quit (GstGLWindow * window);
|
||||||
|
@ -88,6 +89,7 @@ gst_gl_window_win32_class_init (GstGLWindowWin32Class * klass)
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_win32_get_display);
|
GST_DEBUG_FUNCPTR (gst_gl_window_win32_get_display);
|
||||||
window_class->set_preferred_size =
|
window_class->set_preferred_size =
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_win32_set_preferred_size);
|
GST_DEBUG_FUNCPTR (gst_gl_window_win32_set_preferred_size);
|
||||||
|
window_class->show = GST_DEBUG_FUNCPTR (gst_gl_window_win32_show);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -263,23 +265,10 @@ gst_gl_window_win32_set_window_handle (GstGLWindow * window, guintptr id)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_gl_window_win32_set_preferred_size (GstGLWindow * window, gint width,
|
gst_gl_window_win32_show (GstGLWindow * window)
|
||||||
gint height)
|
|
||||||
{
|
{
|
||||||
GstGLWindowWin32 *window_win32 = GST_GL_WINDOW_WIN32 (window);
|
GstGLWindowWin32 *window_win32 = GST_GL_WINDOW_WIN32 (window);
|
||||||
|
|
||||||
window_win32->priv->preferred_width = width;
|
|
||||||
window_win32->priv->preferred_height = height;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Thread safe */
|
|
||||||
static void
|
|
||||||
gst_gl_window_win32_draw (GstGLWindow * window)
|
|
||||||
{
|
|
||||||
GstGLWindowWin32 *window_win32 = GST_GL_WINDOW_WIN32 (window);
|
|
||||||
gint width = window_win32->priv->preferred_width;
|
|
||||||
gint height = window_win32->priv->preferred_height;
|
|
||||||
|
|
||||||
if (!window_win32->visible) {
|
if (!window_win32->visible) {
|
||||||
HWND parent_id = window_win32->parent_win_id;
|
HWND parent_id = window_win32->parent_win_id;
|
||||||
|
|
||||||
|
@ -295,10 +284,29 @@ gst_gl_window_win32_draw (GstGLWindow * window)
|
||||||
MoveWindow (window_win32->internal_win_id, rect.left, rect.top, width,
|
MoveWindow (window_win32->internal_win_id, rect.left, rect.top, width,
|
||||||
height, FALSE);
|
height, FALSE);
|
||||||
}
|
}
|
||||||
ShowWindowAsync (window_win32->internal_win_id, SW_SHOW);
|
|
||||||
|
|
||||||
|
ShowWindowAsync (window_win32->internal_win_id, SW_SHOW);
|
||||||
window_win32->visible = TRUE;
|
window_win32->visible = TRUE;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_gl_window_win32_set_preferred_size (GstGLWindow * window, gint width,
|
||||||
|
gint height)
|
||||||
|
{
|
||||||
|
GstGLWindowWin32 *window_win32 = GST_GL_WINDOW_WIN32 (window);
|
||||||
|
|
||||||
|
window_win32->priv->preferred_width = width;
|
||||||
|
window_win32->priv->preferred_height = height;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Thread safe */
|
||||||
|
static void
|
||||||
|
gst_gl_window_win32_draw (GstGLWindow * window)
|
||||||
|
{
|
||||||
|
GstGLWindowWin32 *window_win32 = GST_GL_WINDOW_WIN32 (window);
|
||||||
|
gint width = window_win32->priv->preferred_width;
|
||||||
|
gint height = window_win32->priv->preferred_height;
|
||||||
|
|
||||||
RedrawWindow (window_win32->internal_win_id, NULL, NULL,
|
RedrawWindow (window_win32->internal_win_id, NULL, NULL,
|
||||||
RDW_NOERASE | RDW_INTERNALPAINT | RDW_INVALIDATE);
|
RDW_NOERASE | RDW_INTERNALPAINT | RDW_INVALIDATE);
|
||||||
|
|
|
@ -71,6 +71,7 @@ void gst_gl_window_x11_set_window_handle (GstGLWindow * window,
|
||||||
guintptr gst_gl_window_x11_get_window_handle (GstGLWindow * window);
|
guintptr gst_gl_window_x11_get_window_handle (GstGLWindow * window);
|
||||||
static void gst_gl_window_x11_set_preferred_size (GstGLWindow * window,
|
static void gst_gl_window_x11_set_preferred_size (GstGLWindow * window,
|
||||||
gint width, gint height);
|
gint width, gint height);
|
||||||
|
void gst_gl_window_x11_show (GstGLWindow * window);
|
||||||
void gst_gl_window_x11_draw_unlocked (GstGLWindow * window);
|
void gst_gl_window_x11_draw_unlocked (GstGLWindow * window);
|
||||||
void gst_gl_window_x11_draw (GstGLWindow * window);
|
void gst_gl_window_x11_draw (GstGLWindow * window);
|
||||||
void gst_gl_window_x11_run (GstGLWindow * window);
|
void gst_gl_window_x11_run (GstGLWindow * window);
|
||||||
|
@ -123,6 +124,7 @@ gst_gl_window_x11_class_init (GstGLWindowX11Class * klass)
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_x11_handle_events);
|
GST_DEBUG_FUNCPTR (gst_gl_window_x11_handle_events);
|
||||||
window_class->set_preferred_size =
|
window_class->set_preferred_size =
|
||||||
GST_DEBUG_FUNCPTR (gst_gl_window_x11_set_preferred_size);
|
GST_DEBUG_FUNCPTR (gst_gl_window_x11_set_preferred_size);
|
||||||
|
window_class->show = GST_DEBUG_FUNCPTR (gst_gl_window_x11_show);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -371,6 +373,37 @@ gst_gl_window_x11_set_preferred_size (GstGLWindow * window, gint width,
|
||||||
window_x11->priv->preferred_height = height;
|
window_x11->priv->preferred_height = height;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
_show_window (GstGLWindow * window)
|
||||||
|
{
|
||||||
|
GstGLWindowX11 *window_x11 = GST_GL_WINDOW_X11 (window);
|
||||||
|
guint width = window_x11->priv->preferred_width;
|
||||||
|
guint height = window_x11->priv->preferred_height;
|
||||||
|
XWindowAttributes attr;
|
||||||
|
|
||||||
|
XGetWindowAttributes (window_x11->device, window_x11->internal_win_id, &attr);
|
||||||
|
|
||||||
|
if (!window_x11->visible) {
|
||||||
|
|
||||||
|
if (!window_x11->parent_win) {
|
||||||
|
attr.width = width;
|
||||||
|
attr.height = height;
|
||||||
|
XResizeWindow (window_x11->device, window_x11->internal_win_id,
|
||||||
|
attr.width, attr.height);
|
||||||
|
XSync (window_x11->device, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
|
XMapWindow (window_x11->device, window_x11->internal_win_id);
|
||||||
|
window_x11->visible = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
gst_gl_window_x11_show (GstGLWindow * window)
|
||||||
|
{
|
||||||
|
gst_gl_window_send_message (window, (GstGLWindowCB) _show_window, window);
|
||||||
|
}
|
||||||
|
|
||||||
/* Called in the gl thread */
|
/* Called in the gl thread */
|
||||||
void
|
void
|
||||||
gst_gl_window_x11_draw_unlocked (GstGLWindow * window)
|
gst_gl_window_x11_draw_unlocked (GstGLWindow * window)
|
||||||
|
@ -397,8 +430,6 @@ static void
|
||||||
draw_cb (gpointer data)
|
draw_cb (gpointer data)
|
||||||
{
|
{
|
||||||
GstGLWindowX11 *window_x11 = data;
|
GstGLWindowX11 *window_x11 = data;
|
||||||
guint width = window_x11->priv->preferred_width;
|
|
||||||
guint height = window_x11->priv->preferred_height;
|
|
||||||
|
|
||||||
if (g_main_loop_is_running (window_x11->loop)) {
|
if (g_main_loop_is_running (window_x11->loop)) {
|
||||||
XWindowAttributes attr;
|
XWindowAttributes attr;
|
||||||
|
@ -406,20 +437,6 @@ draw_cb (gpointer data)
|
||||||
XGetWindowAttributes (window_x11->device, window_x11->internal_win_id,
|
XGetWindowAttributes (window_x11->device, window_x11->internal_win_id,
|
||||||
&attr);
|
&attr);
|
||||||
|
|
||||||
if (!window_x11->visible) {
|
|
||||||
|
|
||||||
if (!window_x11->parent_win) {
|
|
||||||
attr.width = width;
|
|
||||||
attr.height = height;
|
|
||||||
XResizeWindow (window_x11->device, window_x11->internal_win_id,
|
|
||||||
attr.width, attr.height);
|
|
||||||
XSync (window_x11->device, FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
XMapWindow (window_x11->device, window_x11->internal_win_id);
|
|
||||||
window_x11->visible = TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (window_x11->parent_win) {
|
if (window_x11->parent_win) {
|
||||||
XWindowAttributes attr_parent;
|
XWindowAttributes attr_parent;
|
||||||
XGetWindowAttributes (window_x11->device, window_x11->parent_win,
|
XGetWindowAttributes (window_x11->device, window_x11->parent_win,
|
||||||
|
|
Loading…
Reference in a new issue