Flutter中的Alignment是怎么回事?

我们知道Flutter中的Container有个alignment的属性,我们可以设置一些topLeft,center之类的位置名字的值,也可以设置Alignment(x,y)这种具体数值的值。那么Align子widget的位置跟x、y是什么关系呢?以水平方向为例,我们知道x=-1表示子widget和Align的左边重合,x=1表示子widget和Align的右边重合。据此,我们可以计算出子widget的相对位置为:

childX = (alignWidth - childWidth) / 2 * (x+1)

怎么来的呢?根据下面的图所示,绿色的是Align区域,左边的紫色子widget左侧贴紧Align的左侧,此时x=-1。紫色widget移动到和Align的右侧重合时候,x=1。这个过程,紫色widget的移动距离是alignWidth - childWidth。据此我们可以根据它们的线性关系,得出上面公式。

 具体到源码,我们可以找到具体代码实现:

final double halfWidthDelta = (rect.width - size.width) / 2.0;
final double halfHeightDelta = (rect.height - size.height) / 2.0;
return Rect.fromLTWH(
rect.left + halfWidthDelta + x * halfWidthDelta,
rect.top + halfHeightDelta + y * halfHeightDelta,
size.width,
size.height,
);

源码使用的公式是绝对位置,所以加上了Align的left,两者的思路是一致的。

想一想:

如果要让子widget的右侧刚好露出Align右侧50%,x是多少呢?

令childX=alignWidth-childWidth/2=(alignWidth - childWidth) / 2 * (x+1)

得x=alignWidth/(alignWidth-childWidth)

参考:

1.关于前端:Flutter布局彻底搞懂-Align-是怎么对齐的 - 乐趣区

2.《flutter组件详解与实战》王浩然

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值