メイン コンテンツにスキップ

はじめに

GitHub

CapgoのAI-Assistedセットアップを使用してプラグインをインストールできます。AIツールにCapgoスキルを追加するには、以下のコマンドを使用してください:

ターミナル画面
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins

次に、以下のプロンプトを使用してください:

Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-native-loader` plugin in my project.

__CAPGO_KEEP_1__の場合、プラグインをインストールするには、以下のコマンドを実行し、下記のプラットフォーム固有の説明を参照してください:

  1. __CAPGO_KEEP_2__をインストール

    ターミナル画面
    npm install @capgo/capacitor-native-loader
    npx cap sync
  2. JavaScriptからネイティブローダーを表示

    import { NativeLoader } from '@capgo/capacitor-native-loader';
    const { id } = await NativeLoader.show({
    style: 'siri',
    placement: 'fullscreen',
    message: 'Preparing workspace',
    colors: ['#71f6ff', '#8b5cf6', '#ff4ecd', '#fff7ad'],
    scrimColor: 'rgba(3, 7, 18, 0.42)',
    interactionMode: 'block',
    });
    await doExpensiveWork();
    await NativeLoader.hide({ id });

__CAPGO_KEEP_3__を設定

__CAPGO_KEEP_4__
await NativeLoader.configure({
defaults: {
style: 'orbit',
placement: 'center',
size: 96,
colors: ['#38bdf8', '#a78bfa'],
reducedMotion: 'system',
interactionMode: 'passThrough',
},
});

__CAPGO_KEEP_5__

__CAPGO_KEEP_4__

__CAPGO_KEEP_0__ style: 'chrome' ブラウザのトップの進行バーと、WebViewがその下でも使えるようにするときに使用します。

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 エッジ ローダー

__CAPGO_KEEP_2__

Siri V2 エッジ ローダー style: 'siri-v2' __CAPGO_KEEP_3__

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 });
const { id } = await NativeLoader.show({
style: 'ring',
message: 'Uploading',
progress: 0,
});
for await (const progress of uploadFile(file)) {
await NativeLoader.setProgress({ id, progress });
}
await NativeLoader.hide({ id });

使用する場合 setWebViewLayout ネイティブのローダーが画面の一部を占有しながら、ウェブコンテンツが表示され、使用可能な場合

await NativeLoader.setWebViewLayout({
mode: 'inset',
insets: { top: 96, bottom: 24 },
animated: true,
});
await NativeLoader.show({
style: 'wave',
placement: 'top',
size: 72,
message: 'Syncing',
interactionMode: 'passThrough',
});

コピー

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

Lottie JSON またはイメージアセットをネイティブアプリにバンドルし、JavaScript から参照する

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

Native Swift Calls

「Native Swift Calls」

他のiOSプラグインは直接共有ローダーを呼び出すことができます。

import CapgoCapacitorNativeLoader
let id = NativeLoader.shared.show(options: [
"style": "siri",
"placement": "fullscreen",
"message": "Opening secure session",
"interactionMode": "block"
])
NativeLoader.shared.setProgress(id: id, progress: 0.6)
NativeLoader.shared.hide(id: id)

Native Kotlin Calls

「Native Kotlin Calls」

他のAndroidプラグインは直接KotlinまたはJavaから呼び出すことができます。

import app.capgo.nativeloader.NativeLoader
val id = NativeLoader.show(
activity = activity,
options = mapOf(
"style" to "orbit",
"placement" to "fullscreen",
"message" to "Loading profile",
"interactionMode" to "block",
),
webView = bridge.webView,
)
NativeLoader.setProgress(id, 0.6)
NativeLoader.hide(id)

Common Options

「Common Options」
オプションタイプ説明
style'siri' | 'siri-v2' | 'chrome' | 'orbit' | 'ring' | 'pulse' | 'dots' | 'bars' | 'wave' | 'halo' | 'lottie' | 'image'ローダーレンダラー
placement'center' | 'top' | 'bottom' | 'left' | 'right' | 'fullscreen' | 'around' | 'custom'ネイティブ表面の位置
interactionMode'passThrough' | 'block' | 'loaderOnly'タッチハンドリング
backgroundColorstringオーバーレイ色(アルファ含む)
scrimColorstringフルスクリーンまたは周辺スクリーンシーム色
colorsstring[]ローダーグラデーション色
progressnumber確定値から 0 まで 1
autoHidenumber自動的に非表示にするまでのミリ秒
assetobjectLottie または画像アセットのソース

使用 reducedMotion: 'system' ユーザーのプラットフォームの動きの設定を尊重する.