zoukankan      html  css  js  c++  java
  • android之WebView 细节

    package com.example.huadong;

    import android.app.Activity;
    import android.app.AlertDialog;
    import android.app.ProgressDialog;
    import android.content.DialogInterface;
    import android.os.Bundle;
    import android.view.GestureDetector;
    import android.view.GestureDetector.OnGestureListener;
    import android.view.KeyEvent;
    import android.view.MotionEvent;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.view.View.OnTouchListener;
    import android.view.animation.AnimationUtils;
    import android.webkit.WebView;
    import android.webkit.WebViewClient;
    import android.widget.ImageButton;
    import android.widget.Toast;
    import android.widget.ViewFlipper;

    /**
     * ViewFlipperTest.java
     * @author Cloay
     * 2011-6-24
     */
    public class MainActivity extends Activity  {
     
    private WebView webView=null;
    private AlertDialog alertDialog;//添加进度条
    private ProgressDialog progressBar;

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

      
      initWebView();
     

     
        
      
     }
     
     
      class MyWebViewClient extends WebViewClient{

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

             @Override
             public void onPageFinished(WebView view, String url) {
                 if(progressBar.isShowing()){
                     progressBar.dismiss();
                 }
             }

             @Override
             public void onReceivedError(WebView view, int errorCode,
                     String description, String failingUrl) {
                 Toast.makeText(MainActivity.this, "网页加载出错!", Toast.LENGTH_LONG);
                
                 alertDialog.setTitle("ERROR");
                 alertDialog.setMessage(description);
                 alertDialog.setButton("OK", new DialogInterface.OnClickListener(){
                     public void onClick(DialogInterface dialog, int which) {
                         // TODO Auto-generated method stub
                     }
                 });
                 alertDialog.show();
             }
            
            
            
         }
        
         protected void initWebView(){
             //设计进度条
             progressBar = ProgressDialog.show(MainActivity.this, null, "正在进入网页,请稍后…");
             //获得WebView组件
             webView = (WebView) this.findViewById(R.id.webText);
            
             webView.getSettings().setJavaScriptEnabled(true);
            
          webView.getSettings().setDefaultTextEncodingName("gbk");
             webView.getSettings().setUseWideViewPort(true);
            
             webView.getSettings().setLoadWithOverviewMode(true);

       //webView.loadUrl("file:///android_asset/demo1.html");
             webView.loadUrl("http://wap.people.com.cn/");
       
             alertDialog = new AlertDialog.Builder(this).create();
            
             //设置视图客户端
             webView.setWebViewClient(new MyWebViewClient());
         }

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

      
    }

  • 相关阅读:
    ModuleNotFoundError: No module named 'rest_framework_swagger'
    ModuleNotFoundError: No module named 'suit'
    HTTPS连接的前几毫秒发生了什么
    网络通信之 字节序转换原理与网络字节序、大端和小端模式
    聊聊HTTPS和SSL/TLS协议
    ECShop 调用自定义广告
    ECSHOP商城网站建设之自定义调用广告方法(二)
    https原理:证书传递、验证和数据加密、解密过程解析
    图解openssl实现私有CA
    SSL/TLS协议运行机制的概述
  • 原文地址:https://www.cnblogs.com/wangheblog/p/3038726.html
Copyright © 2011-2022 走看看