mirror of
https://github.com/DreamMaoMao/maomaowm.git
synced 2026-04-06 07:15:53 -04:00
增加压缩布局和螺旋布局
This commit is contained in:
parent
d10ceab48c
commit
b3a8150996
2 changed files with 79 additions and 5 deletions
76
maomao.c
76
maomao.c
|
|
@ -485,7 +485,8 @@ static void tile(Monitor *m, unsigned int gappo, unsigned int uappi);
|
||||||
static void overview(Monitor *m, unsigned int gappo, unsigned int gappi);
|
static void overview(Monitor *m, unsigned int gappo, unsigned int gappi);
|
||||||
static void grid(Monitor *m, unsigned int gappo, unsigned int uappi);
|
static void grid(Monitor *m, unsigned int gappo, unsigned int uappi);
|
||||||
static void scroller(Monitor *m, unsigned int gappo, unsigned int uappi);
|
static void scroller(Monitor *m, unsigned int gappo, unsigned int uappi);
|
||||||
|
static void dwindle(Monitor *mon, unsigned int gappo, unsigned int gappi);
|
||||||
|
static void spiral(Monitor *mon, unsigned int gappo, unsigned int gappi);
|
||||||
static void unlocksession(struct wl_listener *listener, void *data);
|
static void unlocksession(struct wl_listener *listener, void *data);
|
||||||
static void unmaplayersurfacenotify(struct wl_listener *listener, void *data);
|
static void unmaplayersurfacenotify(struct wl_listener *listener, void *data);
|
||||||
static void unmapnotify(struct wl_listener *listener, void *data);
|
static void unmapnotify(struct wl_listener *listener, void *data);
|
||||||
|
|
@ -3245,7 +3246,7 @@ monocle(Monitor *m,unsigned int gappo, unsigned int gappi) {
|
||||||
int n = 0;
|
int n = 0;
|
||||||
|
|
||||||
wl_list_for_each(c, &clients, link) {
|
wl_list_for_each(c, &clients, link) {
|
||||||
if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen)
|
if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen || c->ismaxmizescreen || c->iskilling || c->animation.tagouting)
|
||||||
continue;
|
continue;
|
||||||
resize(c, m->w, 0);
|
resize(c, m->w, 0);
|
||||||
n++;
|
n++;
|
||||||
|
|
@ -4833,6 +4834,77 @@ void overview(Monitor *m, unsigned int gappo, unsigned int gappi) {
|
||||||
grid(m, overviewgappo, overviewgappi);
|
grid(m, overviewgappo, overviewgappi);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void fibonacci(Monitor *mon, int s) {
|
||||||
|
unsigned int i=0, n=0, nx, ny, nw, nh;
|
||||||
|
Client *c;
|
||||||
|
|
||||||
|
wl_list_for_each(c, &clients, link)
|
||||||
|
if (VISIBLEON(c, mon) && !c->isfloating)
|
||||||
|
n++;
|
||||||
|
if(n == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
nx = mon->w.x;
|
||||||
|
ny = 0;
|
||||||
|
nw = mon->w.width;
|
||||||
|
nh = mon->w.height;
|
||||||
|
|
||||||
|
wl_list_for_each(c, &clients, link)
|
||||||
|
if (VISIBLEON(c, mon) && !c->isfloating){
|
||||||
|
if((i % 2 && nh / 2 > 2 * c->bw)
|
||||||
|
|| (!(i % 2) && nw / 2 > 2 * c->bw)) {
|
||||||
|
if(i < n - 1) {
|
||||||
|
if(i % 2)
|
||||||
|
nh /= 2;
|
||||||
|
else
|
||||||
|
nw /= 2;
|
||||||
|
if((i % 4) == 2 && !s)
|
||||||
|
nx += nw;
|
||||||
|
else if((i % 4) == 3 && !s)
|
||||||
|
ny += nh;
|
||||||
|
}
|
||||||
|
if((i % 4) == 0) {
|
||||||
|
if(s)
|
||||||
|
ny += nh;
|
||||||
|
else
|
||||||
|
ny -= nh;
|
||||||
|
}
|
||||||
|
else if((i % 4) == 1)
|
||||||
|
nx += nw;
|
||||||
|
else if((i % 4) == 2)
|
||||||
|
ny += nh;
|
||||||
|
else if((i % 4) == 3) {
|
||||||
|
if(s)
|
||||||
|
nx += nw;
|
||||||
|
else
|
||||||
|
nx -= nw;
|
||||||
|
}
|
||||||
|
if(i == 0)
|
||||||
|
{
|
||||||
|
if(n != 1)
|
||||||
|
nw = mon->w.width * mon->mfact;
|
||||||
|
ny = mon->w.y;
|
||||||
|
}
|
||||||
|
else if(i == 1)
|
||||||
|
nw = mon->w.width - nw;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
resize(c, (struct wlr_box){.x = nx, .y = ny,
|
||||||
|
.width = nw - 2 * c->bw, .height = nh - 2 * c->bw}, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
dwindle(Monitor *mon,unsigned int gappo, unsigned int gappi) {
|
||||||
|
fibonacci(mon, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
spiral(Monitor *mon, unsigned int gappo, unsigned int gappi) {
|
||||||
|
fibonacci(mon, 0);
|
||||||
|
}
|
||||||
|
|
||||||
// 网格布局窗口大小和位置计算
|
// 网格布局窗口大小和位置计算
|
||||||
void grid(Monitor *m, unsigned int gappo, unsigned int gappi) {
|
void grid(Monitor *m, unsigned int gappo, unsigned int gappi) {
|
||||||
unsigned int i, n;
|
unsigned int i, n;
|
||||||
|
|
|
||||||
|
|
@ -67,10 +67,12 @@ Layout overviewlayout = { "", overview, "overview" };
|
||||||
|
|
||||||
Layout layouts[] = { //最少两个,不能删除少于两个
|
Layout layouts[] = { //最少两个,不能删除少于两个
|
||||||
/* symbol arrange function name */
|
/* symbol arrange function name */
|
||||||
{ "⬌", scroller, "scroller" }, //滚动布局
|
{ "S", scroller, "scroller" }, //滚动布局
|
||||||
{ "", tile, "tile" }, //堆栈布局
|
{ "T", tile, "tile" }, //堆栈布局
|
||||||
{"", grid, "grid"},
|
{"G", grid, "grid"},
|
||||||
{"M",monocle,"monocle"},
|
{"M",monocle,"monocle"},
|
||||||
|
{"D",dwindle,"dwindle"},
|
||||||
|
{"P",spiral,"spiral"},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue