본문으로 건너뛰기
플러그인으로 돌아가기
@capgo/capacitor-transitions
튜토리얼
@capgo/capacitor-transitions

전환

Ionic UI를 사용하지 않고 Ionic-style 페이지 전환 및 iOS 에지 스와이프 백 가젯을 추가하세요.

데모

WebP 애니메이션 데모

A React router flow showing iOS-style Capacitor page transitions as an animated WebP demo.

원본 자산
Animated React page transition demo showing forward and back navigation in a Capacitor-style shell
React transition flow

Guide

Tutorial on Transitions

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.

설치

npm install @capgo/capacitor-transitions

code 패키지는 native 플러그인 code를 추가하지 않기 때문에 native sync 단계가 없습니다.

요소 등록

import '@capgo/capacitor-transitions';

페이지 wrapping

<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>

라우터 연결

전환 방향을 정의하기 전에 일반적인 라우트 업데이트와 함께:

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 subpath에는 사용자 정의 요소에 대한 JSX 타이핑이 포함되어 있습니다. TypeScript가 여전히 "does not exist on" 오류를 보고한다면, 다음 파일을 추가하세요: cap-router-outlet Vite, Create React App, 및 대부분의 webpack React 앱의 경우, 그 파일을 "아래에 유지하는 것만으로도 충분합니다. Next.js 또는 사용자 정의 TypeScript 설정의 경우, 그것이 포함되어 있는지 확인하세요: JSX.IntrinsicElementsEdge gesture를 활성화하기 위해

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

iOS 네이티브 런타임이 보고하는 경우에만 제스처를 활성화하세요: src/ JavaScript에서 강제로 활성화할 수도 있습니다: tsconfig.json:

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

제스처는 사용자가 손가락을 놓을 때 완료되거나 취소됩니다. Edge gesture를 시작하지 않도록 하려면 버튼, 슬라이더, 또는 드로어에 "on"을 추가하세요.

Swipe back을 활성화하세요. swipe-gesture="auto" Capacitor가 iOS 네이티브 런타임을 보고하는 경우에만 제스처를 활성화하세요.

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

제스처를 강제로 활성화하세요.

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

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

Edge gesture는 사용자가 손가락을 놓을 때 완료되거나 취소됩니다. Edge gesture를 시작하지 않도록 하려면 버튼, 슬라이더, 또는 드로어에 "on"을 추가하세요. data-swipe-gesture-ignore Edge gesture는 사용자가 손가락을 놓을 때 완료되거나 취소됩니다.

자연스러운 네비게이션 사용

설치 @capgo/native-navigation 자연 네이티브层이 navbar 또는 tabbar을 소유할 때:

npm install @capgo/native-navigation
npx cap sync

자연 네이티브 크롬을 구성하고 WebView 페이지에 전환을 유지하는 CSS 변수로 전환:

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 animated page body와 자연스러운 네비게이션 CSS 변수를 사용하여 insets:

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

자연 네이티브 navbar을 중복하여 움직이는 웹 헤더로 사용하지 마십시오. @capgo/native-navigation 바를 자연스럽게 유지하고. @capgo/capacitor-transitions 그것 아래의 페이지 콘텐츠를 애니메이션합니다.

전체 참조

capgo와 capacitor을 사용하여 계속하세요.

__CAPGO_KEEP_0__을 사용하는 경우 Using @capgo/capacitor-transitions __CAPGO_KEEP_0__을 사용하여 네이티브 미디어 및 인터페이스 동작을 계획하고, __CAPGO_KEEP_1__을 사용하여 연결하세요. capgo을 사용하여 capacitor의 구현 세부 정보를 확인하세요. for the implementation detail in @capgo/capacitor-transitions, Getting Started의 구현 세부 정보를 확인하세요. __CAPGO_KEEP_0__을 사용하여 __CAPGO_KEEP_1__을 사용하여 라이브 활동을 사용하세요. capacitor을 사용하여 capgo의 네이티브 기능을 사용하세요. capgo을 사용하여 capacitor을 사용하세요. capgo/capacitor-live-activities for the implementation detail in @capgo/capacitor-live-activities, and Using @capgo/capacitor-video-player for the native capability in Using @capgo/capacitor-video-player.