1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-27 03:35:27 +00:00

corrected things connected to determining attack type

This commit is contained in:
mrcheko 2014-01-26 23:32:57 +02:00
parent 87e83a92f8
commit 45b3aa3d93
4 changed files with 31 additions and 55 deletions

View File

@ -163,9 +163,7 @@ namespace MWMechanics
float rangeMelee; float rangeMelee;
float rangeCloseUp; float rangeCloseUp;
bool distantCombat = false; bool distantCombat = false;
int attackType = actor.getClass().getCreatureStats(actor).getAttackType(); if (weaptype==WeapType_BowAndArrow || weaptype==WeapType_Crossbow || weaptype==WeapType_ThowWeapon)
if (weaptype==WeapType_BowAndArrow || weaptype==WeapType_Crossbow || weaptype==WeapType_ThowWeapon
|| attackType==MWMechanics::CreatureStats::AT_Target )
{ {
rangeMelee = 1000; // TODO: should depend on archer skill rangeMelee = 1000; // TODO: should depend on archer skill
rangeCloseUp = 0; //doesn't needed when attacking from distance rangeCloseUp = 0; //doesn't needed when attacking from distance

View File

@ -644,7 +644,12 @@ bool CharacterController::updateNpcState()
mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Left Hand", effect->mParticle); mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Left Hand", effect->mParticle);
mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Right Hand", effect->mParticle); mAnimation->addEffect("meshes\\" + castStatic->mModel, -1, false, "Right Hand", effect->mParticle);
determineAttackType(effectentry.mRange); switch(effectentry.mRange)
{
case 0: mAttackType = "self"; break;
case 1: mAttackType = "touch"; break;
case 2: mAttackType = "target"; break;
}
mAnimation->play(mCurrentWeapon, Priority_Weapon, mAnimation->play(mCurrentWeapon, Priority_Weapon,
MWRender::Animation::Group_UpperBody, true, MWRender::Animation::Group_UpperBody, true,
@ -698,7 +703,7 @@ bool CharacterController::updateNpcState()
mAttackType = "shoot"; mAttackType = "shoot";
else else
{ {
int attackType = stats.getAttackType(); int attackType;
if(isWeapon && Settings::Manager::getBool("best attack", "Game")) if(isWeapon && Settings::Manager::getBool("best attack", "Game"))
attackType = getBestAttack(weapon->get<ESM::Weapon>()->mBase); attackType = getBestAttack(weapon->get<ESM::Weapon>()->mBase);
else else
@ -1302,57 +1307,34 @@ void CharacterController::updateVisibility()
mAnimation->setAlpha(alpha); mAnimation->setAlpha(alpha);
} }
void CharacterController::determineAttackType(int spellRange) void CharacterController::determineAttackType()
{ {
if(spellRange == -1) float * move = mPtr.getClass().getMovementSettings(mPtr).mPosition;
if (move[0] && !move[1]) //sideway
{ {
float * move = mPtr.getClass().getMovementSettings(mPtr).mPosition; mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Slash);
if(mPtr.getClass().isNpc())
if (move[0] && !move[1]) //sideway mAttackType = "slash";
{
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Slash);
if(mPtr.getClass().isNpc())
mAttackType = "slash";
else
mCurrentWeapon = "attack2";
}
else if (move[1]) //forward
{
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Thrust);
if(mPtr.getClass().isNpc())
mAttackType = "thrust";
else
mCurrentWeapon = "attack3";
}
else else
{ mCurrentWeapon = "attack2";
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Chop); }
if(mPtr.getClass().isNpc()) else if (move[1]) //forward
mAttackType = "chop"; {
else mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Thrust);
mCurrentWeapon = "attack1"; if(mPtr.getClass().isNpc())
} mAttackType = "thrust";
else
mCurrentWeapon = "attack3";
} }
else else
{ {
switch(spellRange) mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Chop);
{ if(mPtr.getClass().isNpc())
case 0: mAttackType = "chop";
mAttackType = "self"; else
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Self); mCurrentWeapon = "attack1";
break;
case 1:
mAttackType = "touch";
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Touch);
break;
case 2:
mAttackType = "target";
mPtr.getClass().getCreatureStats(mPtr).setAttackType(MWMechanics::CreatureStats::AT_Target);
break;
}
} }
} }
} }

View File

@ -165,7 +165,7 @@ class CharacterController
float mSecondsOfRunning; float mSecondsOfRunning;
std::string mAttackType; // slash, chop or thrust std::string mAttackType; // slash, chop or thrust
void determineAttackType(int spellRange = -1); void determineAttackType();
void refreshCurrentAnims(CharacterState idle, CharacterState movement, bool force=false); void refreshCurrentAnims(CharacterState idle, CharacterState movement, bool force=false);

View File

@ -118,11 +118,7 @@ namespace MWMechanics
{ {
AT_Chop, AT_Chop,
AT_Slash, AT_Slash,
AT_Thrust, AT_Thrust
AT_Self,
AT_Touch,
AT_Target,
}; };
void setAttackType(int attackType) { mAttackType = attackType; } void setAttackType(int attackType) { mAttackType = attackType; }
int getAttackType() { return mAttackType; } int getAttackType() { return mAttackType; }