zoukankan      html  css  js  c++  java
  • 有关WebView开发问题(转)

    http://blog.sina.com.cn/s/blog_8241e8510101btvk.html

    如何创建WebView:

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

        2、在要Activity中生成一个WebView组件:WebView webView = new WebView(this);

        3、设置WebView基本信息:

              如果访问的页面中有Javascript,则webview必须设置支持Javascript。

              webview.getSettings().setJavaScriptEnabled(true); 

              触摸焦点起作用

              webview.requestFocus();//如果不设置,则在点击网页文本输入框时,不能弹出软键盘及不响应其他的一些事件。

              取消滚动条

              this.setScrollBarStyle(SCROLLBARS_OUTSIDE_OVERLAY);

        4、设置WevView要显示的网页:

              互联网用:webView.loadUrl("http://www.google.com");

              本地文件用:webView.loadUrl("file:///android_asset/XX.html");  本地文件存放在:assets文件中

        5、如果希望点击链接由自己处理,而不是新开Android的系统browser中响应该链接。

              给WebView添加一个事件监听对象(WebViewClient)     

           

              并重写其中的一些方法

                    shouldOverrideUrlLoading:对网页中超链接按钮的响应。

                                              当按下某个连接时WebViewClient会调用这个方法,并传递参数:按下的url

                    onLoadResource  

                    onPageStart 

                    onPageFinish 

                    onReceiveError

                    onReceivedHttpAuthRequest

         6.listview,webview中滚动拖动到顶部或者底部时的阴影(滑动到项部或底部不固定)
               WebView.setOverScrollMode(View.OVER_SCROLL_NEVER);

        7.//android 中 webview 使用 localStorage
      WebSettings settings = mWebView.getSettings();
        // 设置可以使用localStorage
            settings.setDomStorageEnabled(true);
            // 应用可以有数据库
            settings.setDatabaseEnabled(true);  
            String dbPath = this.getApplicationContext().getDir("database", Context.MODE_PRIVATE).getPath();
            settings.setDatabasePath(dbPath);
            // 应用可以有缓存
            settings.setAppCacheEnabled(true);            
            String appCaceDir = this.getApplicationContext().getDir("cache", Context.MODE_PRIVATE).getPath();
            settings.setAppCachePath(appCaceDir);

        8、如果用webview点链接看了很多页以后,如果不做任何处理,点击系统“Back”键,整个浏览器会调用finish()而结束自身,如果希望浏览的网页回退而不是退出浏览器,需要在当前Activity中处理并消费掉该Back事件。

           覆盖Activity类的onKeyDown(int keyCoder,KeyEvent event)方法。

        public boolean onKeyDown(int keyCoder,KeyEvent event){

                            if(webView.canGoBack() && keyCoder == KeyEvent.KEYCODE_BACK){

                                  webview.goBack();   //goBack()表示返回webView的上一页面

                                     return true;

                               }

                            return false;

                       }

      WebView相关问题注意:

    Android的webView很强大,其实就是一个浏览器,你可以把它嵌入到你想要的位置,我这里遇到两个问题,就是怎么知道网页的加载进度和加载网页时,

    点击网页里面的链接还是在当前的webview里跳转,不想跳到浏览器那边,解决办法如下:

    //此方法可以处理webview 在加载时和加载完成时一些操作

    webView.setWebChromeClient(new WebChromeClient(){

      @Override

      public void onProgressChanged(WebView view, int newProgress) {

        if(newProgress==100){                        // 这里是设置activity的标题, 也可以根据自己的需求做一些其他的操作

              title.setText("加载完成");

         }else{

         title.setText("加载中.......");

          }

        }

    });

    webView.setWebViewClient(new WebViewClient(){

      @Override

        public boolean shouldOverrideUrlLoading(WebView view, String url) {  //重写此方法表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边

           view.loadUrl(url);

           return true;

      }

            @Override

    public void onReceivedSslError(WebView view, SslErrorHandler handler, android.net.http.SslError error) { // 重写此方法可以让webview处理https请求

    handler.proceed();

    }

    });

    其他学习:http://liangruijun.blog.51cto.com/3061169/647456/

        http://www.myexception.cn/h/573394.html

  • 相关阅读:
    [WP]XCTF-Reversing-Newbie_calculations
    [WP]BUUCTF-Reverse-基础题(1-12)
    [WP]XCTF-notsequence
    [WP]XCTF-easyre-153
    [WP]XCTF- 攻防世界-crypto-新手练习区
    [WP]XCTF-simple-check-100
    [WP]XCTF-SignIn
    [WP]XCTF-666
    [WP]XCTF-Reversing-x64Elf-100
    [WP]XCTF-流浪者
  • 原文地址:https://www.cnblogs.com/manmanlu/p/3805586.html
Copyright © 2011-2022 走看看