1
0
mirror of https://github.com/gryf/wmaker.git synced 2025-12-19 12:28:22 +01:00

fixed cycling

This commit is contained in:
kojima
2004-10-14 21:24:21 +00:00
parent 2e572717c5
commit 884a3f1647
5 changed files with 140 additions and 126 deletions

View File

@@ -216,14 +216,16 @@ StartWindozeCycle(WWindow *wwin, XEvent *event, Bool next)
scr->flags.doing_alt_tab = 1; scr->flags.doing_alt_tab = 1;
#ifdef MOX_CYCLING #ifdef MOX_CYCLING
swpanel = wInitSwitchPanel(scr, scr->current_workspace); swpanel = wInitSwitchPanel(scr, wwin, scr->current_workspace);
oldFocused = wwin; oldFocused = wwin;
if (swpanel) { if (swpanel) {
newFocused = wSwitchPanelSelectNext(swpanel, next); newFocused = wSwitchPanelSelectNext(swpanel, !next);
wWindowFocus(newFocused, oldFocused); wWindowFocus(newFocused, oldFocused);
oldFocused = newFocused; oldFocused = newFocused;
} }
else
newFocused= wwin;
#else /* !MOX_CYCLING */ #else /* !MOX_CYCLING */
if (next) { if (next) {
if (wPreferences.windows_cycling) if (wPreferences.windows_cycling)

View File

@@ -1076,7 +1076,7 @@ wFrameWindowPaint(WFrameWindow *fwin)
break; break;
} }
y = *fwin->title_clearance + TITLEBAR_EXTEND_SPACE - 1; y = *fwin->title_clearance + TITLEBAR_EXTEND_SPACE;
h = WMFontHeight(*fwin->font); h = WMFontHeight(*fwin->font);
/* We use a w+2 buffer to have an extra pixel on the left and /* We use a w+2 buffer to have an extra pixel on the left and

View File

@@ -208,135 +208,147 @@ static void addIconForWindow(WSwitchPanel *panel, WWindow *wwin, int iconWidth)
} }
WSwitchPanel *wInitSwitchPanel(WScreen *scr, int workspace) WSwitchPanel *wInitSwitchPanel(WScreen *scr, WWindow *curwin, int workspace)
{ {
WWindow *wwin; WWindow *wwin;
WSwitchPanel *panel= wmalloc(sizeof(WSwitchPanel)); WSwitchPanel *panel= wmalloc(sizeof(WSwitchPanel));
int i; int i;
int width; int width;
int height; int height;
int iconWidth = ICON_IDEAL_SIZE; int iconWidth = ICON_IDEAL_SIZE;
WMBox *vbox; WMBox *vbox;
panel->current= 0; panel->defIcon= NULL;
panel->defIcon= NULL;
panel->normalColor = WMGrayColor(scr->wmscreen); panel->normalColor = WMGrayColor(scr->wmscreen);
panel->selectColor = WMWhiteColor(scr->wmscreen); panel->selectColor = WMWhiteColor(scr->wmscreen);
panel->scr= scr; panel->scr= scr;
panel->windows= WMCreateArray(10); panel->windows= WMCreateArray(10);
for (wwin= scr->focused_window; wwin; wwin= wwin->prev) { for (wwin= curwin; wwin; wwin= wwin->prev) {
if (wwin->frame->workspace == workspace && wWindowCanReceiveFocus(wwin) && if (wwin->frame->workspace == workspace && wWindowCanReceiveFocus(wwin) &&
(!WFLAGP(wwin, skip_window_list) || wwin->flags.internal_window)) { (!WFLAGP(wwin, skip_window_list) || wwin->flags.internal_window)) {
WMInsertInArray(panel->windows, 0, wwin); WMInsertInArray(panel->windows, 0, wwin);
} }
} }
wwin = curwin;
/* start over from the beginning of the list */
while (wwin->next)
wwin = wwin->next;
width= (iconWidth + ICON_EXTRASPACE)*WMGetArrayItemCount(panel->windows); for (wwin= curwin; wwin && wwin != curwin; wwin= wwin->prev) {
if (wwin->frame->workspace == workspace && wWindowCanReceiveFocus(wwin) &&
if (width > WMScreenWidth(scr->wmscreen)) (!WFLAGP(wwin, skip_window_list) || wwin->flags.internal_window)) {
{ WMInsertInArray(panel->windows, 0, wwin);
width= WMScreenWidth(scr->wmscreen) - 100; }
iconWidth = width / WMGetArrayItemCount(panel->windows) - ICON_EXTRASPACE;
}
if (iconWidth < 16 || WMGetArrayItemCount(panel->windows) == 0)
{
/* if there are too many windows, don't bother trying to show the panel */
WMFreeArray(panel->windows);
wfree(panel);
return NULL;
}
height= iconWidth + 20 + 10 + ICON_EXTRASPACE;
panel->icons= WMCreateArray(WMGetArrayItemCount(panel->windows));
panel->images= WMCreateArray(WMGetArrayItemCount(panel->windows));
panel->win = WMCreateWindow(scr->wmscreen, "");
WMResizeWidget(panel->win, width + 10, height);
{
WMFrame *frame = WMCreateFrame(panel->win);
WMSetFrameRelief(frame, WRSimple);
WMSetViewExpandsToParent(WMWidgetView(frame), 0, 0, 0, 0);
vbox = WMCreateBox(panel->win);
}
WMSetViewExpandsToParent(WMWidgetView(vbox), 5, 5, 5, 5);
WMSetBoxHorizontal(vbox, False);
panel->label = WMCreateLabel(vbox);
WMAddBoxSubviewAtEnd(vbox, WMWidgetView(panel->label), False, True, 20, 0, 0);
if (scr->focused_window && scr->focused_window->frame->title)
WMSetLabelText(panel->label, scr->focused_window->frame->title);
else
WMSetLabelText(panel->label, "");
{
WMColor *color;
WMFont *boldFont= WMBoldSystemFontOfSize(scr->wmscreen, 12);
WMSetLabelRelief(panel->label, WRSimple);
WMSetLabelFont(panel->label, boldFont);
color = WMDarkGrayColor(scr->wmscreen);
WMSetWidgetBackgroundColor(panel->label, color);
WMReleaseColor(color);
color = WMWhiteColor(scr->wmscreen);
WMSetLabelTextColor(panel->label, color);
WMReleaseColor(color);
WMReleaseFont(boldFont);
}
{
RImage *tmp= NULL;
RColor bgColor;
char *path = FindImage(wPreferences.pixmap_path, "swtile.png");
if (path) {
tmp = RLoadImage(panel->scr->rcontext, path, 0);
wfree(path);
} }
if (!tmp) width= (iconWidth + ICON_EXTRASPACE)*WMGetArrayItemCount(panel->windows);
tmp= RGetImageFromXPMData(scr->rcontext, tile_xpm);
panel->tile = RScaleImage(tmp, iconWidth+ICON_EXTRASPACE, iconWidth+ICON_EXTRASPACE); if (width > WMScreenWidth(scr->wmscreen))
{
width= WMScreenWidth(scr->wmscreen) - 100;
iconWidth = width / WMGetArrayItemCount(panel->windows) - ICON_EXTRASPACE;
}
bgColor.alpha = 255; if (iconWidth < 16 || WMGetArrayItemCount(panel->windows) == 0)
bgColor.red = WMRedComponentOfColor(WMGrayColor(scr->wmscreen))>>8; {
bgColor.green = WMGreenComponentOfColor(WMGrayColor(scr->wmscreen))>>8; /* if there are too many windows, don't bother trying to show the panel */
bgColor.blue = WMBlueComponentOfColor(WMGrayColor(scr->wmscreen))>>8; WMFreeArray(panel->windows);
wfree(panel);
return NULL;
}
RCombineImageWithColor(panel->tile, &bgColor); height= iconWidth + 20 + 10 + ICON_EXTRASPACE;
RReleaseImage(tmp); panel->icons= WMCreateArray(WMGetArrayItemCount(panel->windows));
} panel->images= WMCreateArray(WMGetArrayItemCount(panel->windows));
panel->hbox = WMCreateBox(vbox); panel->win = WMCreateWindow(scr->wmscreen, "");
WMSetBoxHorizontal(panel->hbox, True); WMResizeWidget(panel->win, width + 10, height);
WMAddBoxSubviewAtEnd(vbox, WMWidgetView(panel->hbox), True, True, 20, 0, 2);
WM_ITERATE_ARRAY(panel->windows, wwin, i) { {
addIconForWindow(panel, wwin, iconWidth); WMFrame *frame = WMCreateFrame(panel->win);
changeImage(panel, i, 0); WMSetFrameRelief(frame, WRSimple);
} WMSetViewExpandsToParent(WMWidgetView(frame), 0, 0, 0, 0);
WMMapSubwidgets(panel->win); vbox = WMCreateBox(panel->win);
WMRealizeWidget(panel->win); }
WMMapWidget(panel->win); WMSetViewExpandsToParent(WMWidgetView(vbox), 5, 5, 5, 5);
{ WMSetBoxHorizontal(vbox, False);
WMPoint center;
center= wGetPointToCenterRectInHead(scr, wGetHeadForPointerLocation(scr), panel->label = WMCreateLabel(vbox);
width+10, height); WMAddBoxSubviewAtEnd(vbox, WMWidgetView(panel->label), False, True, 20, 0, 0);
WMMoveWidget(panel->win, center.x, center.y); if (scr->focused_window && scr->focused_window->frame->title)
} WMSetLabelText(panel->label, scr->focused_window->frame->title);
else
WMSetLabelText(panel->label, "");
changeImage(panel, 0, 1); {
WMColor *color;
WMFont *boldFont= WMBoldSystemFontOfSize(scr->wmscreen, 12);
return panel; WMSetLabelRelief(panel->label, WRSimple);
WMSetLabelFont(panel->label, boldFont);
color = WMDarkGrayColor(scr->wmscreen);
WMSetWidgetBackgroundColor(panel->label, color);
WMReleaseColor(color);
color = WMWhiteColor(scr->wmscreen);
WMSetLabelTextColor(panel->label, color);
WMReleaseColor(color);
WMReleaseFont(boldFont);
}
{
RImage *tmp= NULL;
RColor bgColor;
char *path = FindImage(wPreferences.pixmap_path, "swtile.png");
if (path) {
tmp = RLoadImage(panel->scr->rcontext, path, 0);
wfree(path);
}
if (!tmp)
tmp= RGetImageFromXPMData(scr->rcontext, tile_xpm);
panel->tile = RScaleImage(tmp, iconWidth+ICON_EXTRASPACE, iconWidth+ICON_EXTRASPACE);
bgColor.alpha = 255;
bgColor.red = WMRedComponentOfColor(WMGrayColor(scr->wmscreen))>>8;
bgColor.green = WMGreenComponentOfColor(WMGrayColor(scr->wmscreen))>>8;
bgColor.blue = WMBlueComponentOfColor(WMGrayColor(scr->wmscreen))>>8;
RCombineImageWithColor(panel->tile, &bgColor);
RReleaseImage(tmp);
}
panel->hbox = WMCreateBox(vbox);
WMSetBoxHorizontal(panel->hbox, True);
WMAddBoxSubviewAtEnd(vbox, WMWidgetView(panel->hbox), True, True, 20, 0, 4);
WM_ITERATE_ARRAY(panel->windows, wwin, i) {
addIconForWindow(panel, wwin, iconWidth);
changeImage(panel, i, 0);
}
WMMapSubwidgets(panel->win);
WMRealizeWidget(panel->win);
WMMapWidget(panel->win);
{
WMPoint center;
center= wGetPointToCenterRectInHead(scr, wGetHeadForPointerLocation(scr),
width+10, height);
WMMoveWidget(panel->win, center.x, center.y);
}
panel->current= WMGetFirstInArray(panel->windows, curwin);
changeImage(panel, panel->current, 1);
return panel;
} }

View File

@@ -24,7 +24,7 @@
typedef struct SwitchPanel WSwitchPanel; typedef struct SwitchPanel WSwitchPanel;
WSwitchPanel *wInitSwitchPanel(WScreen *scr, int workspace); WSwitchPanel *wInitSwitchPanel(WScreen *scr, WWindow *curwin, int workspace);
void wSwitchPanelDestroy(WSwitchPanel *panel); void wSwitchPanelDestroy(WSwitchPanel *panel);