bgfx/examples/04-mesh/vs_mesh.sc

33 lines
809 B
Python
Raw Normal View History

2013-02-22 09:07:31 +04:00
$input a_position, a_normal
$output v_pos, v_view, v_normal, v_color0
/*
2023-01-14 21:05:12 +03:00
* Copyright 2011-2023 Branimir Karadzic. All rights reserved.
2022-01-15 22:59:06 +03:00
* License: https://github.com/bkaradzic/bgfx/blob/master/LICENSE
2013-02-22 09:07:31 +04:00
*/
#include "../common/common.sh"
2015-05-29 01:27:00 +03:00
uniform vec4 u_time;
2013-02-22 09:07:31 +04:00
void main()
{
vec3 pos = a_position;
2015-05-29 01:27:00 +03:00
float sx = sin(pos.x*32.0+u_time.x*4.0)*0.5+0.5;
float cy = cos(pos.y*32.0+u_time.x*4.0)*0.5+0.5;
2013-02-22 09:07:31 +04:00
vec3 displacement = vec3(sx, cy, sx*cy);
vec3 normal = a_normal.xyz*2.0 - 1.0;
pos = pos + normal*displacement*vec3(0.06, 0.06, 0.06);
gl_Position = mul(u_modelViewProj, vec4(pos, 1.0) );
v_pos = gl_Position.xyz;
v_view = mul(u_modelView, vec4(pos, 1.0) ).xyz;
v_normal = mul(u_modelView, vec4(normal, 0.0) ).xyz;
float len = length(displacement)*0.4+0.6;
v_color0 = vec4(len, len, len, 1.0);
}