2018-10-06 20:42:33 -07:00
|
|
|
#pragma once
|
2015-09-10 13:30:35 -07:00
|
|
|
|
|
|
|
#include "../../DNACommon/DNACommon.hpp"
|
|
|
|
#include "IScriptObject.hpp"
|
|
|
|
#include "Parameters.hpp"
|
|
|
|
|
2018-12-07 21:30:43 -08:00
|
|
|
namespace DataSpec::DNAMP1 {
|
|
|
|
struct VisorGoo : IScriptObject {
|
2019-08-10 17:49:41 -07:00
|
|
|
AT_DECL_DNA_YAMLV
|
2018-12-07 21:30:43 -08:00
|
|
|
String<-1> name;
|
|
|
|
Value<atVec3f> position;
|
|
|
|
UniqueID32 particle;
|
|
|
|
UniqueID32 electric;
|
|
|
|
Value<float> minDist;
|
|
|
|
Value<float> maxDist;
|
|
|
|
Value<float> nearProb;
|
|
|
|
Value<float> farProb;
|
|
|
|
DNAColor color;
|
|
|
|
Value<atUint32> sfx;
|
|
|
|
Value<bool> skipAngleTest;
|
2015-10-26 17:19:03 -07:00
|
|
|
|
2019-08-09 19:32:48 -07:00
|
|
|
void nameIDs(PAKRouter<PAKBridge>& pakRouter) const override {
|
2019-07-19 21:27:21 -07:00
|
|
|
if (particle.isValid()) {
|
2018-12-07 21:30:43 -08:00
|
|
|
PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(particle);
|
|
|
|
ent->name = name + "_part";
|
2015-10-26 17:19:03 -07:00
|
|
|
}
|
2019-07-19 21:27:21 -07:00
|
|
|
if (electric.isValid()) {
|
2018-12-07 21:30:43 -08:00
|
|
|
PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(electric);
|
|
|
|
ent->name = name + "_elsc";
|
2016-10-02 15:41:36 -07:00
|
|
|
}
|
2018-12-07 21:30:43 -08:00
|
|
|
}
|
2015-09-10 13:30:35 -07:00
|
|
|
|
2019-08-09 19:32:48 -07:00
|
|
|
void gatherDependencies(std::vector<hecl::ProjectPath>& pathsOut,
|
|
|
|
std::vector<hecl::ProjectPath>& lazyOut) const override {
|
2018-12-07 21:30:43 -08:00
|
|
|
g_curSpec->flattenDependencies(particle, pathsOut);
|
|
|
|
g_curSpec->flattenDependencies(electric, pathsOut);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
} // namespace DataSpec::DNAMP1
|