1 Submitted By: Oliver Brakmann <obrakmann AT gmx DOT net>
3 Initial Package version: Windowmaker 0.91.0
4 Origin: http://vlaadworld.net/
5 Description: Adds translucency to Windowmaker menus. To set the level of
6 translucency, start WPrefs.app and select 'Apperance
7 Preferences -> Options -> Transparency'
9 diff -Naur WindowMaker-0.91.0-orig/WPrefs.app/Appearance.c WindowMaker-0.91.0/WPrefs.app/Appearance.c
10 --- WindowMaker-0.91.0-orig/WPrefs.app/Appearance.c 2004-10-26 18:34:28.000000000 +0200
11 +++ WindowMaker-0.91.0/WPrefs.app/Appearance.c 2004-10-26 18:40:51.000000000 +0200
24 @@ -1714,6 +1719,23 @@
29 +tranceCallback(WMWidget *self, void *data)
31 + _Panel *panel = (_Panel*)data;
35 + i = WMGetSliderValue(panel->tranceSl);
39 + WMSetLabelText(panel->tranceL, "OFF");
41 + sprintf(buffer, "%i%%", i);
42 + WMSetLabelText(panel->tranceL, buffer);
51 panel->taliF = WMCreateFrame(panel->optF);
52 - WMResizeWidget(panel->taliF, 110, 80);
53 + WMResizeWidget(panel->taliF, 105, 80);
54 WMMoveWidget(panel->taliF, 15, 100);
55 WMSetFrameTitle(panel->taliF, _("Title Alignment"));
58 WMSetButtonText(panel->taliB[i], _("Right"));
61 - WMResizeWidget(panel->taliB[i], 90, 18);
62 + WMResizeWidget(panel->taliB[i], 85, 18);
63 WMMoveWidget(panel->taliB[i], 10, 15 + 20*i);
65 WMGroupButtons(panel->taliB[0], panel->taliB[1]);
66 @@ -2031,6 +2053,36 @@
68 WMMapSubwidgets(panel->taliF);
70 + panel->tranceF = WMCreateFrame(panel->optF);
71 + WMResizeWidget(panel->tranceF, 105,80);
72 + WMMoveWidget(panel->tranceF, 125, 100);
73 + WMSetFrameTitle(panel->tranceF,_("Transparency"));
75 + WMSetBalloonTextForView(_("<yermom> i love windowmaker\n"
76 + "<tarzeau> get some fresh sand-wich-es\n"
78 + "<flip-> transparency\n"
80 + "<flip-> :P\n"), WMWidgetView(panel->tranceF));
82 + panel->tranceB = WMCreateSwitchButton(panel->tranceF);
83 + WMSetButtonText(panel->tranceB, _("Menu"));
84 + WMResizeWidget(panel->tranceB,85,18);
85 + WMMoveWidget(panel->tranceB, 10, 15);
87 + panel->tranceSl = WMCreateSlider(panel->tranceF);
88 + WMResizeWidget(panel->tranceSl, 70, 18);
89 + WMMoveWidget(panel->tranceSl, 17, 15 + 20*2);
90 + WMSetSliderMinValue(panel->tranceSl, 0);
91 + WMSetSliderMaxValue(panel->tranceSl, 10);
92 + WMSetSliderAction(panel->tranceSl, tranceCallback, panel);
94 + panel->tranceL = WMCreateLabel(panel->tranceF);
95 + WMResizeWidget(panel->tranceL, 27, 18);
96 + WMMoveWidget(panel->tranceL, 40, 35);
98 + WMMapSubwidgets(panel->tranceF);
100 WMMapSubwidgets(panel->optF);
103 @@ -2089,6 +2141,7 @@
105 showData(_Panel *panel)
111 @@ -2134,6 +2187,13 @@
113 WMSetButtonSelected(panel->mstyB[panel->menuStyle], True);
114 WMSetButtonSelected(panel->taliB[panel->titleAlignment], True);
117 + WMSetButtonSelected(panel->tranceB, GetBoolForKey("MenuTrance"));
119 + x = GetIntegerForKey("TranceAmount");
120 + WMSetSliderValue(panel->tranceSl, x);
121 + tranceCallback(NULL, panel);
125 @@ -2185,6 +2245,9 @@
126 SetStringForKey("center", "TitleJustify");
130 + SetBoolForKey(WMGetButtonSelected(panel->tranceB), "MenuTrance");
131 + SetIntegerForKey(WMGetSliderValue(panel->tranceSl), "TranceAmount");
135 diff -Naur WindowMaker-0.91.0-orig/src/WindowMaker.h WindowMaker-0.91.0/src/WindowMaker.h
136 --- WindowMaker-0.91.0-orig/src/WindowMaker.h 2004-10-26 18:34:28.000000000 +0200
137 +++ WindowMaker-0.91.0/src/WindowMaker.h 2004-10-26 18:40:51.000000000 +0200
139 char opaque_move; /* update window position during */
142 + char menu_trance; /* whether menu should be translucent */
143 + int trance_amount; /* percentage of translucency */
144 char wrap_menus; /* wrap menus at edge of screen */
145 char scrollable_menus; /* let them be scrolled */
146 char align_menus; /* align menu with their parents */
147 diff -Naur WindowMaker-0.91.0-orig/src/defaults.c WindowMaker-0.91.0/src/defaults.c
148 --- WindowMaker-0.91.0-orig/src/defaults.c 2004-10-26 18:34:28.000000000 +0200
149 +++ WindowMaker-0.91.0/src/defaults.c 2004-10-26 18:40:51.000000000 +0200
151 {"UseSaveUnders", "NO", NULL,
152 &wPreferences.use_saveunders, getBool, NULL
154 + {"MenuTrance", "NO", NULL,
155 + &wPreferences.menu_trance, getBool, NULL
157 + {"TranceAmount", "30", NULL,
158 + &wPreferences.trance_amount, getInt, NULL
160 {"OpaqueMove", "NO", NULL,
161 &wPreferences.opaque_move, getBool, NULL
163 diff -Naur WindowMaker-0.91.0-orig/src/menu.c WindowMaker-0.91.0/src/menu.c
164 --- WindowMaker-0.91.0-orig/src/menu.c 2004-10-26 18:34:28.000000000 +0200
165 +++ WindowMaker-0.91.0/src/menu.c 2004-10-26 18:40:51.000000000 +0200
167 static void menuCloseClick(WCoreWindow *sender, void *data, XEvent *event);
169 static void updateTexture(WMenu *menu);
170 +static void clipDimensionsToScreen(WMenu *menu, int *x, int *y, int *width, int *height);
173 static int saveMenuRecurs(WMPropList *menus, WScreen *scr, WMenu *menu);
174 @@ -498,6 +499,120 @@
178 +clipDimensionsToScreen(WMenu *menu, int *x, int *y, int *width, int *height)
183 + sw = menu->menu->screen_ptr->scr_width;
184 + sh = menu->menu->screen_ptr->scr_height;
189 + /* CLAMP everything */
190 + if (*x > sw) { *x = sw; } else if (*x < 0) { *x = 0; }
191 + if (*y > sh) { *y = sh; } else if (*y < 0) { *y = 0; }
192 + if (fx > sw) { fx = sw; } else if (fx < 0) { fx = 0; }
193 + if (fy > sh) { fy = sh; } else if (fy < 0) { fy = 0; }
195 + /* Make sure that height and width are positive */
196 + if (fx < *x) { *width = 0; } else { *width = fx - *x; }
197 + if (fy < *y) { *height = 0; } else { *height = fy - *y; }
201 +tranceMenu(WMenu *menu)
203 + WScreen *scr = menu->menu->screen_ptr;
205 + XImage *back, *front;
206 + RImage *trance, *menu_image, *msnormal;
207 + Pixmap original, result;
209 + int mw, mh, dx, dy; /* these correspond to the menu proper */
210 + int gx, gy, gw, gh; /* these correspond to what we grab from the root window */
212 + unsigned long red_mask, green_mask, blue_mask;
214 + unsigned int w, h, bar;
218 + mw = gw = menu->menu->width;
219 + mh = gh = menu->menu->height;
220 + dx = gx = menu->frame_x + 1;
221 + dy = gy = menu->frame_y + menu->frame->top_width + 1;
223 + tamount = wPreferences.trance_amount;
224 + clipDimensionsToScreen(menu, &gx, &gy, &gw, &gh);
225 + back = XGetImage(dpy, scr->root_win, gx, gy, gw, gh,
226 + AllPlanes, ZPixmap);
228 + wwarning(_("error capturing \"back\" image"),RMessageForError(RErrorCode));
231 + red_mask = back->red_mask;
232 + green_mask = back->green_mask;
233 + blue_mask = back->blue_mask;
235 + trance = RCreateImageFromXImage(scr->rcontext, back, NULL);
236 + XDestroyImage(back);
238 + wwarning(_("error rendering \"trance\" image"),
239 + RMessageForError(RErrorCode));
242 + /************************************************************/
243 + original = renderTexture(menu);
245 + XGetGeometry(dpy, original, &baz, &foo,
246 + &foo, &w, &h, &bar, &bar);
247 + front = XGetImage(dpy, original, 0, 0, w, h,
248 + AllPlanes, ZPixmap);
250 + wwarning(_("error capturing \"front\" image"),
251 + RMessageForError(RErrorCode));
254 + front->red_mask = red_mask;
255 + front->green_mask = green_mask;
256 + front->blue_mask = blue_mask;
258 + menu_image=RCreateImageFromXImage(scr->rcontext,front,NULL);
260 + XDestroyImage(front);
261 + /************************************************************/
263 + FREE_PIXMAP(original);
266 + wwarning(_("error rendering \"menu_image\""),
267 + RMessageForError(RErrorCode));
270 + if (wPreferences.menu_style == MS_NORMAL) {
271 + msnormal = RMakeTiledImage(menu_image, mw, mh);
272 + RCombineAreaWithOpaqueness(trance, msnormal,0,0,gw,gh,
273 + gx - dx,gy - dy,256*tamount/10);
274 + RReleaseImage(menu_image);
275 + RReleaseImage(msnormal);
277 + RCombineAreaWithOpaqueness(trance, menu_image,0,0,gw,gh,
278 + gx - dx,gy - dy,256*tamount/10);
279 + RReleaseImage(menu_image);
281 + RConvertImage(scr->rcontext, trance,
284 + RReleaseImage(trance);
292 updateTexture(WMenu *menu)
294 WScreen *scr = menu->menu->screen_ptr;
296 if (!menu->flags.brother) {
297 FREE_PIXMAP(menu->menu_texture_data);
299 - menu->menu_texture_data = renderTexture(menu);
300 + if (wPreferences.menu_trance) {
301 + menu->menu_texture_data = tranceMenu(menu);
303 + menu->menu_texture_data = renderTexture(menu);
306 XSetWindowBackgroundPixmap(dpy, menu->menu->window,
307 menu->menu_texture_data);
308 @@ -1163,6 +1282,11 @@
309 XMoveWindow(dpy, menu->frame->core->window, x, y);
312 + /* FIXME: needs an if */
313 + if (wPreferences.menu_trance) {
314 + updateTexture(menu);
317 XMapWindow(dpy, menu->frame->core->window);
318 wRaiseFrame(menu->frame->core);
319 menu->flags.mapped = 1;
320 @@ -1187,6 +1311,11 @@
321 menu->frame_y = menu->frame->screen_ptr->app_menu_y;
322 XMoveWindow(dpy, menu->frame->core->window, menu->frame_x, menu->frame_y);
324 + /* FIXME: needs an if */
325 + if (wPreferences.menu_trance) {
326 + updateTexture(menu);
329 XMapWindow(dpy, menu->frame->core->window);
330 wRaiseFrame(menu->frame->core);
331 menu->flags.mapped = 1;