Settings是WebView提供給上層App的一個配置Webview的接口,每個WebView都有一個WebSettings,要控制WebView的行為,只能通過WebView.getSettings()獲取WebSettings對象的引用,然後再改變它的屬性。
Browser有一個BrowserSettings用來管理所有的配置信息,它是一個單鍵(Singleton)。BrowserSettings是直接管理WebSettings的,而UI部分則是由BrowserPreferencePage和Fragment來完成。BrowserSettings實現了OnSharedPreferenceChangedListener,當某個配置項發生變化時,BrowserSettings的接口onPreferencesChanged就會被回調到,然後BrowserSettings就會把配置通過WebSettings應用到WebView中,所以這些Settings都是及時生效的。
一共有三類Settings:共享Settings,靜態Settings和動態Settings。靜態就是不會在Browser運行時發生變化的,也就是說在Browser的Settings中無法改變的一些配置,這些跟應用程序內部關聯較多,比如應用程序的數據存放地點等,而與用戶層關系不多;共享Settings是獨立於WebView的,也就是說它被系統內所有WebView共享的一些配置,比如Cookie,它不需要為每個WebView單獨配置。動態Settings就是用於動態配置WebView的,比如字體,縮放,是否加載圖片,是否啟用JavaScript等等。
初始化
因為Browser可以有多個窗口,每一個窗口都會有一個WebView,也就是說Browser會管理多個WebView,所以BrowserSettings也要管理多個WebSettings,因為每一個配置的改變都要應用到所有的WebView中。為了能讓BrowserSettings能夠管理多個WebSettings,它必須持有對這些WebSettings的引用。Browser在創建WebView的時候會把WebView的配置WebSettings通過接口放到BrowserSettings中,BrowserSettings中有一個列表,用於持有對WebSettings的引用。具體的BrowserWebViewFactory中的initWebViewSettings()方法會在每次創建WebView後調用,它把WebView的WebSettings取出,做些必要的初始化,然後放到BrowserSettings中,BrowserSettings.startManagingSettings()會加載SharedPreference文件中的信息對此WebSettings進行初始化,然後放到mManagedSettings列表中。
配置變更
用戶進入Settings界面,進行配置的更改,每當有配置發生變化BrowserSettings.onSharedPreferencesChanged()會被回調到,它就會做syncManagedSettings()的動作,把共享設置同步到底層去(也即把設置同步到Cookiemanager中),再遍歷列表mManagedSettings,把mPref中的信息全部同步到每個WebSettings中,這樣所有的WebView都會實時的響應配置變更。
設置的界面和BrowserSettings沒有直接的關聯,界面是通過PreferenceActivity和Fragment把各種Settings呈現給用戶,而BrowserSettings是把配置信息同步給WebView也就是讓配置生效。它們之間的信息橋梁是SharedPreference,也就是說PreferenceActivity和Fragment從用戶處接收配置信息,然後放到SharedPreference中,BrowserSettings監聽SharedPreference的變化,再把SharedPreference同步給WebView。