From 6672e9efddf60fd641514485fdf4d5d1aeddc6d2 Mon Sep 17 00:00:00 2001 From: syuilo Date: Mon, 18 Dec 2023 13:07:19 +0900 Subject: [PATCH] refactor(frontend): use GLSL ES 3.0 --- .../frontend/src/scripts/snowfall-effect.ts | 39 +++++++++---------- 1 file changed, 18 insertions(+), 21 deletions(-) diff --git a/packages/frontend/src/scripts/snowfall-effect.ts b/packages/frontend/src/scripts/snowfall-effect.ts index 54fb48c5e..a09f02cec 100644 --- a/packages/frontend/src/scripts/snowfall-effect.ts +++ b/packages/frontend/src/scripts/snowfall-effect.ts @@ -4,24 +4,20 @@ */ export class SnowfallEffect { - private VERTEX_SOURCE = ` - precision highp float; - - attribute vec4 a_position; - attribute vec4 a_color; - attribute vec3 a_rotation; - attribute vec3 a_speed; - attribute float a_size; - + private VERTEX_SOURCE = `#version 300 es + in vec4 a_position; + in vec4 a_color; + in vec3 a_rotation; + in vec3 a_speed; + in float a_size; + out vec4 v_color; + out float v_rotation; uniform float u_time; uniform mat4 u_projection; uniform vec3 u_worldSize; uniform float u_gravity; uniform float u_wind; - varying vec4 v_color; - varying float v_rotation; - void main() { v_color = a_color; v_rotation = a_rotation.x + u_time * a_rotation.y; @@ -41,13 +37,13 @@ export class SnowfallEffect { } `; - private FRAGMENT_SOURCE = ` + private FRAGMENT_SOURCE = `#version 300 es precision highp float; + in vec4 v_color; + in float v_rotation; uniform sampler2D u_texture; - - varying vec4 v_color; - varying float v_rotation; + out vec4 out_color; void main() { vec2 rotated = vec2( @@ -55,9 +51,9 @@ export class SnowfallEffect { cos(v_rotation) * (gl_PointCoord.y - 0.5) - sin(v_rotation) * (gl_PointCoord.x - 0.5) + 0.5 ); - vec4 snowflake = texture2D(u_texture, rotated); + vec4 snowflake = texture(u_texture, rotated); - gl_FragColor = vec4(snowflake.rgb * v_color.xyz, snowflake.a * v_color.a); + out_color = vec4(snowflake.rgb * v_color.xyz, snowflake.a * v_color.a); } `; @@ -104,9 +100,9 @@ export class SnowfallEffect { private depth = 100; private count = 1000; private gravity = 100; - private speed: number = 1 / 15000; + private speed: number = 1 / 10000; private color: number[] = [1, 1, 1]; - private opacity = 0.75; + private opacity = 1; private size = 4; private snowflake = ''; @@ -159,7 +155,7 @@ export class SnowfallEffect { constructor() { const canvas = this.initCanvas(); - const gl = canvas.getContext('webgl', { antialias: true }); + const gl = canvas.getContext('webgl2', { antialias: true }); if (gl == null) throw new Error('Failed to get WebGL context'); document.body.append(canvas); @@ -190,6 +186,7 @@ export class SnowfallEffect { height: '100vh', background: 'transparent', 'pointer-events': 'none', + 'z-index': 2147483647, }); return canvas;