diff options
-rw-r--r-- | source/gameengine/Converter/BL_ShapeDeformer.cpp | 6 | ||||
-rw-r--r-- | source/gameengine/Ketsji/KX_Scene.cpp | 9 |
2 files changed, 14 insertions, 1 deletions
diff --git a/source/gameengine/Converter/BL_ShapeDeformer.cpp b/source/gameengine/Converter/BL_ShapeDeformer.cpp index 43f719d80c4..8bb9f850bcf 100644 --- a/source/gameengine/Converter/BL_ShapeDeformer.cpp +++ b/source/gameengine/Converter/BL_ShapeDeformer.cpp @@ -122,6 +122,12 @@ void BL_ShapeDeformer::ProcessReplica() bool BL_ShapeDeformer::LoadShapeDrivers(KX_GameObject* parent) { + // Only load shape drivers if we have a key + if (GetKey() == NULL) { + m_useShapeDrivers = false; + return false; + } + // Fix drivers since BL_ArmatureObject makes copies if (parent->GetGameObjectType() == SCA_IObject::OBJ_ARMATURE) { BL_ArmatureObject *arma = (BL_ArmatureObject*)parent; diff --git a/source/gameengine/Ketsji/KX_Scene.cpp b/source/gameengine/Ketsji/KX_Scene.cpp index fbd9eeba8ed..e125dec860e 100644 --- a/source/gameengine/Ketsji/KX_Scene.cpp +++ b/source/gameengine/Ketsji/KX_Scene.cpp @@ -1601,6 +1601,7 @@ void KX_Scene::AddAnimatedObject(CValue* gameobj) static void update_anim_thread_func(TaskPool *pool, void *taskdata, int UNUSED(threadid)) { KX_GameObject *gameobj, *child; + RAS_Deformer *deformer; CListValue *children; bool needs_update; double curtime = *(double*)BLI_task_pool_userdata(pool); @@ -1648,8 +1649,14 @@ static void update_anim_thread_func(TaskPool *pool, void *taskdata, int UNUSED(t for (int j=0; j<children->GetCount(); ++j) { child = (KX_GameObject*)children->GetValue(j); - if (child->GetDeformer()) + deformer = child->GetDeformer(); + + // This check is ugly, but the modifier deformer currently doesn't + // work if called from here. This is a quick work-around to prevent + // crashing, but it really should be fixed. + if (deformer && !dynamic_cast<BL_ModifierDeformer*>(deformer)) { child->GetDeformer()->Update(); + } } children->Release(); |