diff options
| author | taiyu <taiyu.len@gmail.com> | 2015-08-20 04:47:36 -0700 | 
|---|---|---|
| committer | taiyu <taiyu.len@gmail.com> | 2015-08-20 04:47:36 -0700 | 
| commit | fbaa9111a8525daeef8a5534784da2f793917a36 (patch) | |
| tree | 19c6150da805f3c765746740f0eb8f250682292c /sway/layout.c | |
| parent | ba6034e8c8cd2bbe15f318e511817e0904633bb3 (diff) | |
| download | sway-fbaa9111a8525daeef8a5534784da2f793917a36.tar.xz | |
setup for resizable windows, drop weight
Diffstat (limited to 'sway/layout.c')
| -rw-r--r-- | sway/layout.c | 75 | 
1 files changed, 49 insertions, 26 deletions
| diff --git a/sway/layout.c b/sway/layout.c index f600cf49..50a25442 100644 --- a/sway/layout.c +++ b/sway/layout.c @@ -186,40 +186,63 @@ void arrange_windows(swayc_t *container, int width, int height) {  		break;  	} -	double total_weight = 0; -	for (i = 0; i < container->children->length; ++i) { -		swayc_t *child = container->children->items[i]; -		total_weight += child->weight; -	} - +	x = y = 0; +	double scale = 0;  	switch (container->layout) {  	case L_HORIZ:  	default: -		sway_log(L_DEBUG, "Arranging %p horizontally", container); +		//Calculate total width  		for (i = 0; i < container->children->length; ++i) { -			swayc_t *child = container->children->items[i]; -			double percent = child->weight / total_weight; -			sway_log(L_DEBUG, "Calculating arrangement for %p:%d (will receive %.2f of %d)", child, child->type, percent, width); -			child->x = x + container->x; -			child->y = y + container->y; -			int w = width * percent; -			int h = height; -			arrange_windows(child, w, h); -			x += w; +			int *old_width = &((swayc_t *)container->children->items[i])->width; +			if (*old_width == 0) { +				if (container->children->length > 1) { +					*old_width = width / (container->children->length - 1); +				} else { +					*old_width = width; +				} +				sway_log(L_DEBUG,"setting width as %d",*old_width); +			} +			scale += *old_width; +		} +		//Resize windows +		if (scale > 0.1) { +			scale = width / scale; +			sway_log(L_DEBUG, "Arranging %p horizontally", container); +			for (i = 0; i < container->children->length; ++i) { +				swayc_t *child = container->children->items[i]; +				sway_log(L_DEBUG, "Calculating arrangement for %p:%d (will scale %d by %f)", child, child->type, width, scale); +				child->x = x + container->x; +				child->y = y + container->y; +				arrange_windows(child, child->width * scale, height); +				x += child->width; +			}  		}  		break;  	case L_VERT: -		sway_log(L_DEBUG, "Arranging %p vertically", container); +		//Calculate total height  		for (i = 0; i < container->children->length; ++i) { -			swayc_t *child = container->children->items[i]; -			double percent = child->weight / total_weight; -			sway_log(L_DEBUG, "Calculating arrangement for %p:%d (will receive %.2f of %d)", child, child->type, percent, width); -			child->x = x + container->x; -			child->y = y + container->y; -			int w = width; -			int h = height * percent; -			arrange_windows(child, w, h); -			y += h; +			int *old_height = &((swayc_t *)container->children->items[i])->height; +				if (container->children->length > 1) { +					*old_height = height / (container->children->length - 1); +				} else { +					*old_height = height; +				} +			if (*old_height == 0) { +			} +			scale += *old_height; +		} +		//Resize +		if (scale > 0.1) { +			scale = height / scale; +			sway_log(L_DEBUG, "Arranging %p vertically", container); +			for (i = 0; i < container->children->length; ++i) { +				swayc_t *child = container->children->items[i]; +				sway_log(L_DEBUG, "Calculating arrangement for %p:%d (will scale %d by %f)", child, child->type, height, scale); +				child->x = x + container->x; +				child->y = y + container->y; +				arrange_windows(child, width, child->height * scale); +				y += child->height; +			}  		}  		break;  	} | 
