An open API service indexing awesome lists of open source software.

https://github.com/react-navigation/animated-switch

A switch navigator but with transitions between screens powered by the react-native-reanimated Transitions API
https://github.com/react-navigation/animated-switch

Last synced: 5 months ago
JSON representation

A switch navigator but with transitions between screens powered by the react-native-reanimated Transitions API

Awesome Lists containing this project

README

          

This package has been moved to https://github.com/react-navigation/react-navigation/tree/4.x/packages/animated-switch

---

# react-navigation-animated-switch

This navigator uses the [Reanimated Transitions API](https://github.com/kmagiera/react-native-reanimated) to animate route change transitions. Aside from the animations, it is identical to the standard [switch navigator](https://reactnavigation.org/docs/en/switch-navigator.html).

## Installation

- [Install react-native-reanimated >= 1.0.0](https://github.com/kmagiera/react-native-reanimated#installation) if you have not already (the alpha version will not work!). If you have a managed Expo project, you need to use >= SDK 33 to have the correct version of Reanimated.
- Install `react-navigation-animated-switch` with your favorite JS package manager.

## Usage

```js
import createAnimatedSwitchNavigator from 'react-navigation-animated-switch';

const MySwitch = createAnimatedSwitchNavigator({
Home: HomeScreen,
Other: OtherScreen,
});
```

Ta da! When you change between routes the screens will cross-fade with each other. You can customize the transition using the `transition` prop:

```js
import createAnimatedSwitchNavigator from 'react-navigation-animated-switch';
import { Transition } from 'react-native-reanimated';

const MySwitch = createAnimatedSwitchNavigator(
{
Home: HomeScreen,
Other: OtherScreen,
},
{
transition: (




),
}
);
```

If you need to customize the underlying `Transitioning.View` style, you can pass in a `transitionViewStyle` option.

```js
import createAnimatedSwitchNavigator from 'react-navigation-animated-switch';
import { Transition } from 'react-native-reanimated';

const MySwitch = createAnimatedSwitchNavigator(
{
Home: HomeScreen,
Other: OtherScreen,
},
{
transitionViewStyle: { backgroundColor: 'red' },
}
);
```

[Learn more about the `Transition` API here](https://github.com/kmagiera/react-native-reanimated).