summaryrefslogtreecommitdiff
path: root/src/models.c
diff options
context:
space:
mode:
authorjussi2022-06-13 00:20:34 +0300
committerjussi2022-06-13 00:20:34 +0300
commit7b26e0aa68fb45612083b8e6b5c970564804803d (patch)
treedab279d16464c30dfb0ccf0b1ff2b1725e2af530 /src/models.c
parent4cb361733ef4bce0e803501b750acdd81404778f (diff)
downloadreilua-enhanced-7b26e0aa68fb45612083b8e6b5c970564804803d.tar.gz
reilua-enhanced-7b26e0aa68fb45612083b8e6b5c970564804803d.tar.bz2
reilua-enhanced-7b26e0aa68fb45612083b8e6b5c970564804803d.zip
UnloadModelAnimations and IsModelAnimationValid.
Diffstat (limited to 'src/models.c')
-rw-r--r--src/models.c55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/models.c b/src/models.c
index 9d1b380..4e67ff0 100644
--- a/src/models.c
+++ b/src/models.c
@@ -2147,6 +2147,61 @@ int lmodelsUpdateModelAnimation( lua_State *L ) {
}
/*
+> success = RL_UnloadModelAnimations( ModelAnimations animations )
+
+Unload animation data
+
+- Failure return false
+- Success return true
+*/
+int lmodelsUnloadModelAnimations( lua_State *L ) {
+ if ( !lua_isnumber( L, -1 ) ) {
+ TraceLog( LOG_WARNING, "%s", "Bad call of function. RL_UnloadModelAnimations( ModelAnimations animations )" );
+ lua_pushboolean( L, false );
+ return 1;
+ }
+ size_t animId = lua_tointeger( L, -1 );
+
+ if ( !validAnimation( animId ) ) {
+ lua_pushboolean( L, false );
+ return 1;
+ }
+ UnloadModelAnimation( *state->animations[ animId ]->animations );
+ state->animations[ animId ]->animCount = 0;
+ state->animations[ animId ] = NULL;
+
+ lua_pushboolean( L, true );
+
+ return 1;
+}
+
+/*
+> valid = RL_IsModelAnimationValid( Model model, ModelAnimations animations )
+
+Check model animation skeleton match
+
+- Failure return nil
+- Success return bool
+*/
+int lmodelsIsModelAnimationValid( lua_State *L ) {
+ if ( !lua_isnumber( L, -2 ) || !lua_isnumber( L, -1 ) ) {
+ TraceLog( LOG_WARNING, "%s", "Bad call of function. RL_IsModelAnimationValid( Model model, ModelAnimations animations )" );
+ lua_pushnil( L );
+ return 1;
+ }
+ size_t animId = lua_tointeger( L, -1 );
+ size_t modelId = lua_tointeger( L, -2 );
+
+ if ( !validModel( modelId ) || !validAnimation( animId ) ) {
+ lua_pushnil( L );
+ return 1;
+ }
+ lua_pushboolean( L, IsModelAnimationValid( *state->models[ modelId ], *state->animations[ animId ]->animations ) );
+
+ return 1;
+}
+
+/*
> boneCount = RL_GetModelAnimationBoneCount( ModelAnimations animations, int animation )
Return modelAnimation bone count