index.js 2.34 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
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,
21
      embeddedImage: require("image!Image"),
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
22 23
      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"
24
        "wxqlQkh,G2Whuq3,0bUSEBX,giP58XN,iKdXwVm,IvpoR40,zJIxPEo,CKlmtPs,fnMylHI,vGXYiYy,MnOB9Le,YqsZKgc,0BJobQo,Otbz312"
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
25
          .split(",")
26
          .map(id => `http://imgur.com/${id}.jpg`)
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
    };

    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 () {
44
    const {time, frames, images, embeddedImage} = this.state;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67

    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}
        />

68 69 70 71 72 73
        <Vignette
          time={time}
          width={imgW}
          height={imgH}
          source={embeddedImage}
        />
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
74 75 76 77 78 79

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

      </View>
    );
  }
}

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

module.exports = AdvancedEffects;