summaryrefslogtreecommitdiff
path: root/game/client/animatedentitytextureproxy.cpp
diff options
context:
space:
mode:
authorFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
committerFluorescentCIAAfricanAmerican <[email protected]>2020-04-22 12:56:21 -0400
commit3bf9df6b2785fa6d951086978a3e66f49427166a (patch)
tree2c0f1f0c63c4832882bc93814ebd2c2b1c6224e5 /game/client/animatedentitytextureproxy.cpp
downloadarchived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.tar.xz
archived-source-engine-2018-hl2-src-3bf9df6b2785fa6d951086978a3e66f49427166a.zip
Diffstat (limited to 'game/client/animatedentitytextureproxy.cpp')
-rw-r--r--game/client/animatedentitytextureproxy.cpp51
1 files changed, 51 insertions, 0 deletions
diff --git a/game/client/animatedentitytextureproxy.cpp b/game/client/animatedentitytextureproxy.cpp
new file mode 100644
index 0000000..47c7a62
--- /dev/null
+++ b/game/client/animatedentitytextureproxy.cpp
@@ -0,0 +1,51 @@
+//========= Copyright Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//=============================================================================//
+#include "cbase.h"
+#include "baseanimatedtextureproxy.h"
+
+// memdbgon must be the last include file in a .cpp file!!!
+#include "tier0/memdbgon.h"
+
+class CAnimatedEntityTextureProxy : public CBaseAnimatedTextureProxy
+{
+public:
+ CAnimatedEntityTextureProxy() {}
+ virtual ~CAnimatedEntityTextureProxy() {}
+
+ virtual float GetAnimationStartTime( void* pBaseEntity );
+ virtual void AnimationWrapped( void* pC_BaseEntity );
+
+};
+
+EXPOSE_INTERFACE( CAnimatedEntityTextureProxy, IMaterialProxy, "AnimatedEntityTexture" IMATERIAL_PROXY_INTERFACE_VERSION );
+
+float CAnimatedEntityTextureProxy::GetAnimationStartTime( void* pArg )
+{
+ IClientRenderable *pRend = (IClientRenderable *)pArg;
+ if (!pRend)
+ return 0.0f;
+
+ C_BaseEntity* pEntity = pRend->GetIClientUnknown()->GetBaseEntity();
+ if (pEntity)
+ {
+ return pEntity->GetTextureAnimationStartTime();
+ }
+ return 0.0f;
+}
+
+void CAnimatedEntityTextureProxy::AnimationWrapped( void* pArg )
+{
+ IClientRenderable *pRend = (IClientRenderable *)pArg;
+ if (!pRend)
+ return;
+
+ C_BaseEntity* pEntity = pRend->GetIClientUnknown()->GetBaseEntity();
+ if (pEntity)
+ {
+ pEntity->TextureAnimationWrapped();
+ }
+}