flutter 中監(jiān)聽滑動事件
在移動端,各個平臺或 UI 系統(tǒng)的原始指針事件模型基本都是一致,即:一次完整的事件分為三個階段:手指按下、手指移動、和手指抬起,而更高級別的手勢(如點擊、雙擊、拖動等)都是基于這些原始事件的。
Flutter 中可以使用 Listener widget 來監(jiān)聽原始觸摸事件,它也是一個功能性 widget。
Listener 的常見屬性
| 屬性 | 類型 | 說明 |
|---|---|---|
| onPointerDown | (PointerDownEvent event){} | 手指按下時觸發(fā) |
| onPointerMove | (PointerDownEvent event){} | 手指在屏幕滑動時觸發(fā) |
| onPointerUp | (PointerDownEvent event){} | 手指離開屏幕時觸發(fā) |
| onPointerCancel | (PointerDownEvent event){} | 取消觸摸時觸發(fā) |
Listener({
Key key,
this.onPointerDown, //手指按下回調(diào)
this.onPointerMove, //手指移動回調(diào)
this.onPointerUp,//手指抬起回調(diào)
this.onPointerCancel,//觸摸事件取消回調(diào)
this.behavior = HitTestBehavior.deferToChild, //在命中測試期間如何表現(xiàn)
Widget child
})
用法如下:
Listener(
onPointerDown: (dowPointEvent){},
onPointerMove: (movePointEvent){},
onPointerUp: (upPointEvent){},
child: Container(
child: Text('Listener的監(jiān)聽')
)
);
使用場景一: 下拉刷新,上拉加載
如果實現(xiàn)下拉刷新,必須借助 RefreshIndicator,在 listview 外面包裹一層 RefreshIndicator,然后在 RefreshIndicator 里面實現(xiàn) onRefresh 方法。監(jiān)聽的方法有很多種,就不一一闡述了,這里主要說一下經(jīng)常使用的兩種方法。
/// 下拉刷新,這里必須使用async,不然會報錯
Future<Null> _refresh() async {
final Completer<Null> completer = new Completer<Null>();
_dataList.clear(); // 清空數(shù)據(jù)
setState(() {
page = 1;
});
loadData(completer); // 加載數(shù)據(jù)
return completer.future;
}
加載更多需要對 ListView 進(jìn)行監(jiān)聽,所以需要進(jìn)行監(jiān)聽器的設(shè)置,在 State 中進(jìn)行監(jiān)聽器的初始化。
ScrollController _scrollController = new ScrollController(); // 初始化滾動監(jiān)聽器,加載更多使用
1、直接監(jiān)聽_scrollController,根據(jù)是否滑動到底部來判斷是否需要加載更多
_scrollController.addListener(() {
// 如果滑動到底部
if (_scrollController.position.pixels == _scrollController.position.maxScrollExtent) {
// do something
}
});
RefreshIndicator(
onRefresh: _refresh, // 下拉刷新
child: ListView.builder(
padding: EdgeInsets.only(bottom: Adapt.px(40)),
shrinkWrap: true,
controller: _scrollController,
physics: AlwaysScrollableScrollPhysics(),
itemCount: _dataList.length,
itemBuilder: (context, item) {
return listCard(_dataList[item]);
}
)
)
2、使用上述的 Listener 來監(jiān)聽,通過 Listener 的 onPointerMove(手指在屏幕上滑動)來監(jiān)聽滑動的距離,當(dāng)滑動到底部時加載更多數(shù)據(jù)
new Listener(
onPointerMove: (event) {
var position = event.position.distance;
var detal = position - lastDownY;
if (detal > 0) {
print("================向下移動================");
} else {
// 所摸點長度 +滑動距離 = IistView的長度 說明到達(dá)底部
print("================向上移動================");
print("scrollController==滑動距離=======${(position - downY)}");
var scrollExtent = scrollController.position.maxScrollExtent;
print("scrollController==ListView最大長度===${scrollExtent}");
print("scrollController==所摸點長度===${scrollController.offset}");
print("scrollController==所摸點離屏幕距離===${position}");
var result = scrollController.offset +(position - downY).abs();
if (result >= scrollExtent) {
print("scrollController====到達(dá)底部");
lastListLength = scrollExtent;
loadMore(); // 加載更多數(shù)據(jù)
}
}
lastDownY = position;
},
child: new ListView.builder(
controller: scrollController,
itemCount: datas == null ? 0 : datas.length,
itemBuilder: (BuildContext context, int index) {
return Container(child: Text('列表${index}') )
}
)
);
使用場景二 , 滑動屏幕時,隱藏掉鍵盤
日常使用 TextField 時候,彈出來的鍵盤如果是按鈕提交有時候會出現(xiàn)鍵盤不自動隱藏關(guān)閉的情況,可以觸發(fā)關(guān)閉彈出來的鍵盤。
FocusScope.of(context).requestFocus(FocusNode());
// 或者
FocusNode _foucusNode = new FocusNode();
_foucusNode.unfocus();
使用 Listener 監(jiān)聽,在滑動屏幕的時候關(guān)閉鍵盤
Listener(
onPointerMove: (movePointEvent){
_foucusNode.unfocus();
},
child: return SingleChildScrollView(
controller: _scrollController,
child: Column(
children: <Widget>[
// some widget
],
)
)
)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android getViewById和getLayoutInflater().inflate()的詳解及比較
這篇文章主要介紹了Android getViewById和getLayoutInflater().inflate()的詳解及比較的相關(guān)資料,這里對這兩種方法進(jìn)行了詳細(xì)的對比,對于開始學(xué)習(xí)Android的朋友使用這兩種方法是個很好的資料,需要的朋友可以參考下2016-11-11
Android實現(xiàn)應(yīng)用內(nèi)置語言切換功能
這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)應(yīng)用內(nèi)置語言切換功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02
Android基于RecyclerView實現(xiàn)高亮搜索列表
本文詳細(xì)介紹了Android基于RecyclerView實現(xiàn)高亮搜索列表的方法。具有一定的參考價值,下面跟著小編一起來看下吧2017-01-01
Android EditText限制輸入字符類型的方法總結(jié)
這篇文章主要介紹了Android EditText限制輸入字符類型的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-03-03

