From 219e97bda3a6675cc2d534a8420fab98a7699a8d Mon Sep 17 00:00:00 2001 From: Emmanuele Bassi Date: Tue, 27 Mar 2007 09:38:50 +0000 Subject: [PATCH] Reimplement the clutter_glx_set_stage_foreign() function, used to set an existing X window as the window for the main stage. --- ChangeLog | 6 ++++ clutter/glx/clutter-glx.h | 4 +-- clutter/glx/clutter-stage-glx.c | 62 ++++++++++++++++++++++++++++++--- 3 files changed, 66 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index d79571a62..67efaffdd 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +2007-03-27 Emmanuele Bassi + + * clutter/glx/clutter-glx.h: + * clutter/glx/clutter-stage-glx.c: (Re-)Implement the foreign + window setting function for the stage in the GLX backend. + 2007-03-27 Emmanuele Bassi * clutter/clutter-stage.h: Declare the clutter_perspective_get_type() diff --git a/clutter/glx/clutter-glx.h b/clutter/glx/clutter-glx.h index ef4e90bb3..bc12e8b8f 100644 --- a/clutter/glx/clutter-glx.h +++ b/clutter/glx/clutter-glx.h @@ -43,8 +43,8 @@ Window clutter_glx_get_root_window (void); Window clutter_glx_get_stage_window (ClutterStage *stage); XVisualInfo *clutter_glx_get_stage_visual (ClutterStage *stage); -void clutter_glx_set_stage_foreign (ClutterStage *stage, - Window window); +gboolean clutter_glx_set_stage_foreign (ClutterStage *stage, + Window xwindow); G_END_DECLS diff --git a/clutter/glx/clutter-stage-glx.c b/clutter/glx/clutter-stage-glx.c index d500b8b69..a284941bb 100644 --- a/clutter/glx/clutter-stage-glx.c +++ b/clutter/glx/clutter-stage-glx.c @@ -636,11 +636,65 @@ clutter_glx_get_stage_visual (ClutterStage *stage) return CLUTTER_STAGE_GLX (stage)->xvisinfo; } -void +/** + * clutter_glx_set_stage_foreign: + * @stage: a #ClutterStage + * @xwindow: an existing X Window id + * + * Target the #ClutterStage to use an existing external X Window + * + * Return value: %TRUE if foreign window is valid + * + * Since: 0.4 + */ +gboolean clutter_glx_set_stage_foreign (ClutterStage *stage, - Window window) + Window xwindow) { - g_return_if_fail (CLUTTER_IS_STAGE_GLX (stage)); + ClutterStageGlx *stage_glx; + ClutterActor *actor; + gint x, y; + guint width, height, border, depth; + Window root_return; + Status status; + ClutterGeometry geom; - /* FIXME */ + g_return_val_if_fail (CLUTTER_IS_STAGE_GLX (stage), FALSE); + g_return_val_if_fail (xwindow != None, FALSE); + + stage_glx = CLUTTER_STAGE_GLX (stage); + actor = CLUTTER_ACTOR (stage); + + clutter_glx_trap_x_errors (); + + status = XGetGeometry (stage_glx->xdpy, + xwindow, + &root_return, + &x, &y, + &width, &height, + &border, + &depth); + + if (clutter_glx_untrap_x_errors () || + !status || + width == 0 || height == 0 || + depth != stage_glx->xvisinfo->depth) + { + return FALSE; + } + + clutter_actor_unrealize (actor); + + stage_glx->xwin = xwindow; + stage_glx->is_foreign_xwin = TRUE; + + geom.x = x; + geom.y = y; + geom.width = stage_glx->xwin_width = width; + geom.height = stage_glx->xwin_height = height; + + clutter_actor_set_geometry (actor, &geom); + clutter_actor_realize (actor); + + return TRUE; }