`

android开发中WebView控件的实例与注意要点——个人主页浏览器简易实现

阅读更多

 

    在Android开发中往往需要实现网页的浏览,webview就是android开发控件中功能极其强大的一员,它完全可以充当一个简易的浏览器,能够自己设置主页。试想,用自己开发的app把主页设成自己技术博客地址,一打开便进入了自己的空间,何其的方便。

    在webview使用中有以下几点需要注意:

  1、关于访问网络的问题

 

       由于webview需要通过数据通信来访问网络,所以在manifest.xml配置文件中需要进行权限的设置(声明)

       代码如下

  

<uses-permission android:name="android.permission.INTERNET"/>

   2、如何实现不调用第三方浏览器即可进行页面反应

 

   

/*在webview加载网页时,不调用第三方浏览器打开的办法:
 * 设置WebViewClient,并重写WebViewClient的shouldOverrideUrlLoading方法
 * 返回true为不调用,反之 false为调用第三方浏览器
 */
 	webView.setWebViewClient(new WebViewClient(){
	   @Override
	    public boolean shouldOverrideUrlLoading(WebView view, String url) {
			 // TODO Auto-generated method stub
		        view.loadUrl(url);
		        return true;
		      }
		    });

 

 

   3、网页中包含JavaScript内容时如何设置

     android webview之所以功能强大就是能够和js进行交互 把js写成的网页嵌套到app中。

   

//网页中包含JavaScript内容需调用以下方法,参数为true
		webView.getSettings().setJavaScriptEnabled(true);

 

 

   4、如何使得物理返回键实现页面上翻而不是退出程序

     用过浏览器的同学应该都知道,浏览网页时点按手机上的返回键并不会导致程序的退出,而是回到之前打开的网页,这时候就需要重写onKeyDown(keyCode, event)方法 改写物理按键返回的逻辑。以下是设置方法:

 

//重写onKeyDown(keyCode, event)方法 改写物理按键 返回的逻辑
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        // TODO Auto-generated method stub
        if(keyCode==KeyEvent.KEYCODE_BACK)
        {
            if(webView.canGoBack())
            {
                webView.goBack();//返回上一页面
                return true;
            }
            else
            {
                System.exit(0);//退出程序
            }
        }
        return super.onKeyDown(keyCode, event);
    }

  

 

   5 、出现net::ERR_CACHE_MISS错误提示

      使用缓存的方式是基于导航类型。正常页面加载的情况下将缓存内容。当导航返回,内容不会恢复(重新加载生成),而只是从缓存中取回内容。可以进行一下代码设置:

//出现net::ERR_CACHE_MISS错误提示
		//使用缓存的方式是基于导航类型。正常页面加载的情况下将缓存内容。当导航返回,
		//内容不会恢复(重新加载生成),而只是从缓存中取回内容
		if (Build.VERSION.SDK_INT >= 19) {
			Toast.makeText(this, "hhahhhhaha", Toast.LENGTH_LONG).show();
	        webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);

	    }

   6 、出现net::ERR_NAME_NOT_RESOLVED错误

 

    导致这个错误的因素有很多,我遇到的就比较特殊和纠结。因为用手机调试时需要用流量,鄙人比较穷,就用来电脑开的WiFi,可是出现了这个net::ERR_NAME_NOT_RESOLVED错误,只有用手机数据流量才得以解决。这是我找到的一些解决方法:

DNS 是将网站名称解析为互联网地址的网络服务。

a、把能上网的电脑连上,看一网络连接中的IP、DNS是自动还是指定,如果是指定记下来。
b、再把自己的电脑连上,检查一下自己的电脑的网络连接中的IP、DNS,与能上网的电脑设置成一样再试一下。
c.浏览器设置代理,请检测自己的浏览器是否设置代理或者正在开启代理软件,导致出现打不开网页情况。
d.电脑病毒破坏浏览器组件和系统文件,部分杀毒软件对被木马病毒感染程序进行查杀,但并未进行修复。
e.DNS设置问题,DNS服务器解释出错,需要手动在本地连接进行设置。

 

   7 、若要显示本地文件和本地html文件应该放在哪

   android工程目录下单assets文件

 webView.loadUrl("file:///android_asset/icon.jpg");

 

   8、添加置顶进度条

    在网页访问网络时,如果没有进度条将很难分辨是否正在访问或是否加载完成,所以需要添加置顶的进度条,布局文件中:

 <ProgressBar
        android:id="@+id/progressBar1"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true" />

 

 

    基本上的要点就是和这些了,接下来是具体实现:

   这是布局文件   其实就是一个大大的webview组件加一个ProgressBar:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    tools:context=".MainActivity" >

    <WebView
        android:id="@+id/webView"
        android:layout_width="fill_parent"
        android:layout_height="455sp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentBottom="true" />

    <ProgressBar
        android:id="@+id/progressBar1"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true" />

</RelativeLayout>

 

 

  

 

    这是主文件:

 

package com.example.webviewtest;

import java.net.URLEncoder;

import android.app.Activity;

import android.os.Build;
import android.os.Bundle;

import android.view.KeyEvent;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Toast;

public class MainActivity extends Activity {

	WebView webView;

	final String mimeType = "text/html";

	final String encoding = "utf-8";

	public void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		//添加进度条
 		 final ProgressBar bar = (ProgressBar)findViewById(R.id.progressBar1);
		webView = (WebView) findViewById(R.id.webView);
		/*在webview加载网页时,不调用第三方浏览器打开的办法:
		 * 设置WebViewClient,并重写WebViewClient的shouldOverrideUrlLoading方法
		 * 返回true为不调用,反之 false为调用第三方浏览器
		 */
		webView.setWebViewClient(new WebViewClient(){
			@Override
		    public boolean shouldOverrideUrlLoading(WebView view, String url) {
				 // TODO Auto-generated method stub
		        view.loadUrl(url);
		        return true;
		      }
		    });

	//添加进度条
	  webView.setWebChromeClient(new WebChromeClient() {
           @Override
           public void onProgressChanged(WebView view, int newProgress) {
               if (newProgress == 100) {
                   bar.setVisibility(View.INVISIBLE);
               } else {
                   if (View.INVISIBLE == bar.getVisibility()) {
                       bar.setVisibility(View.VISIBLE);
                   }
                   bar.setProgress(newProgress);
               }
               super.onProgressChanged(view, newProgress);
           }
           
       });
		//网页中包含JavaScript内容需调用以下方法,参数为true
		webView.getSettings().setJavaScriptEnabled(true);
		//出现net::ERR_CACHE_MISS错误提示
		//使用缓存的方式是基于导航类型。正常页面加载的情况下将缓存内容。当导航返回,
		//内容不会恢复(重新加载生成),而只是从缓存中取回内容
		if (Build.VERSION.SDK_INT >= 19) {
	        webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);

	    }
		  webHtml();
		  
//		  webImage();
		  
//		  localHtml();
		  
//		  localImage ();
		  
//		  localHtmlImage();

	}

	//重写onKeyDown(keyCode, event)方法 改写物理按键 返回的逻辑
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        // TODO Auto-generated method stub
        if(keyCode==KeyEvent.KEYCODE_BACK)
        {
            if(webView.canGoBack())
            {
                webView.goBack();//返回上一页面
                return true;
            }
            else
            {
                System.exit(0);//退出程序
            }
        }
        return super.onKeyDown(keyCode, event);
    }
	/**
	 * 显示网页
	 */
	private void webHtml() {
		try {
			webView.loadUrl("http://815222418.iteye.com");

		} catch (Exception ex) {

			ex.printStackTrace();
		}
	}

	/**
	 *  显示网络图片
	 */

	private void webImage() {
		try {

			webView.loadUrl("http://815222418.iteye.com/images/haha.jpg");
			
		} catch (Exception ex) {

			ex.printStackTrace();
		}
	}

	
	
	/**
	 * 显示本地图片文件
	 */

	private void localImage() {

		try {

			// 本地文件处理(文件名中有空格时用+来替代)

			webView.loadUrl("file:///android_asset/icon.jpg");

		} catch (Exception ex) {

			ex.printStackTrace();

		}

	}

	/**
	 * 显示本地网页文件
	 */

	private void localHtml() {

		try {

			// 本地文件处理( 文件名中有空格用+来替代)

			webView.loadUrl("file:///android_asset/find.html");
		} catch (Exception ex) {

			ex.printStackTrace();
		}
	}

	/**
	 * 显示本地图片和文字混合的Html内容
	 */

	private void localHtmlImage() {
		try {

			String data = "测试本地图片和文字混合显示,这是APK里的图片";

			// SDK1.5本地文件处理(不能显示图片)
			// SDK1.6及以后版本
			// webView.loadData(data, mimeType, encoding);
			// 本地文件处理(能显示图片)

			webView.loadDataWithBaseURL("about:blank", data, mimeType,

			encoding, "");

		} catch (Exception ex) {

			ex.printStackTrace();

		}
	}
}

 

 

 这样,一个简易的个人主页浏览器就完成了。

 

 

                                                                                                                                  梣梓cenzi

                                                                                                                           2015      4      8

分享到:
评论

相关推荐

    android开发实现的webview实例

    这个实例主要讲解如何在Android应用中使用WebView来实现远程调用HTML或JSP页面,并且探讨如何通过WebView与远程数据库进行通信。 首先,我们来了解WebView的基本使用。在Android布局XML文件中,你需要添加一个...

    Android WebView控件的用法

    在Android开发中,WebView控件是一个非常重要的组件,它允许我们在应用程序内部嵌入一个浏览器引擎,展示网页内容。这使得开发者能够实现与网页交互的功能,而无需离开应用本身,极大地提升了用户体验。下面我们将...

    android webview控件案例

    在Android开发中,WebView是一个非常重要的组件,它允许我们在应用程序中内嵌网页浏览功能。WebView控件能够加载HTML、CSS和JavaScript代码,使得Android应用能够与网页内容进行交互。本案例"android webview控件...

    Android Studio平台下使用webview开发的android浏览器

    本资源配套本人的博客文章《Android开发】Android Studio中进行简单的WebView构建浏览器开发1》和《Android开发】Android Studio中进行简单的WebView构建浏览器开发2》进行使用,实现了基本的浏览器功能:包括:输入...

    android 使用webview控件,注意在android9.0以后必须使用https才能访问网页

    在Android应用开发中,WebView控件是一个非常重要的组件,它允许开发者在应用程序内嵌入一个浏览器,以便用户能够浏览网页内容。然而,随着网络安全性的不断提升,Android系统对WebView的使用也有了更严格的要求。在...

    WebView控件基本使用 Android

    WebView 控件基本使用 Android WebView 控件是 Android 中的一个浏览器控件,通过这个控件可以直接访问网页,或者把输入的 HTML 字符串...WebView 控件是一个非常强大和灵活的控件,在 Android 开发中发挥着重要作用。

    android WebView控件的使用

    WebView控件的使用是Android开发者必须掌握的一项技能,尤其对于那些希望在应用中嵌入网页功能或者实现轻量级浏览器应用的开发者来说。下面将详细介绍WebView的使用方法以及一些关键知识点。 1. **WebView的基本...

    Android应用开发-WebView控件.pptx

    **Android应用开发中的WebView控件详解** 在Android应用开发中,WebView控件是一个至关重要的组件,它允许开发者在应用程序内部嵌入网页内容,为用户提供无需离开应用就能浏览网页的体验。WebView可以看作是一个轻...

    Android通过webview控件实现webapp的demo androidstudio

    在Android开发中,Webview控件是一个非常重要的组件,它允许开发者在应用程序中嵌入网页内容,从而实现Web与原生应用的结合,这就是我们常说的WebAPP。本项目是基于Android Studio的一个示例,展示了如何利用Webview...

    Android中的webview监听每次URL变化实例

    在Android开发中,WebView组件是一个允许应用显示网页的控件,它使用了WebKit渲染引擎来显示网页内容。随着移动应用越来越依赖于互联网功能,开发者需要能够处理Web内容,同时也要能够监控Web内容的变化,例如URL的...

    Android应用源码之38.WebView控件学习.zip

    在Android应用开发中,WebView控件是一个至关重要的组件,它允许开发者在应用程序内嵌入网页内容,实现浏览器的功能。这份源码提供了关于WebView的详细学习资料,非常适合Android开发者进行参考和学习。 首先,...

    博客《 WebView使用详解(三)——WebChromeClient与LoadData补充》对应源码

    博客《 WebView使用详解(三)——WebChromeClient与LoadData补充》对应源码,博客地址:http://blog.csdn.net/harvic880925/article/details/51583253

    android的webView的登录实例

    在Android开发中,WebView是一个非常重要的组件,它允许我们在应用程序中加载和显示网页内容。本实例将详述如何使用Android Studio 3.1.2版本,通过WebView来创建一个简单的登录界面,该界面使用本地HTML页面进行...

    android开发中WebView的使用

    在Android开发中,WebView是一个非常重要的组件,它允许开发者在应用程序内部嵌入一个浏览器控件,使得用户可以在应用中直接浏览网页内容。WebView基于WebKit渲染引擎,因此它能很好地支持HTML、JavaScript和CSS等...

    android_中webView控件详解

    ### Android中的WebView控件详解 #### 一、概述 WebView是Android系统提供的一个重要的控件,主要用于在应用程序中展示Web内容。它不仅能够加载并显示HTML文档,还支持JavaScript脚本执行,允许开发者通过Java与...

    用webview实现的android简单浏览器

    在Android平台上,WebView是一个强大的组件,它允许开发者在应用程序中嵌入网页内容,甚至实现一个简单的浏览器应用。本文将深入探讨如何使用WebView实现一个具备基本功能的Android浏览器,包括加载网页、添加书签等...

    Android应用源码-浏览器&WebView&JS&HTML5类源代码(8例).zip

    这份名为"Android应用源码-浏览器&WebView&JS&HTML5类源代码(8例).zip"的压缩包文件,包含了一系列与Android应用程序开发相关的源代码示例,特别是聚焦于浏览器功能、WebView组件、JavaScript交互以及HTML5技术的...

    在android的webview中实现websocket通信

    在 Android 的 WebView 中实现 WebSocket 通信是当前移动端应用开发中的一个热门话题。WebSocket 是 HTML5 规范中的一项技术,可以实现客户端与服务器之间的实时双向通信。在桌面浏览器中,WebSocket 技术已经得到了...

    Android Studio 开发的WebView 框架源码

    在Android开发中,WebView是一个非常重要的组件,它允许我们在应用程序中内嵌网页浏览功能,而无需离开应用。本文将深入探讨使用Android Studio开发WebView框架的源码,旨在帮助开发者理解和运用这一关键工具。 ...

    android开发中WebView的使用.pdf

    在Android开发中,WebView是一个非常重要的组件,它允许开发者在应用程序内部嵌入网页内容,从而实现类似浏览器的功能。WebView基于WebKit渲染引擎,因此它可以很好地支持HTML、JavaScript和CSS等网络技术,极大地...

Global site tag (gtag.js) - Google Analytics