diff --git a/src/views/StackView/StackViewCard.js b/src/views/StackView/StackViewCard.js
index af54ab8c4..b9d3f1e7a 100644
--- a/src/views/StackView/StackViewCard.js
+++ b/src/views/StackView/StackViewCard.js
@@ -1,21 +1,36 @@
import React from 'react';
-import { Animated, StyleSheet } from 'react-native';
+import { StyleSheet } from 'react-native';
+import { Screen } from './screens';
import createPointerEventsContainer from './createPointerEventsContainer';
+const EPS = 1e-5;
+
/**
* Component that renders the scene as card for the .
*/
class Card extends React.Component {
render() {
- const { children, pointerEvents, style } = this.props;
+ const {
+ children,
+ pointerEvents,
+ style,
+ position,
+ scene: { index },
+ } = this.props;
+ const active = position.interpolate({
+ inputRange: [index, index + 1 - EPS, index + 1],
+ outputRange: [1, 1, 0],
+ extrapolate: 'clamp',
+ });
return (
-
{children}
-
+
);
}
}
diff --git a/src/views/StackView/StackViewLayout.js b/src/views/StackView/StackViewLayout.js
index 4620fa191..07532b5d8 100644
--- a/src/views/StackView/StackViewLayout.js
+++ b/src/views/StackView/StackViewLayout.js
@@ -21,6 +21,7 @@ import {
import Card from './StackViewCard';
import Header from '../Header/Header';
+import { ScreenContainer } from './screens';
import TransitionConfigs from './StackViewTransitionConfigs';
import { supportsImprovedSpringAnimation } from '../../utils/ReactNativeFeatures';
@@ -469,9 +470,9 @@ class StackViewLayout extends React.Component {
return (
-
+
{scenes.map(s => this._renderCard(s))}
-
+
{floatingHeader}
);
diff --git a/src/views/StackView/screens.js b/src/views/StackView/screens.js
new file mode 100644
index 000000000..fce1d3fb8
--- /dev/null
+++ b/src/views/StackView/screens.js
@@ -0,0 +1,6 @@
+import { Animated, View } from 'react-native';
+
+const ScreenContainer = View;
+const Screen = Animated.View;
+
+export { ScreenContainer, Screen };