Layer.js 785 Bytes
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
const React = require("react-native");
const GL = require("gl-react-native");

const shaders = GL.Shaders.create({
  layer: {
    frag: `
precision highp float;

varying vec2 uv;
uniform sampler2D t1;
uniform sampler2D t2;

void main () {
  vec4 c1 = texture2D(t1, uv);
  vec4 c2 = texture2D(t2, uv);
16
  gl_FragColor = vec4(mix(c1.rgb, c2.rgb, c2.a), 1.0);
17 18 19 20 21 22 23
}
`
  }
});

class Layer extends GL.Component {
  render () {
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
24
    const { width, height, children, ...rest } = this.props;
25 26 27
    if (!children || children.length !== 2) throw new Error("You must provide 2 children to Layer");
    const [t1, t2] = children;
    return <GL.View
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
28
      {...rest}
29 30 31 32 33 34 35 36 37
      shader={shaders.layer}
      width={width}
      height={height}
      uniforms={{ t1, t2 }}
    />;
  }
}

module.exports = Layer;