はじめに
インストール手順とこのプラグインの全マークダウンガイドを含むセットアップ用の質問をコピーする
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-native-loader`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/native-loader/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
インストール
「インストール」のセクション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__の場合、プラグインをインストールするには、以下のコマンドを実行し、下記のプラットフォーム固有の説明を参照してください:
-
__CAPGO_KEEP_2__をインストール
ターミナル画面 npm install @capgo/capacitor-native-loadernpx cap sync -
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 });__CAPGO_KEEP_1__
アップデート中の進行状況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 });__CAPGO_KEEP_4__
「リサイズ可能な WebView」をタイトルにしたセクション使用する場合 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' | タッチハンドリング |
backgroundColor | string | オーバーレイ色(アルファ含む) |
scrimColor | string | フルスクリーンまたは周辺スクリーンシーム色 |
colors | string[] | ローダーグラデーション色 |
progress | number | 確定値から 0 まで 1 |
autoHide | number | 自動的に非表示にするまでのミリ秒 |
asset | object | Lottie または画像アセットのソース |
使用 reducedMotion: 'system' ユーザーのプラットフォームの動きの設定を尊重する.