我们在移动端加载页面的时候也经常遇到页面加载时间很长,没有明确的方法知道他是否正在加载,是在加载中还是已经加载完成了,所以为了用户体验,我们可以添加一个进度条。GeckoView为此提供了一个api——ProgressDelegate,用于观察一个网页的进程中界面。下面是针对不痛的状态的回调:
- onPageStart:在内容开始加载时调用。
- onPageStop:在内容加载完成时调用。
- onProgressChange:每当网页的进度更改时调用。
- onSecurityChange:指示安全状态何时更新。它传递一个
SecurityInformation
对象,该对象包含有关站点安全性的有用信息。
示例(kotlin):
private fun createProgressDelegate(): GeckoSession.ProgressDelegate {
return object : GeckoSession.ProgressDelegate {
override fun onPageStop(session: GeckoSession, success: Boolean) = Unit
override fun onSecurityChange(
session: GeckoSession,
securityInfo: GeckoSession.ProgressDelegate.SecurityInformation
) = Unit
override fun onPageStart(session: GeckoSession, url: String) = Unit
override fun onProgressChange(session: GeckoSession, progress: Int) {
progressView.progress = progress //这个是你自己定义的进度条
if (progress in 1..99) {
progressView.visibility = View.VISIBLE
} else {
progressView.visibility = View.GONE
}
}
}
}
geckoSession.progressDelegate = createProgressDelegate()