一統天下 flutter - widget Sliver: NestedScrollView - 爲可滾動組件提供 sliver 效果

源碼 https://github.com/webabcd/flutter_demo
作者 webabcd

一統天下 flutter - widget Sliver: NestedScrollView - 爲可滾動組件提供 sliver 效果

示例如下:

lib\widget\sliver\nested_scroll_view.dart

/*
 * NestedScrollView - 爲可滾動組件提供 sliver 效果
 */

import 'package:flutter/material.dart';

import '../../helper.dart';

class NestedScrollViewDemo extends StatefulWidget {
  const NestedScrollViewDemo({Key? key}) : super(key: key);

  @override
  _NestedScrollViewDemoState createState() => _NestedScrollViewDemoState();
}

class _NestedScrollViewDemoState extends State<NestedScrollViewDemo> {

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      /// NestedScrollView - 爲可滾動組件提供 sliver 效果
      body: NestedScrollView(
        /// 用於構造 slivers
        headerSliverBuilder: (BuildContext context, bool innerBoxIsScrolled) {
          return [
            SliverAppBar(
              title: const Text('title'),
              expandedHeight: 200,
              flexibleSpace: FlexibleSpaceBar(
                background: Image.asset('assets/son.jpg',fit: BoxFit.cover,),
              ),
              pinned: true,
            ),
          ];
        },

        /// 一個可滾動組件
        body: ListView.builder(
          padding: EdgeInsets.zero,
          itemCount: 20,
          itemBuilder: (BuildContext context,int index) {
            return Container(
              height: 100,
              color: Colors.primaries[index % Colors.primaries.length],
              alignment: Alignment.center,
              child: MyText('$index'),
            );
          },
        ),
      ),
    );
  }
}

源碼 https://github.com/webabcd/flutter_demo
作者 webabcd

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章