I have some templates that are for different NPCs, for example I have a AI_Melee class that I’m trying to load the character model and setup it’s animation controller all in that class. That way I don’t have so much of it in my main program. Is this bad practice?
Archive 19/01/2023.
Can you load a model and all it’s resources in a seperate class
data:image/s3,"s3://crabby-images/7249b/7249b19f133d64005fd4456b5ff607db3d9c722a" alt=""
GodMan
data:image/s3,"s3://crabby-images/1bc43/1bc4383d13c0dc0f0c3098894833c0a7defc49c4" alt=""
SirNate0
That’s the approach I took. I went as far as separating a resource and a component class for some of the character types. I’ll let others comment on whether it’s a good practice.
data:image/s3,"s3://crabby-images/7249b/7249b19f133d64005fd4456b5ff607db3d9c722a" alt=""
GodMan
It just seems easier and cleaner approach. I have not seen a class where someone loaded the actual 3d model and applied it to the node, but I’ve seen some classes where they actually loaded basically everything else.
data:image/s3,"s3://crabby-images/089c1/089c1d0b03fea470b6cee51cbcacdca8f43792f6" alt=""
jmiller
It seems natural enough to take an approach with different classes. Just for reference, I have prototyped with a single Player Component with types differentiated by prefabs containing everything asset-related: nodes and transforms, AnimatedModel (sometimes pasted from editor), physics components, materials…
Player::OnNodeSet(Node* node) {
if (node == nullptr) { return; }
node_->LoadXML(node_->GetVar("template").GetString());
// Subscribe to some events, cache some pointers, create more stuff.. Ninja.as for more
}
playerNode->SetVar("template", "Players/Urho.xml");
playerNode->CreateComponent<Player>();