|
|
@ -1630,23 +1630,25 @@ bool CharacterController::updateWeaponState(CharacterState& idle)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mPtr == getPlayer())
|
|
|
|
if(mPtr == getPlayer())
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isWeapon)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (Settings::Manager::getBool("best attack", "Game"))
|
|
|
|
if (Settings::Manager::getBool("best attack", "Game"))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isWeapon)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
MWWorld::ConstContainerStoreIterator weapon = mPtr.getClass().getInventoryStore(mPtr).getSlot(MWWorld::InventoryStore::Slot_CarriedRight);
|
|
|
|
MWWorld::ConstContainerStoreIterator weapon = mPtr.getClass().getInventoryStore(mPtr).getSlot(MWWorld::InventoryStore::Slot_CarriedRight);
|
|
|
|
mAttackType = getBestAttack(weapon->get<ESM::Weapon>()->mBase);
|
|
|
|
mAttackType = getBestAttack(weapon->get<ESM::Weapon>()->mBase);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
|
|
|
|
setAttackTypeBasedOnMovement();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
// There is no "best attack" for Hand-to-Hand
|
|
|
|
// There is no "best attack" for Hand-to-Hand
|
|
|
|
setAttackTypeRandomly(mAttackType);
|
|
|
|
setAttackTypeRandomly(mAttackType);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
setAttackTypeBasedOnMovement();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
// else if (mPtr != getPlayer()) use mAttackType set by AiCombat
|
|
|
|
// else if (mPtr != getPlayer()) use mAttackType set by AiCombat
|
|
|
|
startKey = mAttackType+" start";
|
|
|
|
startKey = mAttackType+" start";
|
|
|
|
stopKey = mAttackType+" min attack";
|
|
|
|
stopKey = mAttackType+" min attack";
|
|
|
|