日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Android?WebView如何判斷是否滾動到底部_Android

作者:Laikyy ? 更新時間: 2022-04-02 編程語言

場景:

我們有時候需要彈一些必讀公告,但是呢可能會要去你看完之后才可以關掉,所以就需要滾動到底部才顯示關閉按鈕,而公告什么的往往又是基于富文本的,那么在展示在Android上時就要用到WebView,基于這個要求就有了判斷 WebView 判斷是否滾動到底部。

分析:

要判斷是否到底部那么我們先來分析有哪幾種情況,當html文檔加載到WebView后會有一下兩種情況。

WebView里的html內容沒有填充滿,就是無滾動條情況。html內容的高度比WebView控件高,這時候就會有滾動條,即有滾動條

對于情況1,沒有滾動條我們直接顯示關閉按鈕就可,但對于第二種有滾動條情況就需要計算高度即:html高度 = WebView高度 + 滾動條長度 那么這時就可判斷為滾動條到達了底部

實現:

html高度 <= WebView高度 + 滾動條長度 即可視為到達底部

注意:必須要控件初始化好后去獲取高度,不然獲取的高度是0

以下是實現

 x5WebView?.let {
    it.webViewClient = object : WebViewClient() {
	    override fun onPageFinished(
	           view: WebView,
	           url: String
	       ) {
	           super.onPageFinished(view, url)
	           postSafeDelayed(1000) {
	               loading_pb.visibility = View.GONE
	           }
	           //頁面加載完判斷是否到底部邏輯
	           view.post {
	                view.measure(0, 0)
	                val htmlContentHeight: Int = view.getMeasuredHeight()
	                val viewHeight: Int = view.getHeight()
	                //如果html高度小于控件高度,那么說明一屏可以展示下直接顯示關閉按鈕
	                if(htmlContentHeight <= viewHeight){
	                	// TODO 顯示關閉按鈕
	                }else{
	                //這里說明有滾動條,就需要監聽滾動事件
	                	view?.setOnCustomScrollChangedListener(object : WebView.CustomScrollChangeListener{
                        override fun onScrollChange(
                            scrollX: Int,
                            scrollY: Int,
                            oldScrollX: Int,
                            oldScrollY: Int
                        ) {
                            Timber.w("setOnCustomScrollChangedListener 滾動底部,html高度:${htmlContentHeight},scrollY:${scrollY}")
                            //已經處于底端
                            if(htmlContentHeight - (viewHeight + scrollY) <= 0){
                                Timber.w("setOnCustomScrollChangedListener 到達底部")
                                //TODO 到達底部
                            }
                        }
                    })
	                }
                
				}
	       }
	   	}
  }
}

以上就是實現,WebView.CustomScrollChangeListener這個事件是自己在WebView上定義的,監聽的是WebView的onScrollChanged方法下的自定義監聽

總結

原文鏈接:https://blog.csdn.net/Laikyy/article/details/122570556

欄目分類
最近更新