1
0
Fork 0
mirror of https://github.com/alacritty/alacritty.git synced 2024-11-18 13:55:23 -05:00
alacritty/res/text.v.glsl

75 lines
2.2 KiB
Text
Raw Permalink Normal View History

2016-06-30 00:01:22 -04:00
// Copyright 2016 Joe Wilm, The Alacritty Project Contributors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#version 330 core
// Cell properties
2019-02-04 14:03:25 -05:00
layout (location = 0) in vec2 gridCoords;
// glyph properties
2019-02-04 14:03:25 -05:00
layout (location = 1) in vec4 glyph;
// uv mapping
2019-02-04 14:03:25 -05:00
layout (location = 2) in vec4 uv;
// text fg color
2019-02-04 14:03:25 -05:00
layout (location = 3) in vec3 textColor;
// Background color
2019-02-04 14:03:25 -05:00
layout (location = 4) in vec4 backgroundColor;
out vec2 TexCoords;
2019-02-04 14:03:25 -05:00
flat out vec3 fg;
flat out vec4 bg;
// Terminal properties
uniform vec2 cellDim;
2019-02-04 14:03:25 -05:00
uniform vec4 projection;
uniform int backgroundPass;
void main()
{
2019-02-04 14:03:25 -05:00
vec2 projectionOffset = projection.xy;
vec2 projectionScale = projection.zw;
2019-02-04 14:03:25 -05:00
// Compute vertex corner position
vec2 position;
position.x = (gl_VertexID == 0 || gl_VertexID == 1) ? 1. : 0;
position.y = (gl_VertexID == 0 || gl_VertexID == 3) ? 0. : 1;
2019-02-04 14:03:25 -05:00
// Position of cell from top-left
vec2 cellPosition = cellDim * gridCoords;
if (backgroundPass != 0) {
2019-02-04 14:03:25 -05:00
vec2 finalPosition = cellPosition + cellDim * position;
gl_Position = vec4(projectionOffset + projectionScale * finalPosition, 0.0, 1.0);
TexCoords = vec2(0, 0);
} else {
2019-02-04 14:03:25 -05:00
vec2 glyphSize = glyph.zw;
vec2 glyphOffset = glyph.xy;
glyphOffset.y = cellDim.y - glyphOffset.y;
2019-02-04 14:03:25 -05:00
vec2 finalPosition = cellPosition + glyphSize * position + glyphOffset;
gl_Position = vec4(projectionOffset + projectionScale * finalPosition, 0.0, 1.0);
2019-02-04 14:03:25 -05:00
vec2 uvOffset = uv.xy;
vec2 uvSize = uv.zw;
TexCoords = uvOffset + position * uvSize;
}
bg = vec4(backgroundColor.rgb / 255.0, backgroundColor.a);
fg = textColor / vec3(255.0, 255.0, 255.0);
}