diff options
author | Adrian Kummerlaender | 2018-12-19 19:07:05 +0100 |
---|---|---|
committer | Adrian Kummerlaender | 2018-12-19 19:07:31 +0100 |
commit | 994f70f0dd8fff208fab050a8a58f7fdf7bcfb24 (patch) | |
tree | f4cce099a3eafbc52b7dd1b8b23366c1fd8d4df9 /src/shader/code | |
parent | 6f6073be5de8c8598c4af7f38c90c3f83b5bf1bf (diff) | |
download | compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar.gz compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar.bz2 compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar.lz compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar.xz compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.tar.zst compustream-994f70f0dd8fff208fab050a8a58f7fdf7bcfb24.zip |
Tidy up external influence implementation
Diffstat (limited to 'src/shader/code')
-rw-r--r-- | src/shader/code/collide.glsl | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/src/shader/code/collide.glsl b/src/shader/code/collide.glsl index 2626c70..75bfd35 100644 --- a/src/shader/code/collide.glsl +++ b/src/shader/code/collide.glsl @@ -7,9 +7,10 @@ layout (std430, binding=1) buffer bufferCollide{ float collideCells[]; }; layout (std430, binding=2) buffer bufferStream{ float streamCells[]; }; layout (std430, binding=3) buffer bufferFluid{ float fluidCells[]; }; -uniform int mouseClicked; -uniform int mouseX; -uniform int mouseY; +/// external influence + +uniform int mouseState; +uniform vec2 mousePos; /// LBM constants @@ -97,6 +98,16 @@ vec2 velocity(uint x, uint y, float d) { ); } +/// Determine external influence + +float getExternalPressureInflux(uint x, uint y) { + if ( mouseState == 1 && norm(vec2(x,y) - mousePos) < 4 ) { + return 1.5; + } else { + return 0.0; + } +} + /// Actual collide kernel void main() { @@ -107,11 +118,7 @@ void main() { return; } - float d = density(x,y); - if ( mouseClicked == 1 && abs(x - mouseX) < 3 && abs(y - mouseY) < 3 ) { - d = 1.5; - } - + const float d = max(getExternalPressureInflux(x,y), density(x,y)); const vec2 v = velocity(x,y,d); setFluid(x,y,v,d); |