Android簡單實用的可拖拽GridView組件分享
前言
在我們?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
,將DraggableGridItem
的 child
的子組件更換為圖片組件就搞定了。
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)下拉刷新和加載更多效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11如何在Android中實現(xiàn)一個簡易的Http服務(wù)器
這篇文章主要介紹了如何在Android中實現(xiàn)一個簡易的Http服務(wù)器,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05Android基于OpenCV實現(xiàn)QR二維碼檢測
QR碼比普通一維條碼具有快速讀取和更大的存儲資料容量,也無需要像一維條碼般在掃描時需要直線對準掃描儀。因此其應(yīng)用范圍已經(jīng)擴展到包括產(chǎn)品跟蹤,物品識別,文檔管理,庫存營銷等方面。本文講解Android基于OpenCV實現(xiàn)QR二維碼檢測的步驟2021-06-06RecyclerView焦點跳轉(zhuǎn)BUG優(yōu)化的方法
這篇文章主要介紹了RecyclerView焦點跳轉(zhuǎn)BUG優(yōu)化的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04Android apk 項目一鍵打包并上傳到蒲公英的實現(xiàn)方法
這篇文章主要介紹了Android apk 項目一鍵打包并上傳到蒲公英,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06MobLink Android端業(yè)務(wù)場景簡單說明
這篇文章主要介紹了MobLink Android端業(yè)務(wù)場景簡單說明,MobLink的功能實現(xiàn)就是在分享前會將鏈接的參數(shù)信息保存到服務(wù)器,更多相關(guān)內(nèi)容需要的朋友可以參考一下2022-09-09Android Jetpack組件之ViewModel使用詳解
Android中的ViewModel是一個可以用來存儲UI相關(guān)的數(shù)據(jù)的類。ViewModel的生命周期會比創(chuàng)建它的Activity、Fragment的生命周期長,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-04-04Android播放assets文件里視頻文件相關(guān)問題分析
這篇文章主要介紹了Android播放assets文件里視頻文件相關(guān)問題分析,結(jié)合Android播放assets文件出現(xiàn)錯誤的實際問題給出了原因分析與解決方法參考,需要的朋友可以參考下2016-08-08