index.js 2.42 KB
Newer Older
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
const React = require("react-native");
const {
  StyleSheet,
  View,
  StatusBarIOS,
} = React;
const { width: viewportW, height: viewportH } = require("Dimensions").get("window");

const Banner = require("./Banner");
const Intro = require("./Intro");
const Vignette = require("./Vignette");
const Slideshow = require("./Slideshow");

class AdvancedEffects extends React.Component {

  constructor (props) {
    super(props);
    this.state = {
      time: 0.02,
      frames: 1,
      images:
       //"MQtLWbD,N8a9CkZ,adCmISK,AedZQ4N,y9qRJR3,brzKTYZ,NSyk07l,EaZiWfn,I1KZdnl,DoQBdzT,slIt2Ww,DA12puU,IYLdRFW,oqmO4Po,T6NaLyI,6XAPrAY,thYzbif,4qmqo3o,8xT2J96,ZCa2pWq,loQfDN2,oabfA68,uOXqDRY,MyyS4vK,fhNYTX4"
        "ljVkFzQ,ljVkFzQ,qM9BHCy,F7NKlQF,rYcweR7,IE8T6UX,3On9QEu"
          .split(",")
          .map(id => ({ uri: `http://imgur.com/${id}.jpg` }))
    };

    StatusBarIOS.setHidden(true);
  }

  componentDidMount () {
    let startTime;
    const loop = t => {
      requestAnimationFrame(loop);
      if (!startTime) startTime = t;
      const time = (t - startTime) / 1000;
      this.setState({ time: time, frames: this.state.frames+1 });
    };
    requestAnimationFrame(loop);
  }

  render () {
    const {time, frames, images} = this.state;

    const nbVignettes = 1;
    const imgW = Math.floor(viewportW/nbVignettes);
    const imgH = Math.floor((2/3)*viewportW/nbVignettes);
    const introH = 100;
    const transitionH = Math.floor((2/3)*viewportW);

    return (
      <View style={styles.root}>

        <Banner
          time={time}
          width={viewportW}
          height={viewportH - introH - imgH - transitionH}
        />

        <Intro
          time={time}
          fps={frames/time}
          width={viewportW}
          height={introH}
        />

        <View style={{ flex: 1, flexWrap: "wrap", flexDirection: "row" }}>
        {images.slice(0, nbVignettes).map((source, i) =>
          <Vignette key={i}
            time={time}
            width={imgW}
            height={imgH}
            i={i}
            source={source}
          />
        )}
        </View>

        <Slideshow
          time={time}
          width={viewportW}
          height={transitionH}
          images={images.slice(2)}
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
84 85
          pauseDuration={0.5}
          transitionDuration={1.5}
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
        />

      </View>
    );
  }
}

const styles = StyleSheet.create({
  root: {
    flex: 1,
    backgroundColor: "#111"
  }
});

module.exports = AdvancedEffects;