WebView

WebView — це простий елемент для рендерингу HTML-коду, який базується на рушії WebKit. Завдяки цьому WebView можна використовувати як примітивний веб-браузер для перегляду контенту з інтернету. Використання рушія WebKit гарантує, що відображення контенту буде аналогічним до інших браузерів на цьому рушії, наприклад, Google Chrome і Safari.

Основні методи класу WebView

  • boolean canGoBack()
    Повертає true, якщо перед поточною веб-сторінкою в історії навігації WebView є інші сторінки.
  • boolean canGoForward()
    Повертає true, якщо після поточної веб-сторінки в історії навігації WebView є інші сторінки.
  • void clearCache(boolean includeDiskFiles)
    Очищає кеш WebView.
  • void clearFormData()
    Очищає дані автозаповнення полів форм.
  • void clearHistory()
    Очищає історію навігації WebView.
  • String getUrl()
    Повертає адресу поточної веб-сторінки.
  • void goBack()
    Переходить до попередньої веб-сторінки в історії навігації.
  • void goForward()
    Переходить до наступної веб-сторінки в історії навігації.
  • void loadData(String data, String mimeType, String encoding)
    Завантажує в браузер дані у вигляді HTML-коду з вказаним MIME-типом і кодуванням.
  • void loadDataWithBaseURL(String baseUrl, String data, String mimeType, String encoding, String historyUrl)
    Завантажує в браузер дані у вигляді HTML-коду, використовуючи вказаний MIME-тип і кодування. Крім того, приймає валідний базовий URL для зв'язку завантаженого контенту.
    Примітка:
    Метод loadData() встановлює значення null для window.origin, що може перешкоджати перевірці джерела вмісту. Метод loadDataWithBaseURL() дозволяє встановлювати джерело вмісту за допомогою валідних адрес (HTTP або HTTPS).
  • void loadUrl(String url)
    Завантажує веб-сторінку за вказаною адресою.
  • void postUrl(String url, byte[] postData)
    Надсилає дані за допомогою POST-запиту за вказаною адресою.
  • void zoomBy(float zoomFactor)
    Змінює масштаб на вказаний коефіцієнт.
  • boolean zoomIn()
    Збільшує масштаб.
  • boolean zoomOut()
    Зменшує масштаб.

Працювати з WebView дуже просто. Визначимо цей елемент у розмітці layout:

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <WebView
        android:id="@+id/webBrowser"
        android:layout_width="0dp"
        android:layout_height="0dp"
 
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"/>
 
</androidx.constraintlayout.widget.ConstraintLayout>
Для отримання доступу до інтернету із застосунку, необхідно вказати у файлі маніфесту AndroidManifest.xml відповідний дозвіл:
<uses-permission android:name="android.permission.INTERNET"/>

Щоб завантажити певну сторінку в WebView, через метод loadUrl() треба встановити її адресу:

package com.example.viewapp;
 
import androidx.appcompat.app.AppCompatActivity;
 
import android.os.Bundle;
import android.webkit.WebView;
 
public class MainActivity extends AppCompatActivity {
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
 
        WebView browser=findViewById(R.id.webBrowser);
        browser.loadUrl("https://itstep.org");
    }
}

Крім завантаження конкретної сторінки з інтернету за допомогою метод loadData():

WebView browser= findViewById(R.id.webBrowser);
browser.loadData("<html><body><h2>Hello, Android!</h2></body></html>", "text/html", "UTF-8");

Першим параметром метод приймає рядок коду html, у другому - тип вмісту, а в третьому - кодування.

JavaScript

За замовчуванням у WebView вимкнено javascript, щоб його увімкнути треба застосувати метод setJavaScriptEnabled(true) об'єкта WebSettings:

import android.webkit.WebSettings;
//.....................................
WebView browser = findViewById(R.id.webBrowser);
WebSettings webSettings = browser.getSettings();
webSettings.setJavaScriptEnabled(true);