大家好,本篇文章主要讲的是AndroidWebView如何判断是否滚动到底部,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
场景:
我们有时候需要弹一些必读公告,但是呢可能会要去你看完之后才可以关掉,所以就需要滚动到底部才显示关闭按钮,而公告什么的往往又是基于富文本的,那么在展示在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 WebView如何判断是否滚动到底部


基础教程推荐
- iOS中如何判断当前网络环境是2G/3G/4G/5G/WiFi 2023-06-18
- Android实现短信验证码输入框 2023-04-29
- Android开发Compose集成高德地图实例 2023-06-15
- iOS开发 全机型适配解决方法 2023-01-14
- Flutter进阶之实现动画效果(三) 2022-10-28
- Android Compose自定义TextField实现自定义的输入框 2023-05-13
- MVVMLight项目Model View结构及全局视图模型注入器 2023-05-07
- IOS获取系统相册中照片的示例代码 2023-01-03
- iOS Crash常规跟踪方法及Bugly集成运用详细介绍 2023-01-18
- iOS开发使用XML解析网络数据 2022-11-12