Display2.js 1.03 KB
Newer Older
1
const React = require("react-native");
2
const GL = require("gl-react-core");
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24

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

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

void main () {
  float v = vertical ? 1.0 : 0.0;
  vec2 p = uv * mix(vec2(2.0, 1.0), vec2(1.0, 2.0), v);
  vec4 c1 = step(mix(p.x, p.y, v), 1.0) * texture2D(t1, p);
  vec4 c2 = step(1.0, mix(p.x, p.y, v)) * texture2D(t2, p - vec2(1.0-v, v));
  gl_FragColor = c1 + c2;
}
`
  }
});

25 26
module.exports = GL.createComponent(
  ({ width, height, children, vertical, ...rest }) => {
27 28 29
    if (!children || children.length !== 2) throw new Error("You must provide 2 children to Display2");
    let [t1, t2] = children;
    if (vertical) [t1,t2]=[t2,t1]; // just because webgl y's is reversed
30
    return <GL.Node
31 32 33 34
      {...rest}
      shader={shaders.display2}
      width={width}
      height={height}
35
      uniforms={{ t1, t2, vertical: !!vertical }}
36 37
      debug={true}
    />;
38 39 40
  },
  {
    displayName: "Display2"
41
  }
42
);