pb自定义控件 事件_Android WebView与下拉刷新控件滑动冲突的解决方法
生活随笔
收集整理的這篇文章主要介紹了
pb自定义控件 事件_Android WebView与下拉刷新控件滑动冲突的解决方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
? 使用WebView時一般會在外層使用下拉刷新控件如(SwipeRefreshLayout)。但是測試時會發現網頁無法上拉,往上滑動就會觸發下拉刷新控件的refresh事件。所以這里記錄一下解決該問題的辦法。
???1、通過webView.getScrollY() 的值來判斷是否滾動到頂部
private SwipeRefreshLayout mSwipe;mSwipe.setColorSchemeResources(R.color.green_ying_guang, R.color.goods_price_size, R.color.colorRed);/* * 設置下拉刷新的監聽 */mSwipe.setOnRefreshListener(() -> {//刷新需執行的操作 webView.reload(); mSwipe.setRefreshing(false);});mSwipe.setOnChildScrollUpCallback(new SwipeRefreshLayout.OnChildScrollUpCallback() {@Override public boolean canChildScrollUp(@NonNull SwipeRefreshLayout swipeRefreshLayout, @Nullable View view) { return webView.getScrollY()>0;}
});這方法適用于html端是一個類似于線性布局的,內部控件沒有上下滑動的監聽。如果html內部有控件監聽了上下滑動,就會有滑動沖突,所以需要方法2來解決。
2、自定義webview
在onTouchEvent中監聽DOWN事件,然后設置mScrolly的值為1,這樣在子布局消耗完滑動事件前,mScrolly的值一直為1,SwipeRefreshLayout就不會攔截滑動事件(方法1中設置了mScrolly>0時不攔截)
@Overridepublic boolean onTouchEvent(MotionEvent event) {switch (event.getAction()) {case MotionEvent.ACTION_DOWN:if (this.getScrollY() <= 0)this.scrollTo(0, 1); break; default:break; }return super.onTouchEvent(event);}以上方法試用于絕大多數的webview下拉刷新滑動沖突,如果有不適用的,請聯系作者。
總結
以上是生活随笔為你收集整理的pb自定义控件 事件_Android WebView与下拉刷新控件滑动冲突的解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ssh linux 配置文件详解,Lin
- 下一篇: android fragment 管理器