您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關Android WebView怎么判斷是否滾動到底部的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
我們有時候需要彈一些必讀公告,但是呢可能會要去你看完之后才可以關掉,所以就需要滾動到底部才顯示關閉按鈕,而公告什么的往往又是基于富文本的,那么在展示在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方法下的自定義監聽
感謝各位的閱讀!關于“Android WebView怎么判斷是否滾動到底部”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。