react-navigation自定义StackNavigator页面跳转动画

2018.02.09更新:
react-navigation内置跳转动画的路径发生了改变,由
react-navigation/src/views/CardStackStyleInterpolator 改为
react-navigation/src/views/CardStack/CardStackStyleInterpolator

---------------------------------------------- 分割线 ----------------------------------------------

使用StackNavigator跳转页面时,react-navigation根据平台的不同内置了相应的跳转动画。
内置的跳转动画在react-navigation/src/views/CardStack/CardStackStyleInterpolator中,共三种。forHorizontal:从右向左进入、forVertical:从下向上进入、forFadeFromBottomAndroid:从底部淡出。
关于修改默认的跳转动画或者自定义动画效果,以下给出两个场景。

修改整个栈内的页面跳转动画

这种场景是,一个栈内所有页面的跳转使用相同的动画效果,示例代码如下:

import CardStackStyleInterpolator from 'react-navigation/src/views/CardStack/CardStackStyleInterpolator';
const CustomerNavigator = StackNavigator({
  ScreenKey: { screen: MyScreen },
  // other screens
}, {
  transitionConfig: () => {
    screenInterpolator: CardStackStyleInterpolator.forVertical,
    transitionSpec: {
      duration: 250,
      easing: Easing.bounce,
      timing: Animated.timing,
    },
  },
});

在安卓上运行时,默认的跳转动画效果是forFadeFromBottomAndroid,经过上述配置,CustomerNavigator 内的页面切换时,会使用forVertical效果。
transitionSpec内可以配置与动画相关的属性。

通过传递参数决定某页面的跳转动画

在一个StackNavigator内,可能某些页面需要用forHorizontal的跳转方式,另一些需要用forVertical的跳转方式,以下是解决方案。

import CardStackStyleInterpolator from 'react-navigation/src/views/CardStack/CardStackStyleInterpolator';
const TransitionConfiguration = () => ({
  screenInterpolator: (sceneProps) => {
    const { scene } = sceneProps;
    const { route } = scene;
    const params = route.params || {};
    const transition = params.transition || 'forHorizontal';
    return CardStackStyleInterpolator[transition](sceneProps);
  },
});

const CustomerNavigator = StackNavigator({
  ScreenKey: { screen: MyScreen },
  // other screens
}, {
  transitionConfig: TransitionConfiguration,
});

假如希望CustomerNavigator内的某个页面使用forVertical的跳转动画效果,调用this.props.navigate('SomeScreenKey', { transition: 'forVertical' });切换页面即可。

总结

本文均使用react-navigation自带的跳转动画,因为这三种跳转方式可以满足很多需求,希望将来能内置更丰富的效果。
react-navigation支持自定义的跳转动画效果,获取sceneProps中的layout,position,scene属性,以及scene中的index属性,就能完成自定义动画的开发。具体可以参考这篇文章的内容。如果想对其动画原理有更深的了解,可以学习这篇文章

参考资料

  1. React Native Navigation, custom Scene (Screen) Transitions and interpolations
  2. issue#1187--Add support for custom transitionConfig

博文发布在个人博客,欢迎访问!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,089评论 25 709
  • WebSocket-Swift Starscream的使用 WebSocket 是 HTML5 一种新的协议。它实...
    香橙柚子阅读 24,175评论 8 184
  • 文/阿飞 你从哪找来? 这杯毒酒 邀我共饮,在花前月后 我明知有毒 毫不迟犹 与你共饮,在花前月后 你为何伤悲? ...
    阿飞先生阅读 170评论 0 1
  • 死亡,这个词对于二十几岁正值青春年华的人来说,似乎太过遥远、陌生!不知为什么最近突然经常会想到这个词,每天每时每...
    我的英雄梦想阅读 220评论 0 1
  • 俗话说宰相肚里能撑船,大肚能容天下难容之事。说的就是做人要有有度量,心胸要宽广。 山不言自高,水不言自深。凡事不必...
    幻曲风阅读 452评论 0 0