目标:

1)滚动组件的特性?

2)有哪些常用的滚动组件?

一、基础滚动组件

Flutter有许多内置的小部件可以自动滚动,还提供了各种小部件,您可以自定义这些小部件来创建特定的滚动行为。

1.1 Scrollbar组件

滚动条的基本构成

滑块:显示滚动了多少?

轨道:滚动条滑动的轨道。可以直接拖拽滚动到轨道位置。

子组件:对应可以滚动的子组件。

child属性

可滚动属性的组件,例如ListView

Scrollbar(child: ListView.builder(
              itemCount: 20,
              itemBuilder: (c, i) -> MyItem(i),
          )),

controller属性

滚动控制器,为空的话默认使用PrimaryScrollController启动滚动条。

thumbVisibility属性

滑块是否可见,布尔值,默认不可见。

trackVisibility属性

轨道是否可见,布尔值,

如果轨迹可见性与滚动条的素材状态有关,
使用全局[ScrollbarThemeData.trackVisibility]或覆盖
子树的主题数据。

thickness属性

滚动条厚度。

radius属性

滚动条滑块圆角半径。

如果为null,则默认值取决于平台。在[TargetPlatform.android]上,
半径应用于滚动条拇指。在[TargetPlatform.iOS]上,
使用[CupertinoScrollbar.defaultRadius]。其余平台的默认[半径.圆形]为8.0像素。

notificationPredicate属性

[ScrollNotification]的谓词,用于自定义小部件
听取孩子的通知。???

scrollbarOrientation属性

滚动条的方向,水平滚动条,竖直滚动条。参见ScrollbarOrientation,

包括

  • left: 左侧滚动条
  • right: 右侧滚动条
  • top:顶部滚动条
  • bottom: 底部滚动条

 1.2 SingleChildScrollView组件

通常SingleChildScrollView只应在期望的内容不会超过屏幕太多时使用,这是因为SingleChildScrollView不支持基于Sliver的延迟实例化模式,所以如果预计视口可能包含超出屏幕尺寸太多的内容时使用SingleChildScrollView将会导致性能差的问题,此时应该使用一些支持Sliver延迟加载的可滚动组件,如ListView。

当需要构建比较长的页面时,如果直接使用SingleChildScrollView,会将整个页面的内容一次性渲染到内存中,这可能会导致内存用过高,影响应用的性能和体验。

SingleChildScrollView继承StatelessWidget。

scrollDirection属性

滚动方向,默认Axis.vertical

  • Axis.vertical:竖直方向
  • Axis.horizontal水平方向

padding属性

内边距

reverse属性

是否反向滚动

primary属性

controller属性

primary为true时此项必须为空(null).可用于控制此滚动的位置的对象视图滚动。

[ScrollController]有多种用途。

  • 它可以用来控制初始滚动位置(请参见[ScrollController.initialScrollOffset])
  • 它可用于控制滚动视图是否应自动保存并恢复其在[PageStorage]中的滚动位置[ScrollController.kipScrollOffset])
  • 它可以用来读取当前滚动位置(请参阅[ScrollController.offset]),或更改它(请参阅[ScrollController.animateTo])。
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  final controller = ScrollController();

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('SingleChildScrollView Demo - Controller'),
        ),
        body: SingleChildScrollView(
          controller: controller, // 设置控制器
          child: Column(
            children: List.generate(50, (index) => Text('Item $index')), // 生成一个长列表
          ),
        ),
        floatingActionButton: FloatingActionButton(
          onPressed: () {
            controller.animateTo(100, duration: Duration(seconds: 1), curve: Curves.easeInOut); // 滚动到指定位置
          },
          child: Icon(Icons.arrow_upward),
        ),
      ),
    );
  }
}

interactive属性

滑块是否可以拖动。

physics属性

定义滚动的物理行为,比如滚动速度、弹性效果等。

定义ScrollView如何响应用户输入,ScrollPhysics类型。例如,确定用户停止拖动滚动视图后滚动视图如何继续设置动画。

BouncingScrollPhysics:弹性效果

ClampingScrollPhysics:

1.3 基于Sliver的延迟构建模式

Flutter中提出一个Sliver(中文为"薄片"的意思)概念,如果一个可滚动组件支持Sliver模型,那么该滚动组件可以将子组件分成好多个薄片(Sliver),只有当Sliver出现在视口时才会去构建它,这种模型也成为"基于Sliver的延迟构建模型"。相当于延迟加载模式。

这个类似于安卓的ListView的Adapter适配模式,只有可见的列表项才UI展现,滑动过程中通过不停的刷新子项内容实现滑动效果。

SingleChildScrollView不支持该模式。大部分的滑动组件都支持该模式,例如CustomScrollView。

1.4 CustomScrollView组件

CustomScrollView继承ScrollView。CustomScrollView可以将页面划分为多个Sliver,每个Sliver只在需要显示时才会被渲染到内存中。

这种方式可以大大减少内存的占用,并且可以更好地处理滚动事件。例如,在滚动时,CustomScrollView可以只渲染当前可见区域内的Sliver,而不是整个页面的内容。

CustomScrollView还提供了一些方便的特性,如SliverAppBar、SliverPersistentHeader等,可以方便地实现吸顶效果、折叠效果等,使页面的展示更加灵活和美观。

scrollDirection属性

滚动方向,默认Axis.vertical

  • Axis.vertical:竖直方向
  • Axis.horizontal水平方向

padding属性

内边距

reverse属性

是否反向滚动

primary属性

controller属性

primary为true时此项必须为空(null).可用于控制此滚动的位置的对象视图滚动。

[ScrollController]有多种用途。

  • 它可以用来控制初始滚动位置(请参见[ScrollController.initialScrollOffset])
  • 它可用于控制滚动视图是否应自动保存并恢复其在[PageStorage]中的滚动位置[ScrollController.kipScrollOffset])
  • 它可以用来读取当前滚动位置(请参阅[ScrollController.offset]),或更改它(请参阅[ScrollController.animateTo])。

physics属性

定义滚动的物理行为,比如滚动速度、弹性效果等。

定义ScrollView如何响应用户输入,ScrollPhysics类型。例如,确定用户停止拖动滚动视图后滚动视图如何继续设置动画。

BouncingScrollPhysics:弹性效果

ClampingScrollPhysics:

slivers属性

slivers薄片列表