Flutter 列表滚动到固定位置

1,直接计算item显示的高度offsetY,该方案需要计算前面每个item的高度,非常麻烦,适合固定高度item的布局

        _scrollController.animateTo( offsetY, duration: Duration(milliseconds: 500), curve: Curves.decelerate, );

 2,通过GlobalKey获取指定item的位置信息,超过屏幕未渲染时无法获取

void scrollToWelfare(GlobalKey globalKey, double offsetY) {
  RenderBox? evaluationRenderObject = globalKey.currentContext?.findRenderObject() as RenderBox;
  if (evaluationRenderObject != null) {
    Offset offset = evaluationRenderObject!.localToGlobal(Offset(0, _scrollController.offset));
    _scrollController.animateTo(
      offset.dy - offsetY,
      duration: Duration(milliseconds: 500),
      curve: Curves.decelerate,
    );
  }
}

 注意:如果内容不多,可以在每个item外包一层Column,这样超过屏幕也会渲染出来。

WidgetsBinding.instance.addPostFrameCallback((timeStamp) {
  if (_shouldScrollToGoods) {
    scrollToGoods(_goodsKey, CommonUtils.topHeight(navigatorKey) + 88);
  }
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值