Slideshow.js 2.07 KB
Newer Older
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
1
const React = require("react-native");
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
2
const { View, Text, StyleSheet } = React;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
3
const GL = require("gl-react-native");
4
const TransitionGenerator = require("./TransitionGenerator");
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
5 6
const Transition = require("./Transition");

7
const shaders = GL.Shaders.create(TransitionGenerator.shaders);
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
8 9

class Slideshow extends React.Component {
10 11 12 13
  constructor (props) {
    super(props);
    this._currentTransition = -1;
  }
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
14
  render () {
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
15 16
    const { transitionDuration, pauseDuration, width, height, time, images } = this.props;
    const duration = transitionDuration + pauseDuration;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
17
    const slide = time / duration;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
18
    let transitionProgress = Math.min(1, (duration/transitionDuration) * (slide % 1));
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
19 20 21
    let transitionFrom = images[Math.floor(slide) % images.length];
    let transitionTo = images[Math.floor(slide+1) % images.length];

22 23 24 25
    const currentTransition = Math.floor(slide);
    if (currentTransition !== this._currentTransition) {
      this._currentTransition = currentTransition;
      const { name, uniforms } = TransitionGenerator.random();
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
26
      this._name = name;
27 28 29 30
      this._shader = shaders[name];
      this._uniforms = uniforms;
    }

Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
31
    const transitionName = this._name;
32 33 34
    const transitionShader = this._shader;
    const transitionUniforms = this._uniforms;

Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
    return <View style={styles.root}>
      <Transition
        width={width}
        height={height}
        progress={transitionProgress}
        from={transitionFrom}
        to={transitionTo}
        shader={transitionShader}
        uniforms={transitionUniforms}
      />
    <View style={styles.legend}>
        <Text style={styles.textName}>{transitionName}</Text>
        <Text style={styles.textInfo}>(GLSL.io)</Text>
      </View>
    </View>;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
50 51 52
  }
}

Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
const styles = StyleSheet.create({
  root: {
    position: "relative"
  },
  legend: {
    position: "absolute",
    bottom: 5,
    right: 4,
    backgroundColor: "transparent",
    flexDirection: "row"
  },
  textName: {
    color: "#fff",
    fontWeight: "bold",
  },
  textInfo: {
    color: "#fff",
    marginLeft: 8,
    opacity: 0.5
  }
});

Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
75
module.exports = Slideshow;