欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter 利用CustomScrollView實現(xiàn)滑動效果

 更新時間:2021年06月15日 08:45:04   作者:島上碼農(nóng)  
我們可以使用ListView將幾個GridView組合在一起實現(xiàn)了不同可滑動組件的粘合,但是這里必須要設置禁止 GridView 的滑動,防止多個滑動組件的沖突。這種方式寫起來不太方便,事實上 Flutter 提供了 CustomScrollView 來粘合多個滑動組件,并且可以實現(xiàn)更有趣的滑動效果。

我們在之前的文章中//www.dbjr.com.cn/article/213709.htm 使用了 ListView 將幾個 GridView 組合在一起實現(xiàn)滑動效果,今天利用CustomScrollView改造一下代碼

CustomScrollView 簡介

CustomScrollView的常用屬性如下:

  • slivers:最重要的屬性,由多個SliverXX組件組成的數(shù)組,包括如 SliverList(對應 ListView),SliverGrid(對應 GridView)等,如果普通組件無法直接使用,而需要使用SliverToBoxAdapter包裹。
  • reverse:是否反向滾動,如果為 true,則反方向滾動。
  • scrollDirection:滾動方向,可以是橫向或縱向。

改造原代碼

頁面結(jié)構(gòu)需要重新調(diào)整,將原先的 GridView 改成 SliverGrid,然后頂部區(qū)域需要使用 SliverToBoxAdapter進行包裹。每個區(qū)域的標題欄也需要單獨使用SliverToBoxAdapter 包裹起來。SliverToBoxAdapter使用很簡單,只需要將原有的組件設置為其 child 屬性即可。

Widget _headerGridButtons() {
  double height = 144;
  List<Map<String, String>> buttons = GridMockData.headerGrids();
  return SliverToBoxAdapter(
    child: Container(
      height: height,
      margin: EdgeInsets.fromLTRB(MARGIN, MARGIN, MARGIN, MARGIN / 2),
      decoration: BoxDecoration(
        borderRadius: BorderRadius.circular(4.0),
        gradient: LinearGradient(
            begin: Alignment.topCenter,
            end: Alignment.bottomCenter,
            colors: [
              Color(0xFF56AF6D),
              Color(0xFF56AA6D),
            ]),
      ),
      child: Center(
        child: Row(
            mainAxisAlignment: MainAxisAlignment.spaceEvenly,
            children: buttons
                .map((item) => _getMenus(item['icon'], item['name'],
                    color: Colors.white))
                .toList()),
      ),
    ),
  );
}

Widget _getMenuTitle(String title) {
  return SliverToBoxAdapter(
    child: Container(
      margin: EdgeInsets.fromLTRB(MARGIN, MARGIN, MARGIN, MARGIN / 2),
      padding: EdgeInsets.all(MARGIN),
      decoration: BoxDecoration(
        borderRadius: BorderRadius.circular(4.0),
        color: Colors.white,
      ),
      child: Text(
        title,
        style: TextStyle(color: Colors.grey[700]),
      ),
    ),
  );
}

GridView 我們之前使用的是 Grid.count() 方法,這里只需要更換為 SliverGrid.count()即可,參數(shù)基本相同,只是我們可以將之前禁止滑動的代碼刪除了。

//在 SliverGrid 中無需下面兩行代碼禁止滑動
shrinkWrap: true,
physics: NeverScrollableScrollPhysics(),

讓導航欄更有趣

在 Flutter 中提供了一個 SliverAppBar專門用于 CustomScrollView,該導航欄基本屬性和 AppBar 類似,但有些其他的屬性:

  • floating:浮動,即便是滾動視圖不在頂部,SliverAppBar也會跟隨滾動出現(xiàn)。
  • snap:手指放開時會根據(jù)當前狀態(tài)決定是否展開或收起。如果為 false,則導航欄會停留在上次滑動位置。
  • pinned:滾動到頂部后,導航欄是否可見,默認是 false。若為 false,則滾動出頂部后導航欄將消失。
  • expandedHeight:導航欄展開后的高度。
  • flexibleSpace:擴展彈性空間,即導航欄滑動時的收起或展開組件,可以有背景圖片和導航欄文字,當滑動到頂部后只顯示文字導航欄,當下滑后,會逐步顯示背景內(nèi)容,從而實現(xiàn)動態(tài)導航欄的效果。
SliverAppBar _getAppBar(String title) {
  return SliverAppBar(
    pinned: true,
    expandedHeight: 200,
    brightness: Brightness.dark,
    flexibleSpace: FlexibleSpaceBar(
      title: Text(title),
      background: Image.network(
        'https://ss1.bdstatic.com/70cFvXSh_Q1YnxGkpoWK1HF6hhy/it/u=688497718,308119011&fm=26&gp=0.jpg',
        fit: BoxFit.cover,
      ),
    ),
  );
}

改造后的代碼

改造后需要使用 Container 包裹,以設置背景顏色,多個 SliverXX 組件依次排列就可以完成拼接后一起滾動,相比使用 ListView 來說會更簡便,且效果更好。

@override
  Widget build(BuildContext context) {
    return Container(
      color: Colors.white,
      child: CustomScrollView(
        slivers: [
          _getAppBar('個人中心'),
          _headerGridButtons(),
          _getMenuTitle('金融理財'),
          _gridButtons(GridMockData.financeGrids()),
          _getMenuTitle('生活服務'),
          _gridButtons(GridMockData.serviceGrids()),
          _getMenuTitle('購物消費'),
          _gridButtons(GridMockData.thirdpartyGrids()),
        ],
      ),
    );
  }

其他效果

除了上述的效果外,F(xiàn)lutter 還提供了SliverPersistentHeader懸停頭部組件用于顯示懸停的表頭。具體可以參考對應文檔,這在需要展示頂部的功能切換欄或者表格表頭的時候很有用。

總結(jié)

本篇介紹了 CustomScrollView 的基本用法以及 SliverAppBar 的使用,通過 SliverAppBar 可以讓導航欄的滑動更有趣。在實際開發(fā)過程中,推薦在有多個滑動組件組合的時候優(yōu)先使用 CustomScrollView。

以上就是Flutter 利用CustomScrollView實現(xiàn)滑動效果的詳細內(nèi)容,更多關(guān)于Flutter 用CustomScrollView實現(xiàn)滑動的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android 曲線圖的繪制示例代碼

    Android 曲線圖的繪制示例代碼

    本篇文章主要介紹了Android 曲線圖的繪制示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • gradle配置國內(nèi)鏡像的實現(xiàn)

    gradle配置國內(nèi)鏡像的實現(xiàn)

    這篇文章主要介紹了gradle配置國內(nèi)鏡像的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • 超實用的android自定義log日志輸出工具類

    超實用的android自定義log日志輸出工具類

    這篇文章主要為大家詳細介紹了一個超實用的android自定義log日志輸出工具類,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Android?Fragment實現(xiàn)頂部、底部導航欄

    Android?Fragment實現(xiàn)頂部、底部導航欄

    這篇文章主要為大家詳細介紹了Android?Fragment實現(xiàn)頂部、底部導航欄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 解決Android webview設置cookie和cookie丟失的問題

    解決Android webview設置cookie和cookie丟失的問題

    這篇文章主要介紹了解決Android webview設置cookie和cookie丟失的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Android HTTP網(wǎng)絡請求的異步實現(xiàn)

    Android HTTP網(wǎng)絡請求的異步實現(xiàn)

    這篇文章主要介紹了Android HTTP網(wǎng)絡請求的異步實現(xiàn),感興趣的小伙伴們可以參考一下
    2016-07-07
  • 詳解在Flutter中如何使用dio

    詳解在Flutter中如何使用dio

    應用程序開發(fā)的一個關(guān)鍵部分是優(yōu)雅地處理網(wǎng)絡請求。網(wǎng)絡返回的響應可能包含意想不到的結(jié)果,為了獲得良好的用戶體驗,您需要提前處理邊緣情況。本文將詳細為大家介紹Flutter如何使用dio,需要的可以參考一下
    2022-04-04
  • Android調(diào)用應用安裝界面方法

    Android調(diào)用應用安裝界面方法

    大家好,本篇文章主要講的是Android調(diào)用應用安裝界面方法,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • Android Studio出現(xiàn)Failed to pull selection: open failed: Permission denied的解決思路

    Android Studio出現(xiàn)Failed to pull selection: open failed: Permi

    本篇文章給大家分享了Android Studio中導出數(shù)據(jù)庫文件的方法以及出現(xiàn)Failed to pull selection: open failed: Permission denied的解決思路,有興趣的學習下。
    2018-05-05
  • View Controller Transition實現(xiàn)京東加購物車效果

    View Controller Transition實現(xiàn)京東加購物車效果

    這篇文章主要介紹了View Controller Transition實現(xiàn)京東加購物車效果,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02

最新評論