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

Android簡單實用的可拖拽GridView組件分享

 更新時間:2023年06月28日 08:35:55   作者:島上碼農(nóng)  
在我們?nèi)粘i_發(fā)中,使用?GridView?這種網(wǎng)格視圖的場合還是不少的,本篇我們來介紹一個支持拖拽的?GridView?組件,可以輕松搞定網(wǎng)格視圖的拖拽排序,需要的可以參考一下

前言

在我們?nèi)粘i_發(fā)中,使用 GridView 這種網(wǎng)格視圖的場合還是不少的,比如照片墻、九宮格等等。有一個場景就是需要對網(wǎng)格的元素進行拖拽排序,這個時候 Flutter 自帶的GridView 就無法滿足了。本篇我們來介紹一個支持拖拽的 GridView 組件,可以輕松搞定網(wǎng)格視圖的拖拽排序,這個組件就是 flutter_draggable_gridview

GraggableGridView 使用

flutter_draggable_gridview使用一個DraggableGridViewBuilder來構(gòu)建可拖拽的 GridView,內(nèi)部實際上還是基于 GridView 實現(xiàn)的,因此 GridView 的一些配置還是可以沿用。DraggableGridViewBuilder的一些特有的屬性如下:

  • chidren:要求返回的子組件列表需要是 DraggableGridItem,實際上我們可以用DraggableGridItem來包裹我們要展示的元素即可。
  • isOnlyLongPress:是否只有長按才能觸發(fā)拖拽,默認是 true。
  • dragCompletion:完成拖拽后的回調(diào),會告訴我們哪兩個元素進行了位置互換,通過互換的元素的下標我們可以知道拖拽后的次序。如果需要保存的話就可以提交拖拽后的次序到后端更新。
  • dragFeedback:一個回調(diào)函數(shù),當拖拽開始后可以返回一個組件,來突顯正在被控制拖動的元素。通常是將原先的組件尺寸縮小。
  • dragPlaceHolder:元素被拖動后,留下的空白位置的占位組件,可以自定義任何組件。

正常使用的時候,基本上我們把這些屬性設(shè)置好就能用了。比如下面的代碼:

DraggableGridViewBuilder(
  gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
    crossAxisCount: 2,
    childAspectRatio: MediaQuery.of(context).size.width /
        (MediaQuery.of(context).size.height / 3),
  ),
  children: _makeGridItems(12),
  isOnlyLongPress: true,
  dragCompletion:
      (List<DraggableGridItem> list, int beforeIndex, int afterIndex) {
    if (kDebugMode) {
      print('onDragAccept: $beforeIndex -> $afterIndex');
    }
  },
  dragFeedback: (List<DraggableGridItem> list, int index) {
    return SizedBox(
      width: 200,
      height: 150,
      child: list[index].child,
    );
  },
  dragStartBehavior: DragStartBehavior.start,
  dragPlaceHolder: (List<DraggableGridItem> list, int index) {
    return PlaceHolderWidget(
      child: Container(
        color: Colors.blue[100],
      ),
    );
  },
)

這里的_makeGridItems方法就是構(gòu)建子元素列表的方法,實際上就是用DraggableGridItem包裹一層要顯示的組件。

List<DraggableGridItem> _makeGridItems(int count) {
  var colors = [
    Colors.blue,
    Colors.red[400],
    Colors.amber,
    Colors.orange,
    Colors.purple
  ];
  return List.generate(
    count,
    (index) => DraggableGridItem(
      isDraggable: true,
      child: Container(
        color: colors[index % colors.length],
        child: Center(
          child: Material(
            color: Colors.transparent,
            child: Text('$index'),
          ),
        ),
      ),
    ),
  );
}

DraggableGridItem還有兩個參數(shù)可以供我們使用:

  • isDraggable:是否可以拖拽, 默認是 false,比如我們有些元素是固定不可以改變的(如置頂元素),那么就可以設(shè)置為 false
  • dragCallback:在拖拽過程中,當一個元素正在被推擠時,回調(diào)函數(shù)中的第二個參數(shù) isDragging 會為 true。我們可以通過這個參數(shù)來做一些處理,比如高亮當前被推擠的元素。

我們有了上面的框架后,大部分情況下,只需要控制要顯示的子元素和尺寸就可以了,比如我們換成圖片,只需要更改_makeGridItems,將DraggableGridItemchild 的子組件更換為圖片組件就搞定了。

List<DraggableGridItem> _makeGridItems(int count) {
  var assetsName = [
    'images/earth.jpeg',
    'images/fire.png',
    'images/girl.jpeg',
    'images/island-coder.png',
    'images/mb.jpeg'
  ];
  return List.generate(
    count,
    (index) => DraggableGridItem(
      isDraggable: true,
      dragCallback: (_, isDragging) {
        debugPrint('{$index}在拖拽:{$isDragging}');
      },
      child: Image.asset(
        assetsName[index % assetsName.length],
        fit: BoxFit.cover,
      ),
    ),
  );
}

總結(jié)

本篇向大家推薦了一款簡單實用的可拖拽 GridView 組件,基本上可以滿足我們大部分支持拖拽的網(wǎng)格視圖應(yīng)用。大家如果有用過類似的組件,也歡迎在評論區(qū)推薦一下。

以上就是Android簡單實用的可拖拽GridView組件分享的詳細內(nèi)容,更多關(guān)于Android GridView組件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android UI自定義ListView實現(xiàn)下拉刷新和加載更多效果

    Android UI自定義ListView實現(xiàn)下拉刷新和加載更多效果

    這篇文章主要介紹了Android UI自定義ListView實現(xiàn)下拉刷新和加載更多效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 如何在Android中實現(xiàn)一個簡易的Http服務(wù)器

    如何在Android中實現(xiàn)一個簡易的Http服務(wù)器

    這篇文章主要介紹了如何在Android中實現(xiàn)一個簡易的Http服務(wù)器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Android基于OpenCV實現(xiàn)QR二維碼檢測

    Android基于OpenCV實現(xiàn)QR二維碼檢測

    QR碼比普通一維條碼具有快速讀取和更大的存儲資料容量,也無需要像一維條碼般在掃描時需要直線對準掃描儀。因此其應(yīng)用范圍已經(jīng)擴展到包括產(chǎn)品跟蹤,物品識別,文檔管理,庫存營銷等方面。本文講解Android基于OpenCV實現(xiàn)QR二維碼檢測的步驟
    2021-06-06
  • RecyclerView焦點跳轉(zhuǎn)BUG優(yōu)化的方法

    RecyclerView焦點跳轉(zhuǎn)BUG優(yōu)化的方法

    這篇文章主要介紹了RecyclerView焦點跳轉(zhuǎn)BUG優(yōu)化的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • Android apk 項目一鍵打包并上傳到蒲公英的實現(xiàn)方法

    Android apk 項目一鍵打包并上傳到蒲公英的實現(xiàn)方法

    這篇文章主要介紹了Android apk 項目一鍵打包并上傳到蒲公英,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Flutter實現(xiàn)下拉刷新和上拉加載更多

    Flutter實現(xiàn)下拉刷新和上拉加載更多

    這篇文章主要為大家詳細介紹了Flutter實現(xiàn)下拉刷新和上拉加載更多,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • MobLink Android端業(yè)務(wù)場景簡單說明

    MobLink Android端業(yè)務(wù)場景簡單說明

    這篇文章主要介紹了MobLink Android端業(yè)務(wù)場景簡單說明,MobLink的功能實現(xiàn)就是在分享前會將鏈接的參數(shù)信息保存到服務(wù)器,更多相關(guān)內(nèi)容需要的朋友可以參考一下
    2022-09-09
  • Android實現(xiàn)拍照及圖片顯示效果

    Android實現(xiàn)拍照及圖片顯示效果

    這篇文章主要為大家詳細介紹了Android實現(xiàn)拍照及圖片顯示效果 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • Android Jetpack組件之ViewModel使用詳解

    Android Jetpack組件之ViewModel使用詳解

    Android中的ViewModel是一個可以用來存儲UI相關(guān)的數(shù)據(jù)的類。ViewModel的生命周期會比創(chuàng)建它的Activity、Fragment的生命周期長,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-04-04
  • Android播放assets文件里視頻文件相關(guān)問題分析

    Android播放assets文件里視頻文件相關(guān)問題分析

    這篇文章主要介紹了Android播放assets文件里視頻文件相關(guān)問題分析,結(jié)合Android播放assets文件出現(xiàn)錯誤的實際問題給出了原因分析與解決方法參考,需要的朋友可以參考下
    2016-08-08

最新評論