原生加载器 __CAPGO_KEEP_0__ 插件: 安装、设置 & 示例
返回插件
@capgo/capacitor-native-loader
教程
@capgo/capacitor-native-loader

原生加载器

Show native animated loaders, transparent overlays, Lottie assets, and WebView-resizing loading states from JavaScript or native code

指南

原生加载器教程

使用 @capgo/capacitor-native-loader

@capgo/capacitor-native-loader 通过原生 iOS 和 Android 视图渲染加载状态。使用它时 WebView 忙碌时加载器需要保持smooth时、CSS 中透明全屏效果昂贵时、或在 JavaScript 准备好之前另一个原生插件需要显示加载 UI 时。

安装

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

全屏原生加载器

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 });

边缘加载器与 WebView 缩放

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

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

加载完成后恢复 WebView:

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

Chrome 样式顶部进度条

在不要求 CSS 动画时,使用原生顶部进度条加载器来实现浏览器样式的加载条。

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 边缘加载器

使用 siri-v2 为显示屏幕边缘移动颜色的原生全屏加载器,WebView 可见。

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 加载器

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

捆绑资产最适合用于启动加载器,因为它们在网络请求和 JavaScript 初始化之前可用。

原生插件调用

插件公开原生 API,使另一个插件可以直接显示或隐藏加载器。

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)

有用链接

继续使用@capgo/capacitor-native-loader

如果您正在使用 使用@capgo/capacitor-native-loader 来规划原生媒体和界面行为,连接它与 @capgo/capacitor-native-loader 获取实现细节 开始使用 用于设置 使用@capgo/capacitor-native-navigation 用于原生Chrome和WebView布局 使用@capgo/capacitor-transitions 用于WebView路由动画