mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-16 11:42:04 +08:00
149 lines
6.4 KiB
TypeScript
149 lines
6.4 KiB
TypeScript
import utils = require("utils/utils");
|
|
import common = require("./dock-layout-common");
|
|
import {CommonLayoutParams, nativeLayoutParamsProperty} from "ui/styling/style";
|
|
import {Dock} from "ui/enums";
|
|
import {View} from "ui/core/view";
|
|
|
|
global.moduleMerge(common, exports);
|
|
|
|
export class DockLayout extends common.DockLayout {
|
|
|
|
protected onDockChanged(view: View, oldValue: number, newValue: number) {
|
|
this.requestLayout();
|
|
}
|
|
|
|
public onMeasure(widthMeasureSpec: number, heightMeasureSpec: number): void {
|
|
DockLayout.adjustChildrenLayoutParams(this, widthMeasureSpec, heightMeasureSpec);
|
|
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
|
|
|
|
var measureWidth = 0;
|
|
var measureHeight = 0;
|
|
|
|
var width = utils.layout.getMeasureSpecSize(widthMeasureSpec);
|
|
var widthMode = utils.layout.getMeasureSpecMode(widthMeasureSpec);
|
|
|
|
var height = utils.layout.getMeasureSpecSize(heightMeasureSpec);
|
|
var heightMode = utils.layout.getMeasureSpecMode(heightMeasureSpec);
|
|
|
|
var density = utils.layout.getDisplayDensity();
|
|
|
|
var remainingWidth = widthMode === utils.layout.UNSPECIFIED ? Number.MAX_VALUE : width - ((this.paddingLeft + this.paddingRight) * density);
|
|
var remainingHeight = heightMode === utils.layout.UNSPECIFIED ? Number.MAX_VALUE : height - ((this.paddingTop + this.paddingBottom) * density);
|
|
|
|
var tempHeight: number = 0;
|
|
var tempWidth: number = 0;
|
|
var childWidthMeasureSpec: number;
|
|
var childHeightMeasureSpec: number;
|
|
|
|
this.eachLayoutChild((child, last) => {
|
|
if (this.stretchLastChild && last) {
|
|
childWidthMeasureSpec = utils.layout.makeMeasureSpec(remainingWidth, widthMode);
|
|
childHeightMeasureSpec = utils.layout.makeMeasureSpec(remainingHeight, heightMode);
|
|
}
|
|
else {
|
|
// Measure children with AT_MOST even if our mode is EXACT
|
|
childWidthMeasureSpec = utils.layout.makeMeasureSpec(remainingWidth, widthMode === utils.layout.EXACTLY ? utils.layout.AT_MOST : widthMode);
|
|
childHeightMeasureSpec = utils.layout.makeMeasureSpec(remainingHeight, heightMode === utils.layout.EXACTLY ? utils.layout.AT_MOST : heightMode);
|
|
}
|
|
|
|
let childSize = View.measureChild(this, child, childWidthMeasureSpec, childHeightMeasureSpec);
|
|
let dock = DockLayout.getDock(child);
|
|
|
|
switch (dock) {
|
|
case Dock.top:
|
|
case Dock.bottom:
|
|
remainingHeight = Math.max(0, remainingHeight - childSize.measuredHeight);
|
|
tempHeight += childSize.measuredHeight;
|
|
measureWidth = Math.max(measureWidth, tempWidth + childSize.measuredWidth);
|
|
measureHeight = Math.max(measureHeight, tempHeight);
|
|
break;
|
|
|
|
case Dock.left:
|
|
case Dock.right:
|
|
default:
|
|
remainingWidth = Math.max(0, remainingWidth - childSize.measuredWidth);
|
|
tempWidth += childSize.measuredWidth;
|
|
measureWidth = Math.max(measureWidth, tempWidth);
|
|
measureHeight = Math.max(measureHeight, tempHeight + childSize.measuredHeight);
|
|
break;
|
|
}
|
|
});
|
|
|
|
measureWidth += (this.paddingLeft + this.paddingRight) * density;
|
|
measureHeight += (this.paddingTop + this.paddingBottom) * density;
|
|
|
|
measureWidth = Math.max(measureWidth, this.minWidth * density);
|
|
measureHeight = Math.max(measureHeight, this.minHeight * density);
|
|
|
|
var widthAndState = View.resolveSizeAndState(measureWidth, width, widthMode, 0);
|
|
var heightAndState = View.resolveSizeAndState(measureHeight, height, heightMode, 0);
|
|
|
|
this.setMeasuredDimension(widthAndState, heightAndState);
|
|
}
|
|
|
|
public onLayout(left: number, top: number, right: number, bottom: number): void {
|
|
super.onLayout(left, top, right, bottom);
|
|
|
|
var density = utils.layout.getDisplayDensity();
|
|
|
|
var childLeft = this.paddingLeft * density;
|
|
var childTop = this.paddingTop * density;
|
|
|
|
var x = childLeft;
|
|
var y = childTop;
|
|
|
|
var remainingWidth = Math.max(0, right - left - ((this.paddingLeft + this.paddingRight) * density));
|
|
var remainingHeight = Math.max(0, bottom - top - ((this.paddingTop + this.paddingBottom) * density));
|
|
|
|
this.eachLayoutChild((child, last) => {
|
|
let lp: CommonLayoutParams = child.style._getValue(nativeLayoutParamsProperty);
|
|
|
|
let childWidth = child.getMeasuredWidth() + (lp.leftMargin + lp.rightMargin) * density;
|
|
let childHeight = child.getMeasuredHeight() + (lp.topMargin + lp.bottomMargin) * density;
|
|
|
|
if (last && this.stretchLastChild) {
|
|
// Last child with stretch - give it all the space and return;
|
|
View.layoutChild(this, child, x, y, x + remainingWidth, y + remainingHeight);
|
|
return;
|
|
}
|
|
|
|
let dock = DockLayout.getDock(child);
|
|
switch (dock) {
|
|
case Dock.top:
|
|
childLeft = x;
|
|
childTop = y;
|
|
childWidth = remainingWidth;
|
|
y += childHeight;
|
|
remainingHeight = Math.max(0, remainingHeight - childHeight);
|
|
break;
|
|
|
|
case Dock.bottom:
|
|
childLeft = x;
|
|
childTop = y + remainingHeight - childHeight;
|
|
childWidth = remainingWidth;
|
|
remainingHeight = Math.max(0, remainingHeight - childHeight);
|
|
break;
|
|
|
|
case Dock.right:
|
|
childLeft = x + remainingWidth - childWidth;
|
|
childTop = y;
|
|
childHeight = remainingHeight;
|
|
remainingWidth = Math.max(0, remainingWidth - childWidth);
|
|
break;
|
|
|
|
case Dock.left:
|
|
default:
|
|
childLeft = x;
|
|
childTop = y;
|
|
childHeight = remainingHeight;
|
|
x += childWidth;
|
|
remainingWidth = Math.max(0, remainingWidth - childWidth);
|
|
break;
|
|
}
|
|
|
|
View.layoutChild(this, child, childLeft, childTop, childLeft + childWidth, childTop + childHeight);
|
|
});
|
|
|
|
DockLayout.restoreOriginalParams(this);
|
|
}
|
|
} |