- Android 基礎
- Android - 首頁
- Android - 概述
- Android - 環境搭建
- Android - 架構
- Android - 應用元件
- Android - Hello World 示例
- Android - 資源
- Android - 活動 (Activities)
- Android - 服務 (Services)
- Android - 廣播接收器 (Broadcast Receivers)
- Android - 內容提供器 (Content Providers)
- Android - 碎片 (Fragments)
- Android - 意圖/過濾器 (Intents/Filters)
- Android - 使用者介面
- Android - UI 佈局
- Android - UI 控制元件
- Android - 事件處理
- Android - 樣式和主題
- Android - 自定義元件
- Android 高階概念
- Android - 拖放
- Android - 通知
- 基於位置的服務
- Android - 傳送電子郵件
- Android - 傳送簡訊
- Android - 電話撥打
- 釋出 Android 應用
- Android 實用示例
- Android - 警報對話方塊
- Android - 動畫
- Android - 音訊捕捉
- Android - 音訊管理器 (AudioManager)
- Android - 自動完成
- Android - 最佳實踐
- Android - 藍牙
- Android - 相機
- Android - 剪貼簿
- Android - 自定義字型
- Android - 資料備份
- Android - 開發者工具
- Android - 模擬器
- Android - Facebook 整合
- Android - 手勢
- Android - Google 地圖
- Android - 圖片特效
- Android - ImageSwitcher
- Android - 內部儲存
- Android - JetPlayer
- Android - JSON 解析器
- Android - LinkedIn 整合
- Android - 載入旋轉器
- Android - 本地化
- Android - 登入介面
- Android - MediaPlayer
- Android - 多點觸控
- Android - 導航
- Android - 網路連線
- Android - NFC 指南
- Android - PHP/MySQL
- Android - 進度圓圈
- Android - 進度條
- Android - 推送通知
- Android - RenderScript
- Android - RSS 閱讀器
- Android - 螢幕錄製
- Android - SDK 管理器
- Android - 感測器
- Android - 會話管理
- Android - 共享首選項
- Android - SIP 協議
- Android - 拼寫檢查器
- Android - SQLite 資料庫
- Android - 支援庫
- Android - 測試
- Android - 文字轉語音
- Android - TextureView
- Android - Twitter 整合
- Android - UI 設計
- Android - UI 模式
- Android - UI 測試
- Android - WebView 佈局
- Android - Wi-Fi
- Android - 小部件
- Android - XML 解析器
- Android 實用資源
- Android - 問答
- Android - 實用資源
- Android - 討論
Android - WebView
WebView 是一種在你的應用程式中顯示網頁的檢視。你也可以指定 HTML 字串,並使用 WebView 在你的應用程式中顯示它。WebView 將你的應用程式轉變為一個 web 應用程式。
為了將 WebView 新增到你的應用程式中,你必須將 <WebView> 元素新增到你的 xml 佈局檔案中。其語法如下:
<WebView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/webview" android:layout_width="fill_parent" android:layout_height="fill_parent" />
為了使用它,你必須在 Java 檔案中獲取此檢視的引用。要獲取引用,請建立一個 WebView 類的物件。其語法如下:
WebView browser = (WebView) findViewById(R.id.webview);
為了將 web url 載入到 WebView 中,你需要呼叫 WebView 類的 loadUrl(String url) 方法,並指定所需的 url。其語法如下:
browser.loadUrl("https://tutorialspoint.tw");
除了載入 url 之外,你還可以使用 WebView 類中定義的方法來更好地控制你的 WebView。它們列舉如下:
| 序號 | 方法和描述 |
|---|---|
| 1 |
canGoBack() 此方法指定 WebView 是否有後退歷史記錄項。 |
| 2 |
canGoForward() 此方法指定 WebView 是否有前進歷史記錄項。 |
| 3 |
clearHistory() 此方法將清除 WebView 的前進和後退歷史記錄。 |
| 4 |
destroy() 此方法銷燬 WebView 的內部狀態。 |
| 5 |
findAllAsync(String find) 此方法查詢所有字串例項並突出顯示它們。 |
| 6 |
getProgress() 此方法獲取當前頁面的進度。 |
| 7 |
getTitle() 此方法返回當前頁面的標題。 |
| 8 |
getUrl() 此方法返回當前頁面的 url。 |
如果你點選 WebView 網頁中的任何連結,該頁面不會在你的 WebView 中載入。為此,你需要從 WebViewClient 擴充套件你的類並重寫其方法。其語法如下:
private class MyBrowser extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}
示例
這是一個演示 WebView 佈局用法的示例。它建立一個基本的 web 應用程式,將要求你指定一個 url,並在 WebView 中載入此 url 網站。
要試驗此示例,你需要在一個正在執行網際網路的實際裝置上執行它。
| 步驟 | 描述 |
|---|---|
| 1 | 你將使用 Android Studio 在 com.example.sairamkrishna.myapplication 包下建立一個 Android 應用程式。 |
| 2 | 修改 src/MainActivity.java 檔案以新增 WebView 程式碼。 |
| 3 | 修改 res/layout/activity_main 以新增相應的 XML 元件 |
| 4 | 修改 AndroidManifest.xml 以新增必要的許可權 |
| 5 | 執行應用程式,選擇一個正在執行的 Android 裝置,將應用程式安裝在其上並驗證結果。 |
以下是修改後的主活動檔案 src/MainActivity.java 的內容。
package com.example.sairamkrishna.myapplication;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebView;
import android.webkit.WebViewClient;
import android.widget.Button;
import android.widget.EditText;
public class MainActivity extends Activity {
Button b1;
EditText ed1;
private WebView wv1;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
b1=(Button)findViewById(R.id.button);
ed1=(EditText)findViewById(R.id.editText);
wv1=(WebView)findViewById(R.id.webView);
wv1.setWebViewClient(new MyBrowser());
b1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
String url = ed1.getText().toString();
wv1.getSettings().setLoadsImagesAutomatically(true);
wv1.getSettings().setJavaScriptEnabled(true);
wv1.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
wv1.loadUrl(url);
}
});
}
private class MyBrowser extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}
}
以下是修改後的 xml 檔案 res/layout/activity_main.xml 的內容。
在下面的程式碼中,abc 表示 tutorialspoint.com 的徽標
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">
<TextView android:text="WebView" android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textview"
android:textSize="35dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorials point"
android:id="@+id/textView"
android:layout_below="@+id/textview"
android:layout_centerHorizontal="true"
android:textColor="#ff7aff24"
android:textSize="35dp" />
<EditText
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/editText"
android:hint="Enter Text"
android:focusable="true"
android:textColorHighlight="#ff7eff15"
android:textColorHint="#ffff25e6"
android:layout_marginTop="46dp"
android:layout_below="@+id/imageView"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignRight="@+id/imageView"
android:layout_alignEnd="@+id/imageView" />
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageView"
android:src="@drawable/abc"
android:layout_below="@+id/textView"
android:layout_centerHorizontal="true" />
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Enter"
android:id="@+id/button"
android:layout_alignTop="@+id/editText"
android:layout_toRightOf="@+id/imageView"
android:layout_toEndOf="@+id/imageView" />
<WebView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/webView"
android:layout_below="@+id/button"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:layout_alignParentBottom="true" />
</RelativeLayout>
以下是 res/values/string.xml 的內容。
<resources> <string name="app_name">My Application</string> </resources>
以下是 AndroidManifest.xml 檔案的內容。
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.sairamkrishna.myapplication" >
<uses-permission android:name="android.permission.INTERNET" />
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
讓我們嘗試執行你的 WebView 應用程式。要從 Android Studio 執行應用程式,請開啟你的專案中的一個活動檔案,然後單擊工具欄中的執行
圖示。Android Studio 將顯示如下所示:
現在只需在 url 欄位中指定一個 url 並按下出現的瀏覽按鈕即可啟動網站。但在那之前,請確保你已連線到網際網路。按下按鈕後,將出現以下螢幕:
注意:只需更改 url 欄位中的 url,你的 WebView 就會開啟你想要的網站。
上圖顯示了 tutorialspoint.com 的 webview。
