Hi guys,
Is it currently possible to animate UV offsets ? I am trying to fake water for mobile and I am thinking of animating the UV offset to fake the ripples.
Animting UV offsets
data:image/s3,"s3://crabby-images/7844c/7844c28b59e17831933616b9e3447ac89718bfcd" alt=""
data:image/s3,"s3://crabby-images/6e1ee/6e1ee4f4763088562754685f71a910ab9c06f3a8" alt=""
[video]https://www.youtube.com/watch?v=maoDVSdKmiQ[/video]
All questions to codingmonkey
data:image/s3,"s3://crabby-images/9166f/9166fe4e9f94d13377e6e9c524d66364f05e341b" alt=""
In these dark times i’m just do not knowed about - cUOffset.w and cVOffset.w uniforms ) and that’s why I made custom shader for sea foam : oTexCoord +=vec2(cUVShift)
actually for animate textures you need just create ValueAnimation for these this two uniforms: cUOffset and cVOffset especially for last float - “w” this is scroll
Or you may do little tweak(to animate one common uniform and not two) to the std LitSolid Shader with adding one line:
61 vTexCoord.xy += cUVShift.xy;
and also you need add you custom uniform to Uniforms.glsl
30 uniform vec2 cUVShift;
then just add new uniform to you mat that will be animated
and at last you may now animate this uniform with std stuff - ValueAnimation
[code] Material* seaFoamMaterial = cache->GetResource(“Materials/UL_MAT/MAT_SEAFOAM.xml”);
SharedPtr uvShiftAnimation (new ValueAnimation(context_));
uvShiftAnimation->SetKeyFrame(0.0f, Vector2(0.0f, 0.3f));
uvShiftAnimation->SetKeyFrame(2.0f, Vector2(0.0f, 0.7f));
uvShiftAnimation->SetKeyFrame(3.0f, Vector2(0.0f, 0.5f));
uvShiftAnimation->SetKeyFrame(4.0f, Vector2(0.0f, 0.4f));
uvShiftAnimation->SetKeyFrame(5.0f, Vector2(0.0f, 0.3f));
seaFoamMaterial->SetShaderParameterAnimation("UVOffset",uvShiftAnimation );
seaFoamMaterial->SetScene(Scene);[/code]
data:image/s3,"s3://crabby-images/7844c/7844c28b59e17831933616b9e3447ac89718bfcd" alt=""
Thanks a lot I will try it out
data:image/s3,"s3://crabby-images/e8cca/e8ccabf4093e745fe6bf1cadd76afa545f16f91f" alt=""
Or you can do the whole animation in vertex shader using cElapsedTime uniform to offset UVs.