X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=src%2FAIModel%2FAIManager.cxx;h=2ad54837113ec7a6d5e22ca48583208603d54c82;hb=0905b4f36781c057b0c17b5af2c9ccfd72cf0fcd;hp=91ef652717e9cba4c7bdcb0f88fdcc3e322abc2c;hpb=1ebab94710faaa5295470ad77cc44be5e8104473;p=flightgear.git diff --git a/src/AIModel/AIManager.cxx b/src/AIModel/AIManager.cxx index 91ef65271..2ad548371 100644 --- a/src/AIModel/AIManager.cxx +++ b/src/AIModel/AIManager.cxx @@ -43,7 +43,12 @@ #include "AIGroundVehicle.hxx" #include "AIEscort.hxx" -FGAIManager::FGAIManager() { +FGAIManager::FGAIManager() : + cb_ai_bare(SGPropertyChangeCallback(this,&FGAIManager::updateLOD, + fgGetNode("/sim/rendering/static-lod/ai-bare", true))), + cb_ai_detailed(SGPropertyChangeCallback(this,&FGAIManager::updateLOD, + fgGetNode("/sim/rendering/static-lod/ai-detailed", true))) +{ _dt = 0.0; mNumAiModels = 0; @@ -181,6 +186,18 @@ FGAIManager::update(double dt) { thermal_lift_node->setDoubleValue( strength ); // for thermals } +/** update LOD settings of all AI/MP models */ +void +FGAIManager::updateLOD(SGPropertyNode* node) +{ + ai_list_iterator ai_list_itr = ai_list.begin(); + while(ai_list_itr != ai_list.end()) + { + (*ai_list_itr)->updateLOD(); + ++ai_list_itr; + } +} + void FGAIManager::attach(FGAIBase *model) {