HTML5 Web API для мобільних пристроїв: Використання та приклади

js 6 серп. 2023
 HTML5 Web API для мобільних пристроїв: Використання та приклади

HTML5 надав багато нових можливостей для розробки мобільних веб-додатків, завдяки розширенню API (Application Programming Interface). Ці API надають розробникам доступ до різних функцій і можливостей пристроїв, дозволяючи створювати більш потужні та інтерактивні додатки, пристосовані до вимог сучасних користувачів. У цій статті ми розглянемо деякі з найпоширеніших HTML5 Web API для мобільних пристроїв та надамо приклади їх використання.

1. Geolocation API:

Geolocation API дозволяє отримати географічне розташування користувача з допомогою GPS або інших джерел. Це дозволяє створювати локаційні додатки, картографічні сервіси та інші застосунки, що використовують інформацію про місцезнаходження.

<button onclick="getLocation()">Отримати моє місцезнаходження</button>
<p id="demo"></p>

<script>
  function getLocation() {
    if (navigator.geolocation) {
      navigator.geolocation.getCurrentPosition(showPosition);
    } else {
      document.getElementById("demo").innerHTML = "Геолокація не підтримується цим пристроєм.";
    }
  }

  function showPosition(position) {
    var latitude = position.coords.latitude;
    var longitude = position.coords.longitude;
    document.getElementById("demo").innerHTML = "Моє місцезнаходження: " + latitude + ", " + longitude;
  }
</script>

2. Web Storage API:

Web Storage API дозволяє зберігати дані на стороні клієнта. Завдяки цьому можна зберігати інформацію навіть після закриття браузера або перезавантаження сторінки. Це корисно для збереження налаштувань, локальних даних користувача тощо.

<input type="text" id="username" placeholder="Введіть своє ім'я">
<button onclick="saveUsername()">Зберегти</button>
<p id="output"></p>

<script>
  function saveUsername() {
    var username = document.getElementById("username").value;
    localStorage.setItem("username", username);
    document.getElementById("output").innerHTML = "Вітаю, " + username + "! Ваше ім'я збережено.";
  }
</script>

3. Device Orientation API:

Device Orientation API дозволяє отримати дані про орієнтацію пристрою у просторі. За допомогою цього API можна створювати ігри та додатки, які реагують на рухи та нахил пристрою.

<p id="tilt-info">Кут нахилу:</p>

<script>
  window.addEventListener("deviceorientation", handleOrientation, true);

  function handleOrientation(event) {
    var tiltLR = event.gamma; // Кут нахилу відносно лівої-правої осі
    var tiltFB = event.beta; // Кут нахилу відносно передньо-задньої осі
    var tiltDir = event.alpha; // Кут повороту пристрою

    document.getElementById("tilt-info").innerHTML = "Кут нахилу: " + tiltLR + ", " + tiltFB;
  }
</script>

4. MediaDevices API:

MediaDevices API дозволяє отримати доступ до мультимедійних пристроїв, таких як камера та мікрофон. Це корисно для створення фото- та відео-додатків, додатків для розпізнавання облич, QR-кодів та багато іншого.

<video id="video" width="640" height="480" autoplay></video>
<button onclick="startCamera()">Запустити камеру</button>

<script>
  async function startCamera() {
    try {
      const stream = await navigator.mediaDevices.getUserMedia({ video: true });
      const videoElement = document.getElementById("video");
      videoElement.srcObject = stream;
    } catch (error) {
      console.error("Помилка доступу до камери: ", error);
    }
  }
</script>

5. Vibration API:

Vibration API дозволяє контролювати вібрацію пристрою, якщо він підтримує цю функцію. Використовується для створення вібраційного сповіщення або ефектів у додатках.

<button onclick="vibrateDevice()">Вібрація</button>

<script>
  function vibrateDevice() {
    if ("vibrate" in navigator) {
      navigator.vibrate(200); // Вібрація тривалістю 200 мс
    } else {
      console.log("Ваш пристрій не підтримує вібрацію.");
    }
  }
</script>

6. Notifications API:

Notifications API дозволяє надсилати сповіщення користувачеві навіть тоді, коли додаток не активний або браузер закрито. Це дозволяє створювати push-сповіщення та інші повідомлення.

<button onclick="showNotification()">Показати сповіщення</button>

<script>
  function showNotification() {
    if ("Notification" in window) {
      Notification.requestPermission().then(function (permission) {
        if (permission === "granted") {
          new Notification("Привіт!", { body: "Це приклад сповіщення." });
        }
      });
    } else {
      console.log("Сповіщення не підтримується в вашому браузері.");
    }
  }
</script>

7. Battery Status API:

Battery Status API дозволяє отримувати інформацію про рівень заряду батареї пристрою та статус зарядки. Це дозволяє створювати додатки, які оптимізують свою роботу в залежності від рівня заряду батареї.

<p id="battery-level">Рівень заряду батареї: </p>

<script>
  navigator.getBattery().then(function (battery) {
    function updateBatteryStatus() {
      var level = battery.level * 100; // переводимо у відсотки
      document.getElementById("battery-level").innerText = "Рівень заряду батареї: " + level + "%";
    }

    updateBatteryStatus();

    battery.addEventListener("levelchange", updateBatteryStatus);
  });
</script>

8. Payment Request API:

Payment Request API дозволяє спростити процес оплати у додатках, дозволяючи використовувати збережені дані користувача для швидкої оплати покупок.

<button onclick="requestPayment()">Заплатити за замовлення</button>

<script>
  function requestPayment() {
    var paymentDetails = {
      total: {
        label: "Загальна сума",
        amount: { currency: "USD", value: "10.00" },
      },
    };

    var paymentOptions = {
      requestPayerName: true,
      requestPayerEmail: true,
      requestPayerPhone: true,
    };

    var paymentRequest = new PaymentRequest([paymentDetails], paymentOptions);

    paymentRequest
      .show()
      .then(function (paymentResponse) {
        // Обробка платежу і відправка на сервер
        paymentResponse.complete("success");
      })
      .catch(function (error) {
        console.error("Помилка оплати: ", error);
      });
  }
</script>

9. Background Sync API:

Background Sync API дозволяє заплановувати синхронізацію даних між додатком та сервером, навіть коли додаток не активний або відключений. Це корисно для забезпечення оновлення даних навіть при нестабільному інтернет-з'єднанні.

(Примітка: Цей API може працювати тільки під умовою, що додаток використовує HTTPS.)

<p id="sync-status">Статус синхронізації: </p>

<script>
  if ("serviceWorker" in navigator && "SyncManager" in window) {
    navigator.serviceWorker.ready.then(function (registration) {
      if ("periodicSync" in registration) {
        document.getElementById("sync-status").innerText = "Підтримується періодична синхронізація.";
      } else {
        document.getElementById("sync-status").innerText = "Періодична синхронізація не підтримується.";
      }
    });
  } else {
    document.getElementById("sync-status").innerText = "Сервісні робітники або Background Sync не підтримуються.";
  }
</script>

10. Screen Orientation API:

Screen Orientation API дозволяє зчитувати та контролювати орієнтацію екрана пристрою (портретна або ландшафтна). Це корисно для створення додатків, які адаптують свій вигляд залежно від орієнтації екрана.

<p id="orientation-info">Орієнтація екрана: </p>

<script>
  function updateOrientationStatus() {
    var orientation = screen.orientation || screen.mozOrientation || screen.msOrientation || "невідомий";
    document.getElementById("orientation-info").innerText = "Орієнтація екрана: " + orientation.type;
  }

  updateOrientationStatus();
  window.addEventListener("orientationchange", updateOrientationStatus);
</script>

Ці приклади демонструють лише деякі з HTML5 Web API для мобільних пристроїв. Використання цих API дозволяє розробникам створювати потужні та інтерактивні додатки, які працюють на різних мобільних платформах та забезпечують зручний досвід для користувачів. Розуміння та використання цих API допомагає створювати передові та інноваційні мобільні додатки.

HTML5 Web API для мобільних пристроїв надають розробникам масив можливостей для створення потужних та інноваційних додатків. Завдяки цим API можна забезпечити доступ до функцій пристрою, таких як геолокація, камера, батарея, вібрація та інші, що дозволяє створювати додатки, які взаємодіють з користувачем на новому рівні.

Наведені в статті приклади демонструють лише невелику частину можливостей HTML5 Web API. Залежно від потреб вашого проекту, ви можете використовувати більше API та поєднувати їх для створення унікального досвіду для користувачів. Будьте креативними та експериментуйте з можливостями, які надає HTML5 Web API, щоб розробити додатки, які привернуть увагу та забезпечать більш зручний досвід користувачам.

Бажаємо успіхів у розробці ваших мобільних додатків на основі HTML5 Web API!