#ifndef _DNAMP1_DOORAREA_HPP_ #define _DNAMP1_DOORAREA_HPP_ #include "../../DNACommon/DNACommon.hpp" #include "IScriptObject.hpp" #include "Parameters.hpp" namespace DataSpec { namespace DNAMP1 { struct DoorArea : IScriptObject { DECL_YAML String<-1> name; Value location; Value orientation; Value scale; AnimationParameters animationParameters; ActorParameters actorParameters; Value unknown1; Value collisionExtent; Value collisionOffset; Value unknown4; Value unknown5; Value unknown6; Value unknown7; Value unknown8; void addCMDLRigPairs(PAKRouter& pakRouter, std::unordered_map>& addTo) const { actorParameters.addCMDLRigPairs(addTo, animationParameters.getCINF(pakRouter)); } void nameIDs(PAKRouter& pakRouter) const { animationParameters.nameANCS(pakRouter, name + "_animp"); actorParameters.nameIDs(pakRouter, name + "_actp"); } void gatherDependencies(std::vector& pathsOut) const { animationParameters.depANCS(pathsOut); actorParameters.depIDs(pathsOut); } void gatherScans(std::vector& scansOut) const { actorParameters.scanIDs(scansOut); } zeus::CAABox getVISIAABB(hecl::BlenderToken& btok) const { hecl::BlenderConnection& conn = btok.getBlenderConnection(); zeus::CAABox aabbOut; if (animationParameters.animationCharacterSet) { hecl::ProjectPath path = UniqueIDBridge::TranslatePakIdToPath( animationParameters.animationCharacterSet); conn.openBlend(path.getWithExtension(_S(".blend"), true)); hecl::BlenderConnection::DataStream ds = conn.beginData(); auto aabb = ds.getMeshAABB(); aabbOut = zeus::CAABox(aabb.first, aabb.second); } if (aabbOut.min.x > aabbOut.max.x) return {}; zeus::CTransform xf = ConvertEditorEulerToTransform4f(scale, orientation, location); return aabbOut.getTransformedAABox(xf); } }; } } #endif