}
object AutoService {
fun load(clazz: Class): S? {
val service = ServiceLoader.load(clazz).iterator()
try {
if (service.hasNext()) {
return service.next()
}
} catch (e: Exception) {
e.printStackTrace()
}
return null
}
}
以上就完成了 组件化的初步构建,结构如下图
![](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9wOS1qdWVqaW4uYnl0ZWltZy5jb20vdG9zLWNuLWktazN1MWZicGZjcC9hMTNlM Android开源项目《ali1024.coding.net/public/P7/Android/git》 DExOWJjNGI0OWQ4YWUxY2FhMzQzNDgyMjdmZn50cGx2LWszdTFmYnBmY3Atem9vbS0xLmltYWdl?x-oss-process=image/format,png)
3. WebView 组件封装
1).WebView 的组成部分
WebView由四个部分组成的:
2).创建视图
① 创建 WebActivity & WebFragment & BaseWebView & IWebCallBack
IWebCallBack:Web页面打开时 WebViewClient 和 WebChromeClient 事件监听。
WebActivity: Web页面的入口、IWebCallBack 实现监听并统一管理页面。
WebFragment:返回一个统一事件处理的 Fragment 页面。
BaseWebView:自定义 WebView 统一配置 WebSettings 属性、由 IWebCallBack 将 WebViewClient 和 WebChromeClient 事件回调给 WebActivity 或 WebFragment;
并配置 JavascriptInterface 方法用于接收 Web 事件、统一处理。
3).跨进程通信
Web 页面所需要的内存比较大,为了避免 WebView 的OOM造成 App 的崩溃,需将Web 页面运行在独立的进程,跨进程通信使用 AIDL。
① 为了方便