// pathfinder/shaders/gles2/ecaa-curve.vs.glsl // // Copyright (c) 2017 Mozilla Foundation precision highp float; uniform ivec2 uFramebufferSize; uniform ivec2 uBVertexPositionDimensions; uniform ivec2 uBVertexPathIDDimensions; uniform ivec2 uPathTransformDimensions; uniform sampler2D uBVertexPosition; uniform sampler2D uBVertexPathID; uniform sampler2D uPathTransform; uniform bool uLowerPart; attribute vec2 aQuadPosition; attribute vec4 aCurveEndpointIndices; attribute vec2 aCurveControlPointIndex; varying vec4 vEndpoints; varying vec2 vControlPoint; void main() { // Fetch B-vertex positions. ivec3 pointIndices = ivec3(unpackUInt32Attribute(aCurveEndpointIndices.xy), unpackUInt32Attribute(aCurveEndpointIndices.zw), unpackUInt32Attribute(aCurveControlPointIndex)); vec2 leftPosition = fetchFloat2Data(uBVertexPosition, pointIndices.x, uBVertexPositionDimensions); vec2 rightPosition = fetchFloat2Data(uBVertexPosition, pointIndices.y, uBVertexPositionDimensions); vec2 controlPointPosition = fetchFloat2Data(uBVertexPosition, pointIndices.z, uBVertexPositionDimensions); int pathID = fetchUInt16Data(uBVertexPathID, pointIndices.x, uBVertexPathIDDimensions); vec4 transform = fetchFloat4Data(uPathTransform, pathID, uPathTransformDimensions); // Transform the points, and compute the position of this vertex. vec2 position; if (computeQuadPosition(position, leftPosition, rightPosition, aQuadPosition, uFramebufferSize, transform)) { controlPointPosition = transformVertexPositionST(controlPointPosition, transform); } float depth = convertPathIndexToDepthValue(pathID); gl_Position = vec4(position, depth, 1.0); vEndpoints = vec4(leftPosition, rightPosition); vControlPoint = controlPointPosition; }