|
|
@ -15,6 +15,7 @@ NpcAnimation::~NpcAnimation(){
|
|
|
|
NpcAnimation::NpcAnimation(const MWWorld::Ptr& ptr, MWWorld::Environment& _env,OEngine::Render::OgreRenderer& _rend, MWWorld::InventoryStore& _inv): Animation(_env,_rend), mStateID(-1), inv(_inv), timeToChange(0),
|
|
|
|
NpcAnimation::NpcAnimation(const MWWorld::Ptr& ptr, MWWorld::Environment& _env,OEngine::Render::OgreRenderer& _rend, MWWorld::InventoryStore& _inv): Animation(_env,_rend), mStateID(-1), inv(_inv), timeToChange(0),
|
|
|
|
robe(inv.getSlot(MWWorld::InventoryStore::Slot_Robe)), helmet(inv.getSlot(MWWorld::InventoryStore::Slot_Helmet)), shirt(inv.getSlot(MWWorld::InventoryStore::Slot_Shirt)),
|
|
|
|
robe(inv.getSlot(MWWorld::InventoryStore::Slot_Robe)), helmet(inv.getSlot(MWWorld::InventoryStore::Slot_Helmet)), shirt(inv.getSlot(MWWorld::InventoryStore::Slot_Shirt)),
|
|
|
|
cuirass(inv.getSlot(MWWorld::InventoryStore::Slot_Cuirass)), greaves(inv.getSlot(MWWorld::InventoryStore::Slot_Greaves)),
|
|
|
|
cuirass(inv.getSlot(MWWorld::InventoryStore::Slot_Cuirass)), greaves(inv.getSlot(MWWorld::InventoryStore::Slot_Greaves)),
|
|
|
|
|
|
|
|
leftpauldron(inv.getSlot(MWWorld::InventoryStore::Slot_LeftPauldron)), rightpauldron(inv.getSlot(MWWorld::InventoryStore::Slot_RightPauldron)),
|
|
|
|
lclavicle(0),
|
|
|
|
lclavicle(0),
|
|
|
|
rclavicle(0),
|
|
|
|
rclavicle(0),
|
|
|
|
rupperArm(0),
|
|
|
|
rupperArm(0),
|
|
|
@ -185,9 +186,20 @@ void NpcAnimation::updateParts(){
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(greaves != inv.getSlot(MWWorld::InventoryStore::Slot_Greaves)){
|
|
|
|
if(greaves != inv.getSlot(MWWorld::InventoryStore::Slot_Greaves)){
|
|
|
|
cuirass = inv.getSlot(MWWorld::InventoryStore::Slot_Greaves);
|
|
|
|
greaves = inv.getSlot(MWWorld::InventoryStore::Slot_Greaves);
|
|
|
|
removePartGroup(MWWorld::InventoryStore::Slot_Greaves);
|
|
|
|
removePartGroup(MWWorld::InventoryStore::Slot_Greaves);
|
|
|
|
apparelChanged = true;
|
|
|
|
apparelChanged = true;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(leftpauldron != inv.getSlot(MWWorld::InventoryStore::Slot_LeftPauldron)){
|
|
|
|
|
|
|
|
leftpauldron = inv.getSlot(MWWorld::InventoryStore::Slot_LeftPauldron);
|
|
|
|
|
|
|
|
removePartGroup(MWWorld::InventoryStore::Slot_LeftPauldron);
|
|
|
|
|
|
|
|
apparelChanged = true;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(rightpauldron != inv.getSlot(MWWorld::InventoryStore::Slot_RightPauldron)){
|
|
|
|
|
|
|
|
leftpauldron = inv.getSlot(MWWorld::InventoryStore::Slot_RightPauldron);
|
|
|
|
|
|
|
|
removePartGroup(MWWorld::InventoryStore::Slot_RightPauldron);
|
|
|
|
|
|
|
|
apparelChanged = true;
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(shirt != inv.getSlot(MWWorld::InventoryStore::Slot_Shirt)){
|
|
|
|
if(shirt != inv.getSlot(MWWorld::InventoryStore::Slot_Shirt)){
|
|
|
@ -225,6 +237,18 @@ void NpcAnimation::updateParts(){
|
|
|
|
std::vector<ESM::PartReference> parts = armor->parts.parts;
|
|
|
|
std::vector<ESM::PartReference> parts = armor->parts.parts;
|
|
|
|
addPartGroup(MWWorld::InventoryStore::Slot_Greaves, 3, parts);
|
|
|
|
addPartGroup(MWWorld::InventoryStore::Slot_Greaves, 3, parts);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(leftpauldron != inv.end()){
|
|
|
|
|
|
|
|
const ESM::Armor *armor = (leftpauldron->get<ESM::Armor>())->base;
|
|
|
|
|
|
|
|
std::vector<ESM::PartReference> parts = armor->parts.parts;
|
|
|
|
|
|
|
|
addPartGroup(MWWorld::InventoryStore::Slot_LeftPauldron, 3, parts);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(rightpauldron != inv.end()){
|
|
|
|
|
|
|
|
const ESM::Armor *armor = (rightpauldron->get<ESM::Armor>())->base;
|
|
|
|
|
|
|
|
std::vector<ESM::PartReference> parts = armor->parts.parts;
|
|
|
|
|
|
|
|
addPartGroup(MWWorld::InventoryStore::Slot_RightPauldron, 3, parts);
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(shirt != inv.end()){
|
|
|
|
if(shirt != inv.end()){
|
|
|
|
const ESM::Clothing *clothes = (shirt->get<ESM::Clothing>())->base;
|
|
|
|
const ESM::Clothing *clothes = (shirt->get<ESM::Clothing>())->base;
|
|
|
|