awesome/layouts/fibonacci.c

104 lines
3.3 KiB
C
Raw Normal View History

/*
* fibonacci.c - fibonacci layout
*
2008-01-02 16:59:43 +01:00
* Copyright © 2007-2008 Julien Danjou <julien@danjou.info>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
*/
#include "screen.h"
#include "workspace.h"
2008-01-01 17:25:48 +01:00
#include "client.h"
#include "layouts/fibonacci.h"
extern awesome_t globalconf;
static void
layout_fibonacci(workspace_t *ws, int shape)
{
2008-01-05 20:18:30 +01:00
int n = 0, i = 0;
client_t *c;
2008-03-14 09:37:25 +01:00
area_t geometry, area;
int screen = workspace_screen_get(ws);
geometry = area = screen_area_get(screen,
2008-01-05 20:18:30 +01:00
globalconf.screens[screen].statusbar,
&globalconf.screens[screen].padding);
for(c = globalconf.clients; c; c = c->next)
if(IS_TILED(c, screen))
n++;
for(c = globalconf.clients; c; c = c->next)
if(IS_TILED(c, screen))
{
c->ismax = false;
2008-01-05 20:18:30 +01:00
if((i % 2 && geometry.height / 2 > 2 * c->border)
|| (!(i % 2) && geometry.width / 2 > 2 * c->border))
{
if(i < n - 1)
{
if(i % 2)
2008-01-05 20:18:30 +01:00
geometry.height /= 2;
else
2008-01-05 20:18:30 +01:00
geometry.width /= 2;
if((i % 4) == 2 && !shape)
2008-01-05 20:18:30 +01:00
geometry.x += geometry.width;
else if((i % 4) == 3 && !shape)
2008-01-05 20:18:30 +01:00
geometry.y += geometry.height;
}
if((i % 4) == 0)
{
if(shape)
2008-01-05 20:18:30 +01:00
geometry.y += geometry.height;
else
2008-01-05 20:18:30 +01:00
geometry.y -= geometry.height;
}
else if((i % 4) == 1)
2008-01-05 20:18:30 +01:00
geometry.x += geometry.width;
else if((i % 4) == 2)
2008-01-05 20:18:30 +01:00
geometry.y += geometry.height;
else if((i % 4) == 3)
{
if(shape)
2008-01-05 20:18:30 +01:00
geometry.x += geometry.width;
else
2008-01-05 20:18:30 +01:00
geometry.x -= geometry.width;
}
if(i == 0)
2008-01-05 20:18:30 +01:00
geometry.y = area.y;
i++;
}
2008-01-05 20:18:30 +01:00
geometry.width -= 2 * c->border;
geometry.height -= 2 * c->border;
client_resize(c, geometry, globalconf.resize_hints);
2008-01-12 14:24:13 +01:00
geometry.width += 2 * c->border;
geometry.height += 2 * c->border;
}
}
void
layout_spiral(workspace_t *ws)
{
layout_fibonacci(ws, 0);
}
void
layout_dwindle(workspace_t *ws)
{
layout_fibonacci(ws, 1);
}
// vim: filetype=c:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=80