Zum Hauptinhalt springen
Zurück zu Plugins
@capgo/capacitor-transitions
Tutorial
von github.com/Cap-go

Transitions

Fügen Sie ohne Ionic-UI Ionic-Style-Seiteneinblendungen und iOS-Rückgabetasten hinzu

Demo

Animated WebP-Demos

Ein React-Router-Flow, das iOS-stilige Capacitor-Seitenwechsel als animierte WebP-Demo zeigt.

Quellen
Animierte React-Seitenwechsel-Demo, die Vor- und Rücknavigation in einem Capacitor-Stil-Shell zeigt
React-Übergang-Flow

Richtlinie

Anleitung zu Übergängen

Mit @capgo/capacitor-Übergängen arbeiten

@capgo/capacitor-transitions fütt Ionic-Stil-Wechseltransaktionen zu Capacitor-Anwendungen hinzufütgen, ohne Ionic UI zu adoptieren. Es läuft im Weblayer, behält Ihre bestehende Router und kann ein iOS-Rückgabetaste-Schwenkgestisch nur innerhalb von nativen Capacitor-iOS-Anwendungen automatisch aktivieren.

Installieren

npm install @capgo/capacitor-transitions

Es gibt keine native Synchronisierungsstep, weil das Paket keine native Plugin code hinzufütgt.

Registrieren Sie die Elemente

import '@capgo/capacitor-transitions';

Um Ihre Seiten zu umschließen

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

Verbinden Sie es mit einem Router

Legen Sie die Übergangsdirektion vor Ihrer normalen Routenaktualisierung:

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

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

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

Beispiel für 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>
  );
}

Der React-Unterpfad enthält JSX-Typen für die benutzerdefinierten Elemente. Wenn TypeScript immer noch meldet, dass cap-router-outlet fütt nicht existiert auf JSX.IntrinsicElementsfütt dieses Datei hinzufütgen:

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

Für Vite, Create React App und die meisten webpack-React-Anwendungen, behalten Sie diese Datei unter src/ ist ausreichend. Stellen Sie sicher, dass es bei Next.js- oder benutzerdefinierten TypeScript-Einstellungen enthalten ist durch tsconfig.json:

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

Rückblende aktivieren

Verwenden swipe-gesture="auto" um die Geste nur dann zu aktivieren, wenn Capacitor eine native iOS- Runtime meldet:

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

Sie können es auch aus JavaScript zwingen:

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

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

Die Geste folgt der Fingerbewegung während der Übergang, dann wird sie abgeschlossen oder gestoppt, wenn der Benutzer loslässt. Fügen Sie data-swipe-gesture-ignore auf Schaltflächen, Sliders oder Schubladen, die die Edge-Geste nicht auslösen sollen.

Verwenden mit nativer Navigation

Installieren @capgo/native-navigation wenn die native Layer die Navbar oder Tabbar besitzen soll:

npm install @capgo/native-navigation
npx cap sync

Konfigurieren Sie die native Chrome, dann behalten Sie die Übergänge auf den WebView-Seiten im Auge:

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

Verwenden cap-content für den animierten Seitenkörper und native-Navigation-CSS-Variablen für Einfügungen:

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

Dupliciere die native Navbar nicht als bewegliche Web-Oberfläche. @capgo/native-navigation hält die native Leiste; @capgo/capacitor-transitions animiert den Inhalt der Seite darunter.

Vollständige Referenz

Weitermachen von Using @capgo/capacitor-transitions

Wenn Sie Using verwenden Verwendung von @capgo/capacitor-transitions um native Medien und Schnittstellenverhalten zu planen, verbinden Sie es mit @capgo/capacitor-Übergänge für die Implementierungsdetails in @capgo/capacitor-Übergänge, Einstieg für die Implementierungsdetails in Einstieg, Verwendung von @capgo/capacitor-live-Aktivitäten für die native Fähigkeit in Verwendung von @capgo/capacitor-live-Aktivitäten, @capgo/capacitor-live-Aktivitäten für die Implementierungsdetails in @capgo/capacitor-live-Aktivitäten und Verwendung von @capgo/capacitor-Video-Player für die native Fähigkeit in Verwendung von @capgo/capacitor-Video-Player.