最近沒事寫了一個簡易瀏覽器,在剛開始寫的時候遇到一些問題,主要的問題就是如何在自己的webview中顯示所有的網頁數據,不過不指定自己的 webview顯示所有網頁數據則會調用系統默認的webview來加載數據,所以解決的辦法就是用webview的 setWebViewClient()方法設置自己的webviewclient對象,這個對象就是專門負責網頁url與webview綁定的類,重寫當中的shouldOverrideUrlLoading(WebView view, String url)方法,把view換成自己的webview就OK了。
當按回退鍵盤的時候返回歷史頁面可以重寫activity的onkeydown()方法攔截回退鍵事件,然後判斷webview.canGoBack(),返回true就webview.goback()就行了。
如過還想加上放大/放小 控制按鈕就必須先設置webView是支持zoomControls的,設置方法是通過 web_content.getSettings().setSupportZoom(true),然後通過 webview.getZoomControls()方法得到zoomControls的view,再通過 getWindow().getDecorView() .findViewById(android.R.id.content)得到webview的顯示內容的空間,現在就只用把剛剛得到得zoomControls加到webview的內容空間中就OK了。還有1個問題就是當webview上方出現
edittext空間時如果webview中也同時出現(比如:百度,google中的輸入框)時就會出現焦點衝突問題,解決方法就是實現webview 的setOnTouchListener事件,在事件中設置webview.requestFocus()就行了.
還是貼上源碼吧:
01 |
public void
onCreate(Bundle savedInstanceState) { |
02 |
super .onCreate(savedInstanceState); |
03 |
setContentView(R.layout.main); |
07 |
web_content = (WebView) findViewById(R.id.web_content); |
08 |
WebSettings set = web_content.getSettings(); |
09 |
set.setSupportZoom( true ); |
10 |
set.setJavaScriptEnabled( true ); |
11 |
set.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); |
13 |
View control = web_content.getZoomControls(); |
14 |
FrameLayout layout = (FrameLayout) getWindow().getDecorView() |
15 |
.findViewById(android.R.id.content); |
16 |
FrameLayout.LayoutParams params =
new FrameLayout.LayoutParams( |
17 |
FrameLayout.LayoutParams.WRAP_CONTENT, |
18 |
FrameLayout.LayoutParams.WRAP_CONTENT, Gravity.BOTTOM |
20 |
params.bottomMargin =
10 ; |
21 |
params.rightMargin =
10 ; |
22 |
layout.addView(control, params); |
24 |
web_content.setOnTouchListener( new
View.OnTouchListener() { |
27 |
public
boolean onTouch(View v, MotionEvent event) { |
28 |
web_content.requestFocus(); |
33 |
web_content.setWebViewClient( new
WebViewClient() { |
36 |
public
boolean shouldOverrideUrlLoading(WebView view, String url) { |
38 |
tx_address.setText(url); |
43 |
web_content.loadUrl(parseUrl(defaultPage)); |