zoukankan      html  css  js  c++  java
  • Android Internet

    WebView是Android 提供的操作网页的一个组件。

    用于浏览网页及其它Internet资源。

    这里总结了一些WebView 的经常使用接口。和2个小演示样例程序用于自己开发时直接使用。就不用再去Baidu了。节省点时间。


    使用loadUrl和loadData

    WebView.loadUrl:打开URL页面(本地或远端)。
    WebView.goForward:实现浏览器的前进功能。
    WebView.goBack:实现浏览器的回退功能。
    WebView.loadData:载入HTML数据。

    演示样例程序 1:使用WebView.loadUrl 浏览网页
    这里写图片描写叙述

    Layout file:

    <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">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >
    
            <EditText
                android:id="@+id/etUrl"
                android:layout_width="240dip"
                android:layout_height="wrap_content"
                android:text="www.sina.com.cn" >
            </EditText>
    
            <Button
                android:id="@+id/btnGo"
                android:layout_width="80dip"
                android:layout_height="wrap_content"
                android:text="Go" />  
        </LinearLayout>
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
    
                <Button
                    android:id="@+id/btnGoForward"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Forward" />
    
                <Button
                    android:id="@+id/btnGoBack"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="Back" />          
        </LinearLayout>
    
        <WebView
            android:id="@+id/webview"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    
    </LinearLayout>

    MainActivity.java

    package com.example.internet_webview;
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.webkit.WebView;
    import android.webkit.WebViewClient;
    import android.widget.Button;
    import android.widget.EditText;
    
    public class MainActivity extends Activity 
    {
        private WebView m_Webview;
        private Button  m_Go;
        private EditText m_Url;
    
        private Button  m_GoForward;
        private Button  m_GoBack;
    
    
        @Override
        protected void onCreate(Bundle savedInstanceState) 
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            m_Webview = (WebView) findViewById(R.id.webview);
            m_Url = (EditText) findViewById(R.id.etUrl);
            m_Go  = (Button) findViewById(R.id.btnGo);
    
            m_GoForward  = (Button) findViewById(R.id.btnGoForward);
            m_GoBack  = (Button) findViewById(R.id.btnGoBack);
    
            m_Webview.setWebViewClient(new WebViewClient(){});
    
            m_Go.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    m_Webview.loadUrl(m_Url.getText().toString());
                }
            });
    
            m_GoForward.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    if (m_Webview.canGoForward())
                        m_Webview.goForward();
                }
            });
    
            m_GoBack.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    if (m_Webview.canGoBack())
                        m_Webview.goBack();
                }
            });     
        }
    }
    

    演示样例程序 2:使用WebView.loadData解析HTML

    这里写图片描写叙述

    在输入栏中 网址变成了HTML代码,这时使用LoadData能够把HTML代码解析出来

    MainActivity.hava

    package com.example.internet_webview_loaddata;
    
    import android.os.Bundle;
    import android.app.Activity;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.webkit.WebView;
    import android.webkit.WebViewClient;
    import android.widget.Button;
    import android.widget.EditText;
    
    public class MainActivity extends Activity 
    {
        private WebView m_Webview;
        private Button  m_Go;
        private EditText m_Url;
    
        private Button  m_GoForward;
        private Button  m_GoBack;
    
    
        @Override
        protected void onCreate(Bundle savedInstanceState) 
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            m_Webview = (WebView) findViewById(R.id.webview);
            m_Url = (EditText) findViewById(R.id.etUrl);
            m_Go  = (Button) findViewById(R.id.btnGo);
    
            m_GoForward  = (Button) findViewById(R.id.btnGoForward);
            m_GoBack  = (Button) findViewById(R.id.btnGoBack);
    
            m_Webview.setWebViewClient(new WebViewClient(){});
    
            String customHtml = "<html><body><h1>Hello</h1></body></html>";
            m_Url.setText(customHtml);
    
            m_Go.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    m_Webview.loadData(m_Url.getText().toString(), "text/html", "UTF-8");  
                }
            });
    
            m_GoForward.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    if (m_Webview.canGoForward())
                        m_Webview.goForward();
                }
            });
    
            m_GoBack.setOnClickListener(new OnClickListener() 
            {
                @Override
                public void onClick(View v) 
                {
                    if (m_Webview.canGoBack())
                        m_Webview.goBack();
                }
            });     
        }
    }
    

    WebView.loadUrl 与 WebView.loadData 差别

    通过两个測试结果能够非常清楚的看到这两个接口使用时的差别,一个是输入的网址。还有一个输入的是网页的代码。

    WebView并非一个单纯的能载入URL显示网页的控件。它本身也是一个浏览器的引擎,基于这一点。或许能够加以利用。开发出更有趣的App。


    与JavaScript的交互

    WebView与JavaScript的交互事实上本质上是WebView中定义的WebClient的浏览器引擎与javascript的交互。浏览器引擎处理javascript的同一时候也提供给Andriod一些接口。使它能够接收到信息而且进行响应。

    处理方式:

    • Android代码中实现Javascript接口的处理
      javascript::alert() === WebChromeClient::onJsAlert()
      javascript::confirm() === WebChromeClient::onJsConfirm()
      javascript::prompt() === WebChromeClient::onJsPrompt()

    当javascript调用它的函数时,也会触发Android调用响应的接口。

    • Android提供自己定义接口供Javascript使用。
      这里用到的主要是WebChromeClient::addJavascriptInterface()接口。当中实现的一些接口函数能够供javascript程序来调用。

    • Android与Javascript通过消息交互。
      这里使用的是WebChromeClient::onConsoleMessage()接口。它为Android提供了处理javascript日志消息的一种能力。也能够作为消息传递的一种方式。

    layout 定义
    activity_main.xml,当中基本的就是WebView.

    <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">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal" >
    
            <EditText
                android:id="@+id/etUrl"
                android:layout_width="240dip"
                android:layout_height="wrap_content"
                android:text="www.sina.com.cn" >
            </EditText>
    
            <Button
                android:id="@+id/btnGo"
                android:layout_width="80dip"
                android:layout_height="wrap_content"
                android:text="Go" />  
        </LinearLayout>
    
        <WebView
            android:id="@+id/webview"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    
    </LinearLayout>

    js_prompt_layout.xml 弹出对话框时的 layout。

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >
    
        <TextView
            android:id="@+id/tvTitle"
            android:layout_marginTop="20dp"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:text="JS Called prompt Show Android Dialogue" />
    
        <EditText  
            android:id="@+id/etJSPrompt"  
            android:layout_width="fill_parent"  
            android:layout_height="wrap_content"/> 
    
    </LinearLayout>
    

    JS页面定义和预览

    这里写图片描写叙述

    <html>  
        <head>  
            <script type="text/javascript">  
                function doAlert() {  
                    alert("Alert I am from JS!");  
                }  
    
                function doConfirm() {
                    confirm("Confirm from JS");  
                }  
    
                function doPrompt() 
                {
                    var val = prompt("Prompt from JS, please input");
                    if (val) 
                    {
                        document.getElementById('id_name').value = val
                    }
                }  
    
                function CustimizeFunc() 
                {  
                    CustimizeAndroidFunc.popupDialogue();  
                }
    
                function ShowReturn() 
                {  
                    var retResult = CustimizeAndroidFunc.showResult();
                    var dspList = document.getElementById("DispList");
    
                    var div = document.createElement("div");
                    div.innerHTML = retResult;
                    dspList.appendChild(div);
                }            
            </script>  
        </head>  
        <body background="black">  
            <input type="button" value="Alert Test" onclick="doAlert()"/><br/><br/>
            <input type="button" value="Confirm Test" onclick="doConfirm()"/><br/><br/>
            <input type="button" value="Prompt Test" onclick="doPrompt()"/><br/>
            <input type="text" id="id_name" name="name_a" /><br/><br/>
            <input type="button" value="Custimize Function Popup" onclick="CustimizeFunc()"/><br/><br/>
            <input type="button" value="Custimize Function ShowList" onclick="ShowReturn()"/><br/><br/>
            <div id="DispList"></div>  
        </body>  
    </html>  

    程序执行结果

    MainActivity.java
    注意: @JavascriptInterface 在Android较新的版本号中为了防止JS能够通过反射取得Java类全部的接口。在定义接口时添加了一个@JavascriptInterface属性,仅仅有带有这个标志函数才干在JS中被訪问。

    package com.example.internet_webview_jswork;
    
    
    import android.os.Bundle;
    import android.annotation.SuppressLint;
    import android.app.Activity;
    import android.app.AlertDialog;
    import android.content.DialogInterface;
    import android.view.LayoutInflater;
    import android.view.Menu;
    import android.view.View;
    import android.webkit.JavascriptInterface;
    import android.webkit.JsPromptResult;
    import android.webkit.JsResult;
    import android.webkit.WebChromeClient;
    import android.webkit.WebView;
    import android.widget.EditText;
    
    @SuppressLint({ "JavascriptInterface", "SetJavaScriptEnabled" })
    public class MainActivity extends Activity 
    {
        private WebView m_Webview;
        private WebChromeClient m_Client;
    
    
        @Override
        protected void onCreate(Bundle savedInstanceState) 
        {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            m_Webview = (WebView) findViewById(R.id.webview);
    
    
            m_Webview.getSettings().setJavaScriptEnabled(true);
            m_Client = new WebChromeClient()
            {
                 public boolean onJsAlert(WebView view, String url, String message, final JsResult result) 
                 {  
                     new AlertDialog.Builder(MainActivity.this)  
                             .setTitle("JS Call alert and Android show Alert Dialogue")  
                             .setMessage(message)  
                             .setPositiveButton("YES", new DialogInterface.OnClickListener() 
                             {  
                                 @Override  
                                 public void onClick(DialogInterface dialog, int which) 
                                 {  
                                     result.confirm();  
                                 }  
                             }).create().show();  
                     return true;  
                 }  
    
                 public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) 
                 {  
                     new AlertDialog.Builder(MainActivity.this)  
                             .setTitle("JS Call confirm and Android show Confirm Dialogue")  
                             .setMessage(message)  
                             .setPositiveButton("YES", new DialogInterface.OnClickListener() {  
                                 @Override  
                                 public void onClick(DialogInterface dialog, int which) 
                                 {  
                                     result.confirm();  
                                 }  
                             })  
                             .setNegativeButton("NO", new DialogInterface.OnClickListener() {  
                                 @Override  
                                 public void onClick(DialogInterface dialog, int which) 
                                 {
                                     result.cancel();  
                                 }  
                             }).create().show();  
                     return true;  
                 }
    
    
                 public boolean onJsPrompt(WebView view, String url, String message, String defaultValue,  
                         final JsPromptResult result) 
                 {  
                     LayoutInflater inflater = getLayoutInflater();  
                     View prompt = inflater.inflate(R.layout.js_prompt_layout, null);  
                     final EditText etJSPromptValue = (EditText) prompt.findViewById(R.id.etJSPrompt);  
    
                     new AlertDialog.Builder(MainActivity.this)  
                             .setTitle("JS Call prompt and Android show Prompt Dialogue")  
                             .setView(prompt)  
                             .setPositiveButton("YES", new DialogInterface.OnClickListener() 
                             {  
                                 @Override  
                                 public void onClick(DialogInterface dialog, int which) 
                                 {
                                     // Here will confirm the Android text to JS
                                     result.confirm(etJSPromptValue.getText().toString());  
                                 }  
                             })  
                             .setNegativeButton("NO", new DialogInterface.OnClickListener() 
                             {  
                                 @Override  
                                 public void onClick(DialogInterface dialog, int which) 
                                 {
                                     result.cancel();  
                                 }  
                             }).create().show();  
                     return true;  
                }
            };
    
            m_Webview.setWebChromeClient(m_Client);
            m_Webview.addJavascriptInterface(new Object() 
            {
                @SuppressWarnings("unused")
                @JavascriptInterface 
                public void popupDialogue()
                {
                    new AlertDialog.Builder(MainActivity.this) 
                    .setTitle("JS Call Android popupDialogue")  
                    .setMessage("JS Call Android Custimized function::popupDialogue")
                    .setPositiveButton("YES", new DialogInterface.OnClickListener() {  
                        @Override  
                        public void onClick(DialogInterface dialog, int which) 
                        {}  
                    })
                    .setNegativeButton("NO", new DialogInterface.OnClickListener() {  
                        @Override  
                        public void onClick(DialogInterface dialog, int which) 
                        {}
                    }).create().show();  
                }
    
                @SuppressWarnings("unused")
                @JavascriptInterface
                public String showResult() 
                {
                    String strRet = "I am the message from Android";
                    return strRet;
                }
    
    
            }, "CustimizeAndroidFunc");  
    
            m_Webview.loadUrl("file:///android_asset/js_work.html");
        }
    
        @Override
        public boolean onCreateOptionsMenu(Menu menu) {
            // Inflate the menu; this adds items to the action bar if it is present.
            getMenuInflater().inflate(R.menu.main, menu);
            return true;
        }
    
    }
    

    測试GUI.
    这里写图片描写叙述

    測试结果
    - 点击红色部分的按钮时,输入在Android对话框中的内容会把值显示在HTML的输入框中。

    • 点击蓝色部分的按钮时Android函数的返回值会被显示到HTML中。

    这里写图片描写叙述

  • 相关阅读:
    阿里云 NAS OSS 云盘价格对比 GB/小时
    kubernetes/k8s pod下多容器的设计模式(ambassador 大使代理模式,adapter 适配模式,sidecar 边车模式, init containers初始化容器)
    ❤️ 从125ms到11ms,记一次关键字检测过滤服务的优化 -python and Pythonnet
    高效的的关键字查找和检测(哈希表和Trie前缀树和FastCheck)在实际使用中的性能
    FastAPI 中的Async (并发和async/await)
    阿里云vs华为云 的容器镜像服务swr使用体验
    Supermap IClient3D 加载3DTiles倾斜摄影数据
    C#根据数据生成力引导图
    Android WebView
    Nginx 反向代理地址后,session丢失,不能登录的问题
  • 原文地址:https://www.cnblogs.com/clnchanpin/p/7087005.html
Copyright © 2011-2022 走看看