mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 05:59:10 +00:00
sys/ximage/ximagesink.*: assorted fixes to make (re)embedding work
Original commit message from CVS: 2004-01-04 Benjamin Otte <in7y118@public.uni-hamburg.de> * sys/ximage/ximagesink.h: * sys/ximage/ximagesink.c: (gst_ximagesink_xwindow_new), (gst_ximagesink_xwindow_destroy), (gst_ximagesink_sinkconnect), (gst_ximagesink_change_state), (gst_ximagesink_set_xwindow_id), (gst_ximagesink_xoverlay_init): assorted fixes to make (re)embedding work * sys/ximage/ximagesink.c: (gst_ximagesink_sinkconnect), (gst_ximagesink_get_desired_size): implement desired size additions to XOverlay
This commit is contained in:
parent
5e15a670e8
commit
408cd46e50
3 changed files with 52 additions and 30 deletions
12
ChangeLog
12
ChangeLog
|
@ -1,3 +1,15 @@
|
||||||
|
2004-01-04 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||||
|
|
||||||
|
* sys/ximage/ximagesink.h:
|
||||||
|
* sys/ximage/ximagesink.c: (gst_ximagesink_xwindow_new),
|
||||||
|
(gst_ximagesink_xwindow_destroy), (gst_ximagesink_sinkconnect),
|
||||||
|
(gst_ximagesink_change_state), (gst_ximagesink_set_xwindow_id),
|
||||||
|
(gst_ximagesink_xoverlay_init):
|
||||||
|
assorted fixes to make (re)embedding work
|
||||||
|
* sys/ximage/ximagesink.c: (gst_ximagesink_sinkconnect),
|
||||||
|
(gst_ximagesink_get_desired_size):
|
||||||
|
implement desired size additions to XOverlay
|
||||||
|
|
||||||
2004-01-04 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
2004-01-04 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||||
|
|
||||||
* gst-libs/gst/xoverlay/xoverlay.c: (gst_x_overlay_base_init),
|
* gst-libs/gst/xoverlay/xoverlay.c: (gst_x_overlay_base_init),
|
||||||
|
|
|
@ -216,15 +216,19 @@ gst_ximagesink_xwindow_new (GstXImageSink *ximagesink, gint width, gint height)
|
||||||
|
|
||||||
xwindow->width = width;
|
xwindow->width = width;
|
||||||
xwindow->height = height;
|
xwindow->height = height;
|
||||||
xwindow->internal = TRUE;
|
|
||||||
|
|
||||||
g_mutex_lock (ximagesink->x_lock);
|
g_mutex_lock (ximagesink->x_lock);
|
||||||
|
|
||||||
xwindow->win = XCreateSimpleWindow (ximagesink->xcontext->disp,
|
if (ximagesink->embed_into == 0) {
|
||||||
ximagesink->xcontext->root,
|
xwindow->win = XCreateSimpleWindow (ximagesink->xcontext->disp,
|
||||||
0, 0, xwindow->width, xwindow->height,
|
ximagesink->xcontext->root,
|
||||||
0, 0, ximagesink->xcontext->black);
|
0, 0, xwindow->width, xwindow->height,
|
||||||
|
0, 0, ximagesink->xcontext->black);
|
||||||
|
|
||||||
|
XMapRaised (ximagesink->xcontext->disp, xwindow->win);
|
||||||
|
} else {
|
||||||
|
xwindow->win = ximagesink->embed_into;
|
||||||
|
}
|
||||||
XSelectInput (ximagesink->xcontext->disp, xwindow->win, ExposureMask |
|
XSelectInput (ximagesink->xcontext->disp, xwindow->win, ExposureMask |
|
||||||
StructureNotifyMask | PointerMotionMask | KeyPressMask |
|
StructureNotifyMask | PointerMotionMask | KeyPressMask |
|
||||||
KeyReleaseMask | ButtonPressMask | ButtonReleaseMask);
|
KeyReleaseMask | ButtonPressMask | ButtonReleaseMask);
|
||||||
|
@ -232,7 +236,6 @@ gst_ximagesink_xwindow_new (GstXImageSink *ximagesink, gint width, gint height)
|
||||||
xwindow->gc = XCreateGC (ximagesink->xcontext->disp,
|
xwindow->gc = XCreateGC (ximagesink->xcontext->disp,
|
||||||
xwindow->win, 0, NULL);
|
xwindow->win, 0, NULL);
|
||||||
|
|
||||||
XMapRaised (ximagesink->xcontext->disp, xwindow->win);
|
|
||||||
|
|
||||||
g_mutex_unlock (ximagesink->x_lock);
|
g_mutex_unlock (ximagesink->x_lock);
|
||||||
|
|
||||||
|
@ -250,8 +253,11 @@ gst_ximagesink_xwindow_destroy (GstXImageSink *ximagesink, GstXWindow *xwindow)
|
||||||
g_mutex_lock (ximagesink->x_lock);
|
g_mutex_lock (ximagesink->x_lock);
|
||||||
|
|
||||||
/* If we did not create that window we just free the GC and let it live */
|
/* If we did not create that window we just free the GC and let it live */
|
||||||
if (xwindow->internal)
|
if (ximagesink->embed_into == 0) {
|
||||||
XDestroyWindow (ximagesink->xcontext->disp, xwindow->win);
|
XDestroyWindow (ximagesink->xcontext->disp, xwindow->win);
|
||||||
|
} else {
|
||||||
|
XSelectInput (ximagesink->xcontext->disp, xwindow->win, 0);
|
||||||
|
}
|
||||||
|
|
||||||
XFreeGC (ximagesink->xcontext->disp, xwindow->gc);
|
XFreeGC (ximagesink->xcontext->disp, xwindow->gc);
|
||||||
|
|
||||||
|
@ -609,6 +615,9 @@ gst_ximagesink_sinkconnect (GstPad *pad, const GstCaps *caps)
|
||||||
GST_VIDEOSINK_WIDTH (ximagesink),
|
GST_VIDEOSINK_WIDTH (ximagesink),
|
||||||
GST_VIDEOSINK_HEIGHT (ximagesink));
|
GST_VIDEOSINK_HEIGHT (ximagesink));
|
||||||
|
|
||||||
|
gst_x_overlay_got_desired_size (GST_X_OVERLAY (ximagesink),
|
||||||
|
GST_VIDEOSINK_WIDTH (ximagesink),
|
||||||
|
GST_VIDEOSINK_HEIGHT (ximagesink));
|
||||||
gst_video_sink_got_video_size (GST_VIDEOSINK (ximagesink),
|
gst_video_sink_got_video_size (GST_VIDEOSINK (ximagesink),
|
||||||
GST_VIDEOSINK_WIDTH (ximagesink),
|
GST_VIDEOSINK_WIDTH (ximagesink),
|
||||||
GST_VIDEOSINK_HEIGHT (ximagesink));
|
GST_VIDEOSINK_HEIGHT (ximagesink));
|
||||||
|
@ -638,6 +647,8 @@ gst_ximagesink_change_state (GstElement *element)
|
||||||
case GST_STATE_PLAYING_TO_PAUSED:
|
case GST_STATE_PLAYING_TO_PAUSED:
|
||||||
break;
|
break;
|
||||||
case GST_STATE_PAUSED_TO_READY:
|
case GST_STATE_PAUSED_TO_READY:
|
||||||
|
GST_VIDEOSINK_WIDTH (ximagesink) = 0;
|
||||||
|
GST_VIDEOSINK_HEIGHT (ximagesink) = 0;
|
||||||
break;
|
break;
|
||||||
case GST_STATE_READY_TO_NULL:
|
case GST_STATE_READY_TO_NULL:
|
||||||
break;
|
break;
|
||||||
|
@ -880,12 +891,13 @@ static void
|
||||||
gst_ximagesink_set_xwindow_id (GstXOverlay *overlay, XID xwindow_id)
|
gst_ximagesink_set_xwindow_id (GstXOverlay *overlay, XID xwindow_id)
|
||||||
{
|
{
|
||||||
GstXImageSink *ximagesink = GST_XIMAGESINK (overlay);
|
GstXImageSink *ximagesink = GST_XIMAGESINK (overlay);
|
||||||
GstXWindow *xwindow = NULL;
|
|
||||||
XWindowAttributes attr;
|
|
||||||
|
|
||||||
g_return_if_fail (ximagesink != NULL);
|
g_return_if_fail (ximagesink != NULL);
|
||||||
g_return_if_fail (GST_IS_XIMAGESINK (ximagesink));
|
g_return_if_fail (GST_IS_XIMAGESINK (ximagesink));
|
||||||
|
|
||||||
|
if (ximagesink->embed_into == xwindow_id)
|
||||||
|
return;
|
||||||
|
|
||||||
if (!ximagesink->xcontext)
|
if (!ximagesink->xcontext)
|
||||||
{
|
{
|
||||||
ximagesink->xcontext = gst_ximagesink_xcontext_get (ximagesink);
|
ximagesink->xcontext = gst_ximagesink_xcontext_get (ximagesink);
|
||||||
|
@ -899,31 +911,28 @@ gst_ximagesink_set_xwindow_id (GstXOverlay *overlay, XID xwindow_id)
|
||||||
gst_ximagesink_xwindow_destroy (ximagesink, ximagesink->xwindow);
|
gst_ximagesink_xwindow_destroy (ximagesink, ximagesink->xwindow);
|
||||||
}
|
}
|
||||||
|
|
||||||
xwindow = g_new0 (GstXWindow, 1);
|
ximagesink->embed_into = xwindow_id;
|
||||||
|
|
||||||
xwindow->win = xwindow_id;
|
ximagesink->xwindow = gst_ximagesink_xwindow_new (ximagesink, GST_VIDEOSINK_WIDTH (ximagesink), GST_VIDEOSINK_HEIGHT (ximagesink));
|
||||||
|
ximagesink->ximage = gst_ximagesink_ximage_new (ximagesink,
|
||||||
|
GST_VIDEOSINK_WIDTH (ximagesink), GST_VIDEOSINK_HEIGHT (ximagesink));
|
||||||
|
gst_x_overlay_got_xwindow_id (overlay, xwindow_id);
|
||||||
|
}
|
||||||
|
|
||||||
/* We get window geometry, set the event we want to receive, and create a GC */
|
static void
|
||||||
g_mutex_lock (ximagesink->x_lock);
|
gst_ximagesink_get_desired_size (GstXOverlay *overlay, guint *width, guint *height)
|
||||||
XGetWindowAttributes (ximagesink->xcontext->disp, xwindow->win, &attr);
|
{
|
||||||
xwindow->width = attr.width;
|
GstXImageSink *ximagesink = GST_XIMAGESINK (overlay);
|
||||||
xwindow->height = attr.height;
|
|
||||||
xwindow->internal = FALSE;
|
|
||||||
XSelectInput (ximagesink->xcontext->disp, xwindow->win, ExposureMask |
|
|
||||||
StructureNotifyMask | PointerMotionMask | KeyPressMask |
|
|
||||||
KeyReleaseMask);
|
|
||||||
|
|
||||||
xwindow->gc = XCreateGC (ximagesink->xcontext->disp,
|
*width = GST_VIDEOSINK_WIDTH (ximagesink);
|
||||||
xwindow->win, 0, NULL);
|
*height = GST_VIDEOSINK_HEIGHT (ximagesink);
|
||||||
g_mutex_unlock (ximagesink->x_lock);
|
|
||||||
|
|
||||||
ximagesink->xwindow = xwindow;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_ximagesink_xoverlay_init (GstXOverlayClass *iface)
|
gst_ximagesink_xoverlay_init (GstXOverlayClass *iface)
|
||||||
{
|
{
|
||||||
iface->set_xwindow_id = gst_ximagesink_set_xwindow_id;
|
iface->set_xwindow_id = gst_ximagesink_set_xwindow_id;
|
||||||
|
iface->get_desired_size = gst_ximagesink_get_desired_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* =========================================== */
|
/* =========================================== */
|
||||||
|
|
|
@ -83,7 +83,6 @@ struct _GstXContext {
|
||||||
struct _GstXWindow {
|
struct _GstXWindow {
|
||||||
Window win;
|
Window win;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
gboolean internal;
|
|
||||||
GC gc;
|
GC gc;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -103,6 +102,8 @@ struct _GstXImageSink {
|
||||||
/* Our element stuff */
|
/* Our element stuff */
|
||||||
GstVideoSink videosink;
|
GstVideoSink videosink;
|
||||||
|
|
||||||
|
XID embed_into;
|
||||||
|
|
||||||
GstXContext *xcontext;
|
GstXContext *xcontext;
|
||||||
GstXWindow *xwindow;
|
GstXWindow *xwindow;
|
||||||
GstXImage *ximage;
|
GstXImage *ximage;
|
||||||
|
|
Loading…
Reference in a new issue