简单范例:

public class MainActivity extends Activity
{
                                           
    private WebView wv;
    private Button btn;
    private EditText et;
                                           
    String url = "http://www.baidu.com";
                                           
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
                                               
                                               
        wv = (WebView) findViewById(R.id.webView1);
        btn = (Button) findViewById(R.id.button1);
        et = (EditText) findViewById(R.id.editText1);
                                               
        wv.loadUrl(url);
        wv.setWebViewClient(new WebViewClient());//必须设置
        wv.setInitialScale(39);//缩放比例
                                               
        btn.setOnClickListener(new OnClickListener()
        {
            @Override
            public void onClick(View v)
            {
                String str = et.getText().toString();
                if(str == null || str.trim().length() == 0)
                {
                    str = url;
                }
                                                       
                wv.loadUrl(str);
                                                       
            }
        });
    }
}


注:

1.设置权限

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


2.常见功能;

mWebView.goBack();   //后退  
mWebView.goForward();//前进

mWebView.reload();  //刷新



详细范例:

wKiom1P-1s7Rl0NoAAB-m7szQU8571.jpg


WebViewActivity类代码:

import android.os.Bundle;
import android.app.Activity;
import android.view.KeyEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.ProgressBar;

public class WebViewActivity extends Activity implements OnClickListener
{
    private WebView mWebView;
    private ProgressBar mProgressBar;
    
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.webview_main);
        
        String url = getIntent().getStringExtra(LoadWebView.KEY_INTENT_URL);
        
        mWebView = (WebView) findViewById(R.id.webView);
        Button mBtn_back = (Button) findViewById(R.id.webView_bt_back);
        Button mBtn_forward = (Button) findViewById(R.id.webView_bt_forward);
        Button mBtn_refresh = (Button) findViewById(R.id.webView_bt_refresh);
        Button mBtn_close = (Button) findViewById(R.id.webView_bt_close);
        
        mProgressBar = (ProgressBar) findViewById(R.id.webView_progressBar);
        mProgressBar.setMax(100);
        
        mBtn_back.setOnClickListener(this);
        mBtn_forward.setOnClickListener(this);
        mBtn_refresh.setOnClickListener(this);
        mBtn_close.setOnClickListener(this);
        
        // 加载网页
        loadWebView(url);
    }
    
    /**
     * 加载网页 setWebViewClient,功能比setWebChromeClient少,如果你只需要一个html加载,那直接用这个就可以了;
     * 如果你需要一个js,以及favicons, titles, and the progress那你就需要setWebChromeClient.
     * 
     * @param url
     */
    private void loadWebView(String url)
    {
        // 必须设置,在原有的webview上加载网页
        mWebView.setWebViewClient(new WebViewClient()
        {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url)
            {
                view.loadUrl(url);
                return true;
            }
        });
        mWebView.setInitialScale(39);// 缩放比例
        
        // 加载进度条
        mWebView.setWebChromeClient(new WebProgressClient());
        
        // 支持JavaScript
        WebSettings webSetting = mWebView.getSettings();
        webSetting.setJavaScriptEnabled(true);
        
        webSetting.setSupportZoom(true);
        webSetting.setBuiltInZoomControls(true);
        
        // 支持输入框聚焦
        mWebView.requestFocusFromTouch();
        
        mWebView.loadUrl(url);
    }
    
    // 控制加载进度
    class WebProgressClient extends WebChromeClient
    {
        @Override
        public void onProgressChanged(WebView view, int newProgress)
        {
            mProgressBar.setProgress(newProgress);
            if (newProgress == 100)
            {
                mProgressBar.setVisibility(View.GONE);
            }
            else
            {
                if (mProgressBar.getVisibility() == View.GONE)
                {
                    mProgressBar.setVisibility(View.VISIBLE);
                }
            }
        }
    }
    
    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event)
    {
        if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack())
        {
            mWebView.goBack();
            return true;
        }
        return super.onKeyDown(keyCode, event);
    }
    
    @Override
    public void onClick(View v)
    {
        switch (v.getId())
        {
            case R.id.webView_bt_back:
                
                if (mWebView.canGoBack())
                {
                    mWebView.goBack();
                }
                else
                {
                    finish();
                }
                break;
            
            case R.id.webView_bt_forward:
                mWebView.goForward();
                break;
            
            case R.id.webView_bt_refresh:
                mWebView.reload();
                break;
            
            case R.id.webView_bt_close:
                finish();
                break;
            
            default:
                break;
        }
    }
}


webview_main.xml布局文件代码:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

        <Button
            android:id="@+id/webView_bt_back"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="返回" />

        <Button
            android:id="@+id/webView_bt_forward"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="前进"
            android:visibility="visible" />

        <Button
            android:id="@+id/webView_bt_close"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="关闭" />

        <View
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="2dp"
            android:text="" />

        <Button
            android:id="@+id/webView_bt_refresh"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="刷新" />
    </LinearLayout>

    <ProgressBar
        android:id="@+id/webView_progressBar"
        style="?android:attr/progressBarStyleHorizontal"
        android:layout_width="fill_parent"
        android:layout_height="5dp"
        android:max="100"
        android:progressDrawable="@drawable/webview_progressbar_bg" />

    <WebView
        android:id="@+id/webView"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>



进度条背景webview_progressbar_bg.xml代码:

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >

    <item android:id="@android:id/background">
        <shape>
            <gradient
                android:centerColor="#ffa600"
                android:endColor="#ff5500"
                android:startColor="#ff0000" />
        </shape>
    </item>
    <item android:id="@android:id/secondaryProgress">
        <clip>
            <shape>
                <gradient
                    android:centerColor="#234"
                    android:endColor="#a24"
                    android:startColor="#234" />
            </shape>
        </clip>
    </item>
    <item android:id="@android:id/progress">
        <clip>
            <shape>
                <gradient
                    android:centerColor="#40000000"
                    android:endColor="#44000000"
                    android:startColor="#33000001" />
            </shape>
        </clip>
    </item>

</layer-list>








[转]其他总结:

1.AndroidManifest.xml中必须使用许可"android.permission.INTERNET",否则会出 Web page not available 错误。

2.如果访问的页面中有JavaSrcipt,则webview必须设置支持JavaScript

WebSettings webSetting = webview.getSettings() ;
webSetting.setJavaScriptEnabled(true) ;


3.如果页面中连接,如果希望点击连接继续在当前browser中相应,而不是新开Android的系统browser中应该连接,必须覆盖webview的WebViewClient对象。


mWebView.setWebViewClient(new WebViewClient(){

 public boolean shouldOverrideUrlLoading(WebView view,String url){
   view.loadUrl(url) ;
   return true ;
 }
})

4.如果不做任何处理,浏览网页,点击系统"Back"键,整个Browser会调用finish()而结束自身,如果希望浏览的网页回退而不是推出浏览器,需要在当前Activity中处理并消费掉该Back事件。


public boolean onKeyDown(int keyCode, KeyEvent event){
 if((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()){
   mWebView.goBack() ;
   return true ;
 }

 return super.onKeyDown(keyCode, event) ;
}

5.如果webView中需要用户手动输入用户名,密码或其他,则webview必须设置支持获取手势焦点。

 webview.requestFocusFromTouch() ;

6.WebView加载界面主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL
1.LoadUrl 直接加载网页,图片并显示

2.LoadData 显示文字与图片内容

3.LoadDataWithBase 显示文字与图片内容


webSettings的常用方法

setJavaScriptEnabled(true) ;
//支持js脚本
setPluginsEnabled(true) ;
//支持插件
setUserWideViewPort(false) ;
//将图片调整到适合webview的大小
setSupportZoom(true) ;
//支持缩放
setLayoutAlgorithm(LayoutAlgrithm.SINGLE_COLUMN) ;
//支持内容从新布局
supportMultipleWindows() ;
//多窗口
setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK) ;
//关闭webview中缓存
setAllowFileAccess(true) ;
//设置可以访问文件
setNeedInitialFocus(true) ;
//当webview调用requestFocus时为webview设置节点
setjavaScriptCanOpenWindowsAutomatically(true) ;
//支持通过JS打开新窗口
setLoadsImagesAutomatically(true) ;
//支持自动加载图片

setBuiltInZoomControls(true);

//支持缩放

webView.setInitialScale(35);

//设置缩放比例

webView.setScrollBarStyle(View.SCROLLBARS_OUTSIDE_OVERLAY);

//设置滚动条隐藏

webView.getSettings().setGeolocationEnabled(true);

//启用地理定位

webView.getSettings().setRenderPriority(RenderPriority.HIGH);

//设置渲染优先级

String dir = "/sdcard/temp";
//设置定位的数据库路径
webView.getSettings().setGeolocationDatabasePath(dir);

这里是使用webview以及webview的相关设置,课根据实际情况进行设置.


WebViewClient的方法全解

doUpdateVisitedHistory(WebView view, String url ,boolean isReload)
更新历史记录
onFormResubmission(WebView view, Message dontResend, Message resend)
应用程序重新请求页面数据
onLoadResource(WebView view, String url)
在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次
onPageStarted(WebView view, String url, Bitmap favicon)
这个事件就是开始载入页面调用的,通常我们可以在这个设定一个loading的页面,告诉用户程序在等待网络相应。
onPageFinished(WebView view, String url)
在页面加载结束时调用,同样道理,我们知道一个页面载入完成,于是我们可以关闭loading条,切换程序动作。
onReceivedError(WebView view, int errorCode, String description, String failingUrl)
报告错误信息
onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,Stirng realm)
获取返回信息授权请求
onScaleChanged(WebView view, float oldScale, float newScale)
WebView 发生改变时调用

onUnhandledKeyEvent(WebView view, KeyEvent event)
key事件未被加载时调用

shouldOverrideUrlLoading并不是每次都在onPageStarted之前开始调用的,就是说一个新的URL不是每次都经过shouldOverrideUrlLoading的,只有在调用webview.loadURL的时候才会调用。


//设置在同一个webview中打开新的网页
webView.setWebViewClient(new WebViewClient(){
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
});

//设置WebChromeClient
webView.setWebChromeClient(new WebChromeClient(){
//配置权限
public void onGeolocationPermissionsShowPrompt(String origin,GeolocationPermissions.Callback callback){
callback.invoke(origin, true, false);
super.onGeolocationPermissionsShowPrompt(origin, callback);
}

//处理javascript中的alert
public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
//构建一个Builder来显示网页中的对话框
Builder builder = new Builder(MainAcitivity.this);
builder.setTitle("提示");
builder.setMessage(message);
builder.setPositiveButton(android.R.string.ok,
new AlertDialog.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
result.confirm();
}
});

builder.setCancelable(false);
builder.create();
builder.show();
return true;


@Override
//设置网页加载的进度条
public void onProgressChanged(WebView view, int newProgress) {
MainAcitivity.this.getWindow().setFeatureInt(Window.FEATURE_PROGRESS, newProgress * 100);
super.onProgressChanged(view, newProgress);
}

//设置应用程序的标题title
public void onReceivedTitle(WebView view, String title) {
MainAcitivity.this.setTitle(title);
super.onReceivedTitle(view, title);
}
});

//判断是否联网
ConnectivityManager cm;
cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
boolean isWifiConnected=cm.getNetworkInfo(ConnectivityManager.TYPE_WIFI).getState() == NetworkInfo.State.CONNECTED;
if(!isWifiConnected){
boolean isGprsConnected=cm.getNetworkInfo(ConnectivityManager.TYPE_MOBILE).getState() == NetworkInfo.State.CONNECTED;
if(!isGprsConnected){
new AlertDialog.Builder(this)
.setTitle("提示" )
.setMessage("离线状态,启用离线模式" )
.setPositiveButton("确定" , null )
.show();
}
else{
result = CallWCF();
}
}




参考资料:

1.http://hi.baidu.com/mowangsheng/item/3a0921295ffbee0276272c5e


2.Android WebView相关属性

http://www.2cto.com/kf/201206/137219.html