メインコンテンツにスキップ
プラグインに戻る
@capgo/capacitor-transitions
チュートリアル
@capgo/capacitor-transitions

トランジション

Ionicスタイルのページ遷移とiOSのエッジスワイプバックジェスチャーを追加する

デモ

アニメーションWebPデモ

iOSスタイルのCapacitorページ遷移を示すReactルーターフロー

ソースアセット
Animated React page transition demo showing forward and back navigation in a Capacitor-style shell
React遷移フロー

ガイド

トランジションのチュートリアル

Using @capgo/capacitor-transitions

@capgo/capacitor-transitions adds Ionic-style route transitions to Capacitor apps without adopting Ionic UI. It runs in the web layer, keeps your existing router, and can auto-enable an iOS edge swipe-back gesture only inside native Capacitor iOS.

__CAPGO_KEEP_0__アプリにこのパッケージをインストールすると、ルート遷移が自動的に有効になります。

npm install @capgo/capacitor-transitions

There is no native sync step because the package does not add native plugin code.

ページをラップする

import '@capgo/capacitor-transitions';

ルーターに接続する

<cap-router-outlet platform="auto" swipe-gesture="auto">
  <cap-page>
    <cap-header slot="header">
      <h1>Inbox</h1>
    </cap-header>

    <cap-content slot="content">
      <button>Open message</button>
    </cap-content>

    <cap-footer slot="footer">
      <nav>Tabs</nav>
    </cap-footer>
  </cap-page>
</cap-router-outlet>

ルートの更新前に遷移の方向を設定する

このパッケージは、__CAPGO_KEEP_0__アプリにnativeプラグインを追加する必要がないため、native syncステップはありません。

import { setDirection } from '@capgo/capacitor-transitions/react';

setDirection('forward');
router.push('/message/42');

setDirection('back');
router.back();

Reactの例

import { useEffect, useRef } from 'react';
import { useNavigate } from 'react-router-dom';
import { initTransitions, setDirection, setupPage, setupRouterOutlet } from '@capgo/capacitor-transitions/react';
import '@capgo/capacitor-transitions';

initTransitions({ platform: 'auto' });

export function AppShell() {
  const outletRef = useRef<HTMLElement>(null);

  useEffect(() => {
    if (!outletRef.current) return;
    setupRouterOutlet(outletRef.current, { platform: 'auto', swipeGesture: 'auto' });
  }, []);

  return <cap-router-outlet ref={outletRef}>{/* routes */}</cap-router-outlet>;
}

export function InboxPage() {
  const navigate = useNavigate();
  const pageRef = useRef<HTMLElement>(null);

  useEffect(() => {
    if (!pageRef.current) return;
    return setupPage(pageRef.current);
  }, []);

  return (
    <cap-page ref={pageRef}>
      <cap-header slot="header">
        <h1>Inbox</h1>
      </cap-header>
      <cap-content slot="content">
        <button
          onClick={() => {
            setDirection('forward');
            navigate('/message/42');
          }}
        >
          Open message
        </button>
      </cap-content>
    </cap-page>
  );
}

Reactのサブパスには、カスタム要素のためのJSXの型定義が含まれています。TypeScriptがまだ「」が存在しないと報告している場合、以下のファイルを追加してください。 cap-router-outlet Vite、Create React App、そして大部分のwebpack Reactアプリでは、そのファイルを以下のディレクトリに置くだけで十分です。Next.jsまたはカスタムTypeScriptの設定では、そのファイルが含まれていることを確認してください。 JSX.IntrinsicElementsスワイプバックを有効にする

// src/capgo-transitions.d.ts
import '@capgo/capacitor-transitions/react';

を使用してスワイプバックを有効にする src/ iOSのネイティブランタイムが報告される場合にのみジェスチャーを有効にする tsconfig.json:

{
  "include": ["src", "src/capgo-transitions.d.ts"]
}

ネイティブiOSランタイムが報告される場合にのみジェスチャーを有効にする

ネイティブiOSランタイムが報告されていない場合にのみジェスチャーを無効にする swipe-gesture="auto" to enable the gesture only when Capacitor reports a native iOS runtime:

<cap-router-outlet swipe-gesture="auto"></cap-router-outlet>

ネイティブiOSランタイムが報告されていない場合にのみジェスチャーを無効にする

const outlet = document.querySelector('cap-router-outlet');

outlet?.setSwipeGesture(true);
outlet?.setSwipeGesture(false);
outlet?.setSwipeGesture('auto');

ネイティブiOSランタイムが報告されていない場合にのみジェスチャーを無効にする data-swipe-gesture-ignore ネイティブiOSランタイムが報告されていない場合にのみジェスチャーを無効にする

ネイティブナビゲーションと組み合わせて使用

インストール @capgo/native-navigation ネイティブレイヤーがナビゲーションバーまたはタブバーを所有する場合の設定:

npm install @capgo/native-navigation
npx cap sync

ネイティブブラウザを設定し、WebViewページにフォーカスしたままのトランジションを設定します。

import { NativeNavigation } from '@capgo/native-navigation';
import { setDirection } from '@capgo/capacitor-transitions/react';
import { router } from './router';

await NativeNavigation.configure({
  contentInsetMode: 'css',
});

await NativeNavigation.setNavbar({
  title: 'Inbox',
  backButton: { visible: false },
});

await NativeNavigation.addListener('navbarBack', () => {
  setDirection('back');
  router.back();
});

async function openMessage(id: string) {
  setDirection('forward');
  router.push(`/message/${id}`);

  await NativeNavigation.setNavbar({
    title: 'Message',
    backButton: { visible: true, title: 'Inbox' },
  });
}

使用 cap-content アニメーションページボディとネイティブナビゲーションCSS変数のインセットのために:

<cap-router-outlet platform="auto" swipe-gesture="auto">
  <cap-page>
    <cap-content slot="content" fullscreen>
      <main class="native-page">Inbox content</main>
    </cap-content>
  </cap-page>
</cap-router-outlet>
.native-page {
  padding-top: var(--cap-native-navigation-top);
  padding-bottom: var(--cap-native-navigation-bottom);
}

ネイティブナビゲーションバーを移動するWebヘッダーとして複製しないでください。 @capgo/native-navigation バーはネイティブです。 @capgo/capacitor-transitions その下のページコンテンツをアニメーションします。

フルリファレンス

capgo/capacitorの使用を継続してください

使用中の場合 capgo/capacitorの使用 ネイティブのメディアとインターフェイスの動作を計画する場合、@__CAPGO_KEEP_0__/__CAPGO_KEEP_1__-transitionsと接続してください capgo/capacitor-transitionsの実装詳細 for the implementation detail in @capgo/capacitor-transitions, Getting Startedの実装詳細 __CAPGO_KEEP_0__/__CAPGO_KEEP_1__-live-activitiesの使用 capgo/capacitor-live-activitiesのネイティブ機能 capgo/capacitor-live-activities @capgo/capacitor-live-activities 実装詳細については@capgo/capacitor-live-activitiesのドキュメントを参照してください。 Using @capgo/capacitor-video-player Using @capgo/capacitor-video-player