/* Copyright (c) 2019 The Khronos Group Inc. Use of this source code is governed by an MIT-style license that can be found in the LICENSE.txt file. */ attribute vec4 gtf_Color; attribute vec4 gtf_Vertex; uniform mat4 gtf_ModelViewProjectionMatrix; varying vec4 color; void main (void) { const float M_PI = 3.14159265358979323846; // Both are unit vectors vec2 v1; vec2 v2 = normalize(vec2(1.0, 1.0)); float theta = gtf_Color.g * 2.0 * M_PI; float phi = gtf_Color.b * 2.0 * M_PI; v1.x = cos(theta) * sin(phi); v1.y = sin(theta) * sin(phi); if(dot(v1, v2) >= 0.0) v1 *= -1.0; color = vec4((v1 + 1.0) / 2.0, 0.0, 1.0); gl_Position = gtf_ModelViewProjectionMatrix * gtf_Vertex; }