Zum Hauptinhalt springen
Zurück zu Plugins
@capgo/capacitor-native-loader
Tutorial
@capgo/capacitor-native-loader

Native Loader

Zeige native animierte Loader, transparente Überlagerungen, Lottie-Assets und WebView-Größenanpassungen von JavaScript oder nativen code

Richtlinie

Tutorial zu nativen Lädtstatus

Mit @capgo/capacitor-native-loader werden Lädtstatus über native iOS- und Android-Ansichten angezeigt. Verwende es, wenn ein Loader glatt bleiben muss, während der WebView beschäftigt ist, wenn transparente Vollbild-Effekte in CSS teuer sind oder wenn ein anderer nativer Plugin die Lade-UI vor der JavaScript-Verfügbarkeit anzeigen muss.

@capgo/capacitor-native-loader Installieren

protectedTokens

npm install @capgo/capacitor-native-loader
npx cap sync

Vollbild-Native-Lader

import { NativeLoader } from '@capgo/capacitor-native-loader';

const { id } = await NativeLoader.show({
  style: 'siri',
  placement: 'fullscreen',
  message: 'Preparing your session',
  colors: ['#71f6ff', '#8b5cf6', '#ff4ecd', '#fff7ad'],
  scrimColor: 'rgba(3, 7, 18, 0.42)',
  interactionMode: 'block',
});

await initializeAppData();
await NativeLoader.hide({ id });

Kantenlader mit WebView-Größe anpassen

await NativeLoader.setWebViewLayout({
  mode: 'inset',
  insets: { top: 96 },
  animated: true,
});

await NativeLoader.show({
  style: 'wave',
  placement: 'top',
  message: 'Syncing changes',
  interactionMode: 'passThrough',
});

Wenn das Laden abgeschlossen ist, wird der WebView wiederhergestellt:

await NativeLoader.hideAll({ restoreWebView: true });

Chrome-Stil-Top-Progress

Verwenden Sie den nativen oberen Progress-Lader, wenn Sie ein Browser-artiges Ladebalken oben über dem WebView ohne Anfrage an CSS während schwerer Arbeit möchten.

const { id } = await NativeLoader.show({
  style: 'chrome',
  placement: 'top',
  colors: ['#4285f4', '#34a853', '#fbbc05', '#ea4335'],
  thickness: 4,
  interactionMode: 'passThrough',
  webView: {
    mode: 'resize',
    insets: { top: 12 },
    restoreOnHide: true,
  },
});

await NativeLoader.hide({ id, restoreWebView: true });

Siri V2-Kantenlader

Verwenden Sie siri-v2 für einen nativen Vollbildlader, der die Farbe um die Bildschirmkante bewegt, während der WebView sichtbar bleibt.

const { id } = await NativeLoader.show({
  style: 'siri-v2',
  placement: 'fullscreen',
  colors: ['#71f6ff', '#8b5cf6', '#ff4ecd', '#fff7ad'],
  thickness: 10,
  scrimColor: 'rgba(3, 7, 18, 0.10)',
  interactionMode: 'passThrough',
});

await NativeLoader.hide({ id });

Lottie-Lader

await NativeLoader.show({
  style: 'lottie',
  placement: 'center',
  asset: {
    type: 'lottie',
    source: 'loader.json',
    loop: true,
  },
});

Bundelte Assets sind am besten für Startlader geeignet, da sie vor Netzwerkanfragen und JavaScript-Initialisierung verfügbar sind.

Native-Pluginaufrufe

Der Plugin stellt öffentliche native APIs zur Verfügung, damit ein anderes Plugin die Lader direkt anzeigen oder verberbern kann.

Swift:

import CapgoCapacitorNativeLoader

let id = NativeLoader.shared.show(options: [
  "style": "orbit",
  "placement": "fullscreen",
  "message": "Opening secure session"
])

NativeLoader.shared.hide(id: id)

Kotlin:

import app.capgo.nativeloader.NativeLoader

val id = NativeLoader.show(
  activity = activity,
  options = mapOf(
    "style" to "orbit",
    "placement" to "fullscreen",
    "message" to "Loading profile",
  ),
  webView = bridge.webView,
)

NativeLoader.hide(id)

Nützliche Links

Weitermachen Sie mit der Verwendung von @capgo/capacitor-native-loader

Wenn Sie native Medien und Schnittstellenverhalten planen Mit @capgo/capacitor-native-loader konnektieren Sie es mit @capgo/capacitor-native-loader für Implementierungsdetails, Einstieg für die Einrichtung Mit @capgo/capacitor-native-navigation für native Chrome- und WebView-Ansichten, und Mit @capgo/capacitor-transitions für WebView-Routenbewegungen.