Copy.js 783 Bytes
Newer Older
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
1 2 3 4 5 6 7 8 9 10
const React = require("react-native");
const GL = require("gl-react-native");

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

varying vec2 uv;
uniform sampler2D t;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
11
uniform bool preventAlphaMult;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
12 13

void main () {
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
14 15 16 17 18
  vec4 c = texture2D(t, uv);
  if (preventAlphaMult) // (I know if() in glsl is not performant. don't do this. It's just for readability purpose here)
    gl_FragColor = c / sqrt(c.a);
  else
    gl_FragColor = c;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
19 20 21 22 23 24 25
}
`
  }
});

class Copy extends GL.Component {
  render () {
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
26
    const { width, height, children: t, last, ...rest } = this.props;
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
27 28 29 30 31
    return <GL.View
      {...rest}
      shader={shaders.Copy}
      width={width}
      height={height}
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
32
      uniforms={{ t, preventAlphaMult: !last }}
Gaëtan Renaudeau's avatar
Gaëtan Renaudeau committed
33 34 35 36 37
    />;
  }
}

module.exports = Copy;