index.js 2.43 KB
Newer Older
1
require("gl-react-core/react-native");
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
2 3 4 5 6 7 8
const React = require("react-native");
const {
  StyleSheet,
  View,
} = React;
const { width: viewportW, height: viewportH } = require("Dimensions").get("window");

Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
9 10
const resolveAssetSource = require("react-native/Libraries/Image/resolveAssetSource");

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

  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

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

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

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

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

module.exports = AdvancedEffects;