最近沒事寫了一個簡易瀏覽器,在剛開始寫的時候遇到一些問題,主要的問題就是如何在自己的webview中顯示所有的網(wǎng)頁數(shù)據(jù),不過不指定自己的webview顯示所有網(wǎng)頁數(shù)據(jù)則會調(diào)用系統(tǒng)默認(rèn)的webview來加載數(shù)據(jù),所以解決的辦法就是用webview的setWebViewClient()方法設(shè)置自己的webviewclient對象,這個對象就是專門負(fù)責(zé)網(wǎng)頁url與webview綁定的類,重寫當(dāng)中的shouldOverrideUrlLoading(WebView view, String url)方法,把view換成自己的webview就OK了。
當(dāng)按回退鍵盤的時候返回歷史頁面可以重寫activity的onkeydown()方法攔截回退鍵事件,然后判斷webview.canGoBack(),返回true就webview.goback()就行了。
如過還想加上放大/放小 控制按鈕就必須先設(shè)置webView是支持zoomControls的,設(shè)置方法是通過web_content.getSettings().setSupportZoom(true),然后通過webview.getZoomControls()方法得到zoomControls的view,再通過getWindow().getDecorView() .findViewById(Android.R.id.content)得到webview的顯示內(nèi)容的空間,現(xiàn)在就只用把剛剛得到得zoomControls加到webview的內(nèi)容空間中就OK了。還有1個問題就是當(dāng)webview上方出現(xiàn)edittext空間時如果webview中也同時出現(xiàn)(比如:百度,google中的輸入框)時就會出現(xiàn)焦點沖突問題,解決方法就是實現(xiàn)webview的setOnTouchListener事件,在事件中設(shè)置webview.requestFocus()就行了.
還是貼上源碼吧:
public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); init(); } private void init() { web_content = (WebView) findViewById(R.id.web_content); WebSettings set = web_content.getSettings(); set.setSupportZoom(true); set.setJavaScriptEnabled(true); set.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); View control = web_content.getZoomControls(); FrameLayout layout = (FrameLayout) getWindow().getDecorView() .findViewById(android.R.id.content); FrameLayout.LayoutParams params = new FrameLayout.LayoutParams( FrameLayout.LayoutParams.WRAP_CONTENT, FrameLayout.LayoutParams.WRAP_CONTENT, Gravity.BOTTOM | Gravity.RIGHT); params.bottomMargin = 10; params.rightMargin = 10; layout.addView(control, params); web_content.setOnTouchListener(new View.OnTouchListener() { @Override public boolean onTouch(View v, MotionEvent event) { web_content.requestFocus(); return false; } }); web_content.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); tx_address.setText(url); return true; } }); web_content.loadUrl(parseUrl(defaultPage)); } 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。
新聞熱點
疑難解答