X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=openbox%2Fframe.c;h=55fe98f8d0db77484fef68c546b5aece6818ccfd;hb=9d593db034fc2f5f662f7a1502d6a64536ced014;hp=8f947e49d49e289aea1bf48f2564b899fe0cdf43;hpb=7d3e3ff6dfda1fa87165d9823e47cd2c9dd9f57e;p=chaz%2Fopenbox diff --git a/openbox/frame.c b/openbox/frame.c index 8f947e49..55fe98f8 100644 --- a/openbox/frame.c +++ b/openbox/frame.c @@ -27,7 +27,6 @@ #include "mainloop.h" #include "focus_cycle.h" #include "focus_cycle_indicator.h" -#include "composite.h" #include "moveresize.h" #include "screen.h" #include "render/theme.h" @@ -52,8 +51,6 @@ static void set_theme_statics(ObFrame *self); static void free_theme_statics(ObFrame *self); static gboolean frame_animate_iconify(gpointer self); static void frame_adjust_cursors(ObFrame *self); -static void frame_get_offscreen_buffer(ObFrame *self); -static void frame_free_offscreen_buffer(ObFrame *self); static Window createWindow(Window parent, Visual *visual, gulong mask, XSetWindowAttributes *attrib) @@ -65,46 +62,58 @@ static Window createWindow(Window parent, Visual *visual, } +static Visual *check_32bit_client(ObClient *c) +{ + XWindowAttributes wattrib; + Status ret; + + /* we're already running at 32 bit depth, yay. we don't need to use their + visual */ + if (RrDepth(ob_rr_inst) == 32) + return NULL; + + ret = XGetWindowAttributes(ob_display, c->window, &wattrib); + g_assert(ret != BadDrawable); + g_assert(ret != BadWindow); + + if (wattrib.depth == 32) + return wattrib.visual; + return NULL; +} + ObFrame *frame_new(ObClient *client) { XSetWindowAttributes attrib; gulong mask; ObFrame *self; - XWindowAttributes wattrib; - Status ret; + Visual *visual; self = g_new0(ObFrame, 1); self->client = client; - ret = XGetWindowAttributes(ob_display, client->window, &wattrib); - g_assert(ret != BadDrawable); - g_assert(ret != BadWindow); - self->has_alpha = composite_window_has_alpha(wattrib.visual); + visual = check_32bit_client(client); /* create the non-visible decor windows */ mask = 0; - if (self->has_alpha) { - /* the colormap/backpixel/borderpixel are required for supporting - windows with 32bit visuals */ - mask = CWColormap | CWBackPixel | CWBorderPixel; + if (visual) { + /* client has a 32-bit visual */ + mask |= CWColormap | CWBackPixel | CWBorderPixel; /* create a colormap with the visual */ self->colormap = attrib.colormap = XCreateColormap(ob_display, RootWindow(ob_display, ob_screen), - wattrib.visual, AllocNone); + visual, AllocNone); attrib.background_pixel = BlackPixel(ob_display, ob_screen); attrib.border_pixel = BlackPixel(ob_display, ob_screen); } - - self->window = createWindow(RootWindow(ob_display, ob_screen), - (self->has_alpha ? wattrib.visual : NULL), + self->window = createWindow(RootWindow(ob_display, ob_screen), visual, mask, &attrib); /* create the visible decor windows */ mask = 0; - if (self->has_alpha) { + if (visual) { /* client has a 32-bit visual */ mask |= CWColormap | CWBackPixel | CWBorderPixel; attrib.colormap = RrColormap(ob_rr_inst); @@ -231,7 +240,6 @@ void frame_free(ObFrame *self) XDestroyWindow(ob_display, self->window); if (self->colormap) XFreeColormap(ob_display, self->colormap); - frame_free_offscreen_buffer(self); g_free(self); } @@ -243,8 +251,6 @@ void frame_show(ObFrame *self) framerender_frame(self); XMapWindow(ob_display, self->client->window); XMapWindow(ob_display, self->window); - - frame_get_offscreen_buffer(self); } } @@ -254,7 +260,6 @@ void frame_hide(ObFrame *self) self->visible = FALSE; if (!frame_iconify_animating(self)) XUnmapWindow(ob_display, self->window); - /* we unmap the client itself so that we can get MapRequest events, and because the ICCCM tells us to! */ XUnmapWindow(ob_display, self->client->window); @@ -313,9 +318,6 @@ void frame_adjust_shape(ObFrame *self) ShapeUnion, Unsorted); } #endif - - /* the offscreen buffer's shape needs to match */ - frame_get_offscreen_buffer(self); } void frame_adjust_area(ObFrame *self, gboolean moved, @@ -366,8 +368,8 @@ void frame_adjust_area(ObFrame *self, gboolean moved, self->cbwidth_l + (!self->max_horz ? self->bwidth : 0), self->cbwidth_t + self->bwidth, self->cbwidth_r + (!self->max_horz ? self->bwidth : 0), - self->cbwidth_b + (!self->max_horz || !self->max_vert ? - self->bwidth : 0)); + self->cbwidth_b + + (!self->max_horz || !self->max_vert ? self->bwidth : 0)); if (self->decorations & OB_FRAME_DECOR_TITLEBAR) self->size.top += ob_rr_theme->title_height + self->bwidth; @@ -724,8 +726,8 @@ void frame_adjust_area(ObFrame *self, gboolean moved, if (self->bwidth && !self->max_horz) { XMoveResizeWindow(ob_display, self->right, - self->client->area.width + - self->cbwidth_l + self->cbwidth_r + self->bwidth, + self->client->area.width + self->cbwidth_l + + self->cbwidth_r + self->bwidth, self->bwidth + ob_rr_theme->grip_width, self->bwidth, self->client->area.height + @@ -757,9 +759,7 @@ void frame_adjust_area(ObFrame *self, gboolean moved, frame_client_gravity. */ self->area.x = self->client->area.x; self->area.y = self->client->area.y; - frame_client_gravity(self, &self->area.x, &self->area.y, - self->client->area.width, - self->client->area.height); + frame_client_gravity(self, &self->area.x, &self->area.y); } if (!fake) { @@ -786,7 +786,6 @@ void frame_adjust_area(ObFrame *self, gboolean moved, if (resized) { self->need_render = TRUE; framerender_frame(self); - /* this also updates the offscreen buffer */ frame_adjust_shape(self); } @@ -918,9 +917,6 @@ void frame_grab_client(ObFrame *self) /* reparent the client to the frame */ XReparentWindow(ob_display, self->client->window, self->window, 0, 0); - /* enable the offscreen composite buffer for the client window */ - composite_enable_for_window(self->client->window); - /* When reparenting the client window, it is usually not mapped yet, since this occurs from a MapRequest. However, in the case where Openbox is @@ -1404,7 +1400,7 @@ ObFrameContext frame_context(ObClient *client, Window win, gint x, gint y) return OB_FRAME_CONTEXT_NONE; } -void frame_client_gravity(ObFrame *self, gint *x, gint *y, gint w, gint h) +void frame_client_gravity(ObFrame *self, gint *x, gint *y) { /* horizontal */ switch (self->client->gravity) { @@ -1467,7 +1463,7 @@ void frame_client_gravity(ObFrame *self, gint *x, gint *y, gint w, gint h) } } -void frame_frame_gravity(ObFrame *self, gint *x, gint *y, gint w, gint h) +void frame_frame_gravity(ObFrame *self, gint *x, gint *y) { /* horizontal */ switch (self->client->gravity) { @@ -1528,7 +1524,7 @@ void frame_rect_to_frame(ObFrame *self, Rect *r) { r->width += self->size.left + self->size.right; r->height += self->size.top + self->size.bottom; - frame_client_gravity(self, &r->x, &r->y, r->width, r->height); + frame_client_gravity(self, &r->x, &r->y); } static void flash_done(gpointer data) @@ -1677,11 +1673,11 @@ void frame_end_iconify_animation(ObFrame *self) XUnmapWindow(ob_display, self->window); else { /* Send a ConfigureNotify when the animation is done, this fixes - KDE's pager showing the window in the wrong place. */ + KDE's pager showing the window in the wrong place. since the + window is mapped at a different location and is then moved, we + need to send the synthetic configurenotify, since apps may have + read the position when the client mapped, apparently. */ client_reconfigure(self->client, TRUE); - - /* the offscreen buffer is invalid when the window is resized */ - frame_get_offscreen_buffer(self); } /* we're not animating any more ! */ @@ -1746,34 +1742,3 @@ void frame_begin_iconify_animation(ObFrame *self, gboolean iconifying) XMapWindow(ob_display, self->window); } } - -static void frame_get_offscreen_buffer(ObFrame *self) -{ - frame_free_offscreen_buffer(self); - - if (self->visible || frame_iconify_animating(self)) { - self->pixmap = composite_get_window_pixmap(self->client->window); - -#ifdef SHAPE - /* shape the offscreen buffer to match the window */ - XShapeCombineShape(ob_display, self->pixmap, ShapeBounding, - 0, 0, self->client->window, - ShapeBounding, ShapeSet); -#endif - - /* - self->picture = composite_create_picture(self->window, - wattrib.visual, - &self->has_alpha); - */ - } - -} - -static void frame_free_offscreen_buffer(ObFrame *self) -{ - if (self->pixmap) { - XFreePixmap(ob_display, self->pixmap); - self->pixmap = None; - } -}