android实现自己的浏览器

最近没事写了一个简易浏览器,在刚开始写的时候遇到一些问题,主要的问题就是如何在自己的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()就行了.

还是贴上源码吧:

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)); }

你可能感兴趣的:(android实现自己的浏览器)