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如何判断是否滚动到底部的文章就介绍到这了,更多相关Android WebView滚动到底部内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Android Studio 如何删除/新建一个module(图文教程详解)
这篇文章主要介绍了Android Studio 如何删除/新建一个module,此方法也会将该module从你的硬盘中删除,如果直接右键会发现没有delete选项,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友参考下吧2020-03-03Android开发之利用Activity实现Dialog对话框
这篇文章主要给大家介绍了Android开发之如何利用Activity实现Dialog对话框效果,文中给出了详细的示例代码,相信对大家的理解及学习具有一定的参考借鉴价值,有需要的朋友们下面来一起看看吧。2016-12-12Android开发中Activity的生命周期及加载模式详解
这篇文章主要介绍了Android开发中Activity的生命周期及加载模式详解的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下2016-05-05android仿知乎ScrollView滚动改变标题栏透明度
这篇文章主要为大家详细介绍了android仿知乎ScrollView滚动改变标题栏透明度,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-06-06
最新评论