AnimatedList自动向最后一个项目滚动然后返回
创始人
2024-11-02 09:00:31
0

使用这种方法,我们可以使用AnimatedListState的scrollTo和scrollToIndex方法来向下滚动,然后向上滚动。

scrollToEnd() async {
  await Future.delayed(Duration(milliseconds: 300));
  _listKey.currentState.scrollController.animateTo(
    _listKey.currentState.scrollController.position.maxScrollExtent,
    duration: Duration(milliseconds: 800),
    curve: Curves.easeOut,
  );
  await Future.delayed(Duration(milliseconds: 800));
  _listKey.currentState.scrollController.animateTo(
    0.0,
    duration: Duration(milliseconds: 800),
    curve: Curves.easeOut,
  );
}

在构建AnimatedList并给AnimatedListState添加scrollController后,我们可以使用方法scrollToEnd()从任何位置触发滚动。

AnimatedList(
  key: _listKey,
  controller: _animationController,
  initialItemCount: _messages.length,
  itemBuilder: (BuildContext context, int index, Animation animation) {
    // ...
  },
),

当用户在屏幕上滚动时,还要更新_scrollToBottom值,以便在下一次插入时知道是否滚动到底部。

_scrollListener() {
  if (_listKey.currentState != null &&
      _listKey.currentState.scrollController != null &&
      _listKey.currentState.scrollController.offset >=
          _listKey.currentState.scrollController.position.maxScrollExtent) {
    setState(() {
      _scrollToBottom = true;
    });
  } else {
    setState(() {
      _scrollToBottom = false;
    });
  }
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...