|
|
@ -1311,10 +1311,10 @@ bool CharacterController::updateWeaponState()
|
|
|
|
mWeaponType == WeapType_Thrown)
|
|
|
|
mWeaponType == WeapType_Thrown)
|
|
|
|
mAttackType = "shoot";
|
|
|
|
mAttackType = "shoot";
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isWeapon)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if(mPtr == getPlayer())
|
|
|
|
if(mPtr == getPlayer())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (isWeapon)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (Settings::Manager::getBool("best attack", "Game"))
|
|
|
|
if (Settings::Manager::getBool("best attack", "Game"))
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1324,10 +1324,10 @@ bool CharacterController::updateWeaponState()
|
|
|
|
else
|
|
|
|
else
|
|
|
|
setAttackTypeBasedOnMovement();
|
|
|
|
setAttackTypeBasedOnMovement();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// else if (mPtr != getPlayer()) use mAttackType already set by AiCombat
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
setAttackTypeRandomly();
|
|
|
|
setAttackTypeRandomly(mAttackType);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// else if (mPtr != getPlayer()) use mAttackType set by AiCombat
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mAnimation->play(mCurrentWeapon, priorityWeapon,
|
|
|
|
mAnimation->play(mCurrentWeapon, priorityWeapon,
|
|
|
@ -2188,17 +2188,6 @@ void CharacterController::updateMagicEffects()
|
|
|
|
mAnimation->setLightEffect(light);
|
|
|
|
mAnimation->setLightEffect(light);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CharacterController::setAttackTypeRandomly()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
float random = Misc::Rng::rollProbability();
|
|
|
|
|
|
|
|
if (random >= 2/3.f)
|
|
|
|
|
|
|
|
mAttackType = "thrust";
|
|
|
|
|
|
|
|
else if (random >= 1/3.f)
|
|
|
|
|
|
|
|
mAttackType = "slash";
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
mAttackType = "chop";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CharacterController::setAttackTypeBasedOnMovement()
|
|
|
|
void CharacterController::setAttackTypeBasedOnMovement()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
float *move = mPtr.getClass().getMovementSettings(mPtr).mPosition;
|
|
|
|
float *move = mPtr.getClass().getMovementSettings(mPtr).mPosition;
|
|
|
@ -2240,6 +2229,17 @@ void CharacterController::setAIAttackType(std::string attackType)
|
|
|
|
mAttackType = attackType;
|
|
|
|
mAttackType = attackType;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CharacterController::setAttackTypeRandomly(std::string& attackType)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
float random = Misc::Rng::rollProbability();
|
|
|
|
|
|
|
|
if (random >= 2/3.f)
|
|
|
|
|
|
|
|
attackType = "thrust";
|
|
|
|
|
|
|
|
else if (random >= 1/3.f)
|
|
|
|
|
|
|
|
attackType = "slash";
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
attackType = "chop";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool CharacterController::readyToPrepareAttack() const
|
|
|
|
bool CharacterController::readyToPrepareAttack() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return (mHitState == CharState_None || mHitState == CharState_Block)
|
|
|
|
return (mHitState == CharState_None || mHitState == CharState_Block)
|
|
|
|