91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android?Flutter如何實現有趣的頁面滾動效果

發布時間:2022-06-15 16:08:51 來源:億速云 閱讀:217 作者:iii 欄目:開發技術

本文小編為大家詳細介紹“Android Flutter如何實現有趣的頁面滾動效果”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Android Flutter如何實現有趣的頁面滾動效果”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

在Flutter 高仿一個某支付價值幾個億的頁面這一篇中,我們使用了 ListView 將幾個 GridView 組合在一起實現了不同可滑動組件的粘合,但是這里必須要設置禁止 GridView 的滑動,防止多個滑動組件的沖突。這種方式寫起來不太方便,事實上 Flutter 提供了 CustomScrollView 來粘合多個滑動組件,并且可以實現更有趣的滑動效果。

Android?Flutter如何實現有趣的頁面滾動效果

CustomScrollView 簡介

CustomScrollView的常用屬性如下:

  • slivers:最重要的屬性,由多個SliverXX組件組成的數組,包括如 SliverList(對應 ListView),SliverGrid(對應 GridView)等,如果普通組件無法直接使用,而需要使用SliverToBoxAdapter包裹。

  • reverse:是否反向滾動,如果為 true,則反方向滾動。

  • scrollDirection:滾動方向,可以是橫向或縱向。

改造原代碼

頁面結構需要重新調整,將原先的 GridView 改成 SliverGrid,然后頂部區域需要使用 SliverToBoxAdapter進行包裹。每個區域的標題欄也需要單獨使用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()即可,參數基本相同,只是我們可以將之前禁止滑動的代碼刪除了。

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

讓導航欄更有趣

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

  • floating:浮動,即便是滾動視圖不在頂部,SliverAppBar也會跟隨滾動出現。

  • snap:手指放開時會根據當前狀態決定是否展開或收起。如果為 false,則導航欄會停留在上次滑動位置。

  • pinned:滾動到頂部后,導航欄是否可見,默認是 false。若為 false,則滾動出頂部后導航欄將消失。

  • expandedHeight:導航欄展開后的高度。

  • flexibleSpace:擴展彈性空間,即導航欄滑動時的收起或展開組件,可以有背景圖片和導航欄文字,當滑動到頂部后只顯示文字導航欄,當下滑后,會逐步顯示背景內容,從而實現動態導航欄的效果。

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 包裹,以設置背景顏色,多個 Sliver 組件依次排列就可以完成拼接后一起滾動,相比使用 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()),
        ],
      ),
    );
  }

讀到這里,這篇“Android Flutter如何實現有趣的頁面滾動效果”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

西安市| 青铜峡市| 陆河县| 团风县| 阿克陶县| 三穗县| 和田市| 邵东县| 哈巴河县| 潮安县| 贺州市| 台南县| 淳安县| 罗山县| 荔浦县| 仁化县| 黄梅县| 罗田县| 绩溪县| 沂水县| 界首市| 盘山县| 赤城县| 临夏市| 留坝县| 隆回县| 宿松县| 丰宁| 平舆县| 延吉市| 滁州市| 比如县| 东宁县| 万山特区| 资源县| 同仁县| 崇义县| 林芝县| 河西区| 蒙山县| 玉溪市|