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 17/01/2023.
Can you load a model and all it’s resources in a seperate class
data:image/s3,"s3://crabby-images/69f65/69f65655c300bc0948c316a891771b4857c13497" alt=""
GodMan
data:image/s3,"s3://crabby-images/69f65/69f65655c300bc0948c316a891771b4857c13497" 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/69f65/69f65655c300bc0948c316a891771b4857c13497" 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/ebd09/ebd09fc3bb3d01df8534f46f270c271f501cb56e" 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>();