Server IP : 195.201.23.43 / Your IP : 3.18.213.37 Web Server : Apache System : Linux webserver2.vercom.be 5.4.0-192-generic #212-Ubuntu SMP Fri Jul 5 09:47:39 UTC 2024 x86_64 User : kdecoratie ( 1041) PHP Version : 7.1.33-63+ubuntu20.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /proc/self/root/lib/libreoffice/program/opengl/ |
Upload File : |
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #version 150 layout(triangles) in; layout(triangle_strip, max_vertices=11) out; uniform float shadow; uniform mat4 u_projectionMatrix; uniform mat4 orthoProjectionMatrix; uniform mat4 orthoViewMatrix; in vec2 g_texturePosition[]; in vec3 g_normal[]; in mat4 modelViewMatrix[]; in mat4 transform[]; in float nTime[]; in float startTime[]; in float endTime[]; out vec2 v_texturePosition; out vec3 v_normal; out vec4 shadowCoordinate; mat4 identityMatrix(void) { return mat4(1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0); } mat4 scaleMatrix(vec3 axis) { mat4 matrix = identityMatrix(); matrix[0][0] = axis.x; matrix[1][1] = axis.y; matrix[2][2] = axis.z; return matrix; } mat4 translationMatrix(vec3 axis) { mat4 matrix = identityMatrix(); matrix[3] = vec4(axis, 1.0); return matrix; } void emitHexagonVertex(int index, vec3 translation, float fdsq) { mat4 projectionMatrix; mat4 shadowMatrix; if (shadow < 0.5) { projectionMatrix = u_projectionMatrix; shadowMatrix = orthoProjectionMatrix * orthoViewMatrix; } else { projectionMatrix = orthoProjectionMatrix * orthoViewMatrix; shadowMatrix = mat4(0.0); } mat4 normalMatrix = transpose(inverse(modelViewMatrix[index])); vec4 pos = gl_in[index].gl_Position + vec4(translation, 0.0); // Apply our transform operations. pos = transform[index] * pos; v_normal = normalize(vec3(normalMatrix * transform[index] * vec4(g_normal[index], 0.0))); v_normal.z *= fdsq; gl_Position = projectionMatrix * modelViewMatrix[index] * pos; shadowCoordinate = translationMatrix(vec3(0.5, 0.5, 0.5)) * scaleMatrix(vec3(0.5, 0.5, 0.5)) * shadowMatrix * modelViewMatrix[index] * pos; v_texturePosition = g_texturePosition[index]; EmitVertex(); } void main() { const vec4 invalidPosition = vec4(-256.0, -256.0, -256.0, -256.0); const vec3 noTranslation = vec3(0.0, 0.0, 0.0); if (gl_in[0].gl_Position == invalidPosition) return; // Draw “walls” to the hexagons. if (nTime[0] > startTime[0] && nTime[0] <= endTime[0]) { const vec3 translation = vec3(0.0, 0.0, -0.02); emitHexagonVertex(2, noTranslation, 0.3); emitHexagonVertex(2, translation, 0.3); for (int i = 0; i < 3; ++i) { emitHexagonVertex(i, noTranslation, 0.3); emitHexagonVertex(i, translation, 0.3); } EndPrimitive(); } // Draw the main quad part. for (int i = 0; i < 3; ++i) { emitHexagonVertex(i, noTranslation, 1.0); } EndPrimitive(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */Private