1.webkit架构
1.1 简介
android平台的Webkit模块可以分成Java和WebKit库2个部分。
1.2 Webkit目录结构
WebKit模块目录结构 |
|
根目录frameworks\base\core\java\android\webkit |
|
BrowserFrame.java |
BrowserFrame对象是对WebCore库中的Frame对象的Java层封装,用于创建WebCore中定义的Frame,以及为该Frame对象提供Java层回调方法。 |
ByteArrayBuilder.java |
ByteArrayBuilder辅助对象,用于byte块链表的处理。 |
CachLoader.java |
URL Cache载入器对象,该对象实现StreadLoader抽象基类,用于通过CacheResult对象载入内容数据。 |
CacheManager.java |
Cache管理对象,负责Java层Cache对象管理 |
CacheSyncManager.java |
Cache同步管理对象,负责同步RAM和FLASH之间的浏览器Cache数据。实际的物理数据操作在WebSyncManager对象中完成。 |
CallbackProxy.java |
该对象是用于处理WebCore与UI线程消息的代理类。当有Web事件产生时WebCore线程会调用该回调代理类,代理类会通过消息的方式通知UI线程,并且调用设置的客户对象的回调函数。 |
CellList.java |
CellList定义图片集合中的Cell,管理Cell图片的绘制、状态改变以及索引。 |
CookieManager.java |
根据RFC2109规范,管理cookies |
CookieSyncManager.java |
Cookies同步管理对象,该对象负责同步RAM和Flash之间的Cookies数据。实际的物理数据操作在基类WebSyncManager中完成。 |
DataLoader.java |
数据载入器对象,用于载入网页数据。 |
DateSorter.java |
尚未使用 |
DownloadListener.java |
下载侦听器接口 |
DownloadManagerCore.java |
下载管理器对象,管理下载列表。该对象运行在WebKit的线程中,通过CallbackProxy对象与UI线程交互。 |
FileLoader.java |
文件载入器,将文件数据载入到Frame中。 |
FrameLoader.java |
Frame载入器,用于载入网页Frame数据 |
HttpAuthHandler.java |
Http认证处理对象,该对象会作为参数传递给BrowserCallback.displayHttpAuthDialog方法,与用户交互。 |
HttpDataTime.java |
该对象是处理HTTP日期的辅助对象。 |
JsConfirmResult.java |
Js确认请求对象 |
JsPromptResult.java |
Js结果提示对象,用于向用户提示Javascript运行结果。 |
JsResult.java |
Js结果对象,用于用户交互 |
JWebCoreJavaBridge.java |
用Java与WebCore库中Timer和Cookies对象交互的桥接代码。 |
LoadListener.java |
载入器侦听器,用于处理载入器侦听消息。 |
Network.java |
该对象封装网络连接逻辑,为调用者提供更为高级的网络连接接口。 |
PanZoom.java |
用于处理图片缩放、移动等操作 |
PanZoomCellList.java |
用于保存移动、缩放图片的Cell |
PerfChecker.java |
用于效率测试的功能对象??? |
SslErrorHandler.java |
用于处理SSL错误消息。 |
StreamLoader.java |
StreamLoader抽象类是所有内容载入器对象的基类。该类是通过消息方式控制的状态机,用于将数据载入到Frame中。 |
TextDialog.java |
用于处理html中文本区域叠加情况,可以使用标准的文本编辑而定义的特殊EditText控件。 |
URLUtil.java |
URL处理功能函数,用于编码、解码URL字符串,以及提供附加的URL类型分析功能。 |
WebBackForwardList.java |
该对象包含WebView对象中显示的历史数据。 |
WebBackForwardListClient.java |
浏览历史处理的客户接口类,所有需要接收浏览历史改变的类都需要实现该接口。 |
WebChromeClient.java |
Chrome客户基类,Chrome客户对象在浏览器文档标题、进度条、图标改变时候会得到通知。 |
WebHistoryItem.java |
该对象用于保存一条网页历史数据 |
WebIconDataBase.java |
图表数据库管理对象,所有的WebView均请求相同的图标数据库对象。 |
WebSettings.java |
WebView的管理设置数据,该对象数据是通过JNI接口从底层获取。 |
WebSyncManager.java |
数据同步对象,用于RAM数据和FLASH数据的同步操作。 |
WebView.java |
Web视图对象,用于基本的网页数据载入、显示等UI操作。 |
WebViewClient.java |
Web视图客户对象,在Web视图中有事件产生时,该对象可以获得通知。 |
WebViewCore.java |
该对象对WebCore库进行了封装,将UI线程中的数据请求发送给WebCore处理,并且通过CallbackProxy的方式,通过消息通知UI线程数据处理的结果。 |
WebViewDatabase.java |
该对象使用SQLiteDatabase为WebCore模块提供数据存取操作。 |
1.3整体框架结构
JNI和Bridge起到中介作用。
1.4顶端的Java层
1. WebView视图类
WebView类是WebKit模块Java层的视图类,所有需要使用Web浏览功能的Android应用程序都要创建该视图对象显示和处理请求的网络资源。目前,WebKit模块支持HTTP、HTTPS、FTP以及javascript请求。WebView作为应用程序的UI接口,为用户提供了一系列的网页浏览、用户交互接口,客户程序通过这些接口访问WebKit核心代码。
2. WebViewDatabase封装类
WebViewDatabase是WebKit模块中针对SQLiteDatabase对象的封装,用于存储和获取运行时浏览器保存的缓冲数据、历史访问数据、浏览器配置数据等。该对象是一个单实例对象,通过getInstance方法获取WebViewDatabase的实例。WebViewDatabase是WebKit模块中的内部对象,仅供WebKit框架内部使用。
3. WebViewCore交互类
WebViewCore类是Java层与C层WebKit核心库的交互类,客户程序调用WebView的网页浏览相关操作会转发给BrowserFrame对象。当WebKit核心库完成实际的数据分析和处理后会回调WebViweCore中定义的一系列JNI接口,这些接口会通过CallbackProxy将相关事件通知相应的UI对象。
4. CallbackProxy代理类
CallbackProxy是一个代理类,用于UI线程和WebCore线程交互。该类定义了一系列与用户相关的通知方法,当WebCore完成相应的数据处理,则会调用CallbackProxy类中对应的方法,这些方法通过消息方式间接调用相应处理对象的处理方法。详细的处理流程在下文中会具体分析。
5. WebViewClient
WebViewClient类定义了一系列事件方法,如果Android应用程序设置了WebViewClient派生对象,则在页面载入、资源载入、页面访问错误等情况发生时,该派生对象的相应方法会被调用。
6. WebChromeClient
WebChromeClient类定义了与浏览窗口修饰相关的事件。例如接收到Title、接收到Icon、进度变化时,WebChromeClient的相应方法会被调用。
1.5底部的C层
java层 ——————> c层
WebView WebViewNative
WebViewNative中的mJavaGlue保存了WebView中定义的属性ID和方法ID,,其构造方法WebViewNative负责初始化,并将构造的WebViewNative对象的指针赋值给变量mNativeClass。
LoadListener struct resourceloader_t
struct resourceloader_t 结构中保存了LoaderListener对象的ID、cancelMethod ID,当有cancel或download事件产生时,WebCore会回调类CancelMethod或DownloadFileMethod。
BrowserFrame FrameBriage
FrameBriage类为Dalvik虚拟机回调BrowserFrame类中定义的本地方法进行封装,在FameBriage构造函数中,BrowserFrame类的回调方法的偏移量初始化JavaBrowserFrame构造的各个域。
2.WebView
2.1访问网页
webview=(webView)findViewById(R.id.wb); webview.loadUrl(url);
显示互联网
webview,loadUrl("http://www.baidu.com");
显示本地文件
webview.loadUrl("file://android_asset/index.html");
2.2常用设置
addJavascriptInterface(Object object ,StringinterfaceName)//使用此函数来绑定一个对象的Javascript,该方法可以访问Javascript
setDefaultFontsize()//设置字体
setDefaultZoom();//设置屏幕的缩放级别
setPluginsEnabled();//设置允许Gears插件显示flash动画的功能
setjavaScriptEnabled();//设置是否执行Javascript脚本
setBuildInZoomControls ();//设置支持缩放
2.3 WebView实现方式
1.在布局文件中声明WebView
2.在Activity中实例化WebView,设置要求
3.调用WebView的loadUrl()方法
4.让WebView响应超链接,调用setWebViewClient()方法,设置WebView视图
5.(注意)WebView点击链接很多页后,为了WebView支持回退功能,需要覆盖Activity的onKeyDown()方法,如果不做处理,点击系统back键,整个浏览器会调用finish ()而结束,而不是回退到上一页。
6.在androidMainfest.xml添加权限
<uses-permission android:name="android.permission.INTERNET"/>
eg1.webview实现
public class MainActivity extends ActionBarActivity { private WebView webView; String url="http://www.51cto.com"; @SuppressLint({ "SetJavaScriptEnabled", "NewApi" }) @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); webView=(WebView)findViewById(R.id.webView); webView.getSettings().setJavaScriptEnabled(true); webView.getSettings().setAllowContentAccess(true); webView.getSettings().setAllowFileAccess(true); webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE); webView.setLayerType(View.LAYER_TYPE_SOFTWARE, null); webView.loadUrl(url); webView.setWebViewClient(new HelloWebViewClient());//将每个新开的activity填入web视图中 } public boolean onKeyDown(int keycode ,KeyEvent key) { if((keycode==KeyEvent.KEYCODE_BACK) && webView.canGoBack()) { webView.goBack(); return true; } return false; } public class HelloWebViewClient extends WebViewClient { public boolean shouldOverrideUrlLoading(WebView view,String url)//在用户试图点开页面上的某个链接时被调用 { view.loadUrl(url); return true; } } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } }