GeckoSession
这是一个将所有这些配置都放在一个地方的对象,使使用它变得简单而直接。这个强大的概念将GeckoView
视图与GeckoSession
状态解耦。这样,你可以拥有一个GeckoView
视图负责渲染和多个会话GeckoSession
以表示每个选项卡的状态。
这个使用很难实现WebView
。由于缺少会话,因此它将配置直接应用于视图
1、session.open(runtime)
打开会话,当准备好使用GeckoSession实例时,调用open。首次创建会话时,会话处于“关闭”状态。打开它会创建加载页面等所需的底层Gecko对象大多数GeckoSession方法只在打开的会话上生效,并且在此处打开会话之前一直排队。打开会话是一个异步操作
2、加载网页
session.load("http://www.baidu.com");
session.loadUri(new Loader().uri("http://www.baidu.com"));
3、session.setActive(true/false)
将此GeckoSession设置为active或inactive,这表示会话当前是否可见。将GeckoSession设置为inactive将显著减少其内存占用,但只有当GeckoSession当前不可见时才应该这样做。请注意,会话可以是活动的(即可见的),但不能是集中的。当会话设置为非活动时,它将刷新会话状态并触发“ProgressDelegate.onSessionStateChange”回调。
GeckoSessionSettings
自定义会话行为的一个好方法是提供GeckoSessionSettings对象。您可以通过将settings对象传递给GeckoSession构造函数来实现这一点。
可以使用其生成器创建设置对象GeckoSessionSettings.Builder(),示例:
GeckoSessionSettings settings = GeckoSessionSettings.Builder()
.usePrivateMode(true)
.useTrackingProtection(true)
.userAgentMode(USER_AGENT_MODE_MOBILE)
.userAgentOverride("")
.suspendMediaWhenInactive(true)
.allowJavascript(true)
api解释:
- usePrivateMode:指示会话是否应为私有。
- useTrackingProtection:指示是否应启用跟踪保护。
- userAgentMode:指示页面布局。您可以使用以下选项:
USER_AGENT_MODE_DESKTOP:启用桌面模式。
USER_AGENT_MODE_MOBILE:禁用桌面模式。
USER_AGENT_MODE_VR:VR体验的布局。 - userAgentOverride:更改用户代理标识符。
- suspendMediaWhenInactive:指示在应用程序挂起时媒体是否应继续播放。
- allowJavascript:指示是否应启用JavaScript。
请注意,每个GeckoSession
对象都有其自己的设置对象。这使您可以进行大量自定义,而无需创建的多个实例GeckoView
。