mirror of
https://github.com/mod-playerbots/mod-playerbots
synced 2025-11-29 15:58:20 +08:00
Rogue stealth spell & Target selection for combo class
This commit is contained in:
@@ -34,9 +34,7 @@ AssassinationRogueStrategy::AssassinationRogueStrategy(PlayerbotAI* ai) : MeleeC
|
||||
|
||||
NextAction** AssassinationRogueStrategy::getDefaultActions()
|
||||
{
|
||||
return NextAction::array(0,
|
||||
new NextAction("garrote", ACTION_DEFAULT + 0.2f),
|
||||
new NextAction("ambush", ACTION_DEFAULT + 0.1f),
|
||||
return NextAction::array(0,
|
||||
new NextAction("melee", ACTION_DEFAULT),
|
||||
NULL);
|
||||
}
|
||||
@@ -44,6 +42,12 @@ NextAction** AssassinationRogueStrategy::getDefaultActions()
|
||||
void AssassinationRogueStrategy::InitTriggers(std::vector<TriggerNode*> &triggers)
|
||||
{
|
||||
MeleeCombatStrategy::InitTriggers(triggers);
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"high energy available",
|
||||
NextAction::array(0,
|
||||
new NextAction("garrote", ACTION_HIGH + 0.3f),
|
||||
new NextAction("ambush", ACTION_HIGH + 0.2f), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"high energy available",
|
||||
|
||||
@@ -23,51 +23,51 @@ class DpsRogueStrategyActionNodeFactory : public NamedObjectFactory<ActionNode>
|
||||
static ActionNode* melee(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("melee",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("mutilate"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("mutilate"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* mutilate(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("mutilate",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("sinister strike"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("sinister strike"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* sinister_strike(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("sinister strike",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("melee"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("melee"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* kick(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("kick",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("kidney shot"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("kidney shot"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* kidney_shot(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("kidney shot",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NULL,
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ nullptr,
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* backstab(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("backstab",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("mutilate"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("mutilate"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
static ActionNode* rupture(PlayerbotAI* botAI)
|
||||
{
|
||||
return new ActionNode ("rupture",
|
||||
/*P*/ NULL,
|
||||
/*A*/ NextAction::array(0, new NextAction("eviscerate"), NULL),
|
||||
/*C*/ NULL);
|
||||
/*P*/ nullptr,
|
||||
/*A*/ NextAction::array(0, new NextAction("eviscerate"), nullptr),
|
||||
/*C*/ nullptr);
|
||||
}
|
||||
|
||||
};
|
||||
@@ -79,11 +79,9 @@ DpsRogueStrategy::DpsRogueStrategy(PlayerbotAI* botAI) : MeleeCombatStrategy(bot
|
||||
|
||||
NextAction** DpsRogueStrategy::getDefaultActions()
|
||||
{
|
||||
return NextAction::array(0,
|
||||
new NextAction("garrote", ACTION_DEFAULT + 0.3f),
|
||||
new NextAction("ambush", ACTION_DEFAULT + 0.2f),
|
||||
return NextAction::array(0,
|
||||
new NextAction("killing spree", ACTION_DEFAULT + 0.1f),
|
||||
new NextAction("melee", ACTION_DEFAULT), NULL);
|
||||
new NextAction("melee", ACTION_DEFAULT), nullptr);
|
||||
}
|
||||
|
||||
void DpsRogueStrategy::InitTriggers(std::vector<TriggerNode*>& triggers)
|
||||
@@ -92,45 +90,51 @@ void DpsRogueStrategy::InitTriggers(std::vector<TriggerNode*>& triggers)
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"high energy available",
|
||||
NextAction::array(0, new NextAction("sinister strike", ACTION_NORMAL + 3), NULL)));
|
||||
NextAction::array(0,
|
||||
new NextAction("garrote", ACTION_HIGH + 0.3f),
|
||||
new NextAction("ambush", ACTION_HIGH + 0.2f), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"high energy available",
|
||||
NextAction::array(0, new NextAction("sinister strike", ACTION_NORMAL + 3), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"slice and dice",
|
||||
NextAction::array(0, new NextAction("slice and dice", ACTION_HIGH + 2), NULL)));
|
||||
NextAction::array(0, new NextAction("slice and dice", ACTION_HIGH + 2), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"combo points available",
|
||||
NextAction::array(0,
|
||||
new NextAction("rupture", ACTION_HIGH + 1), NULL)));
|
||||
new NextAction("rupture", ACTION_HIGH + 1), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"target with combo points almost dead",
|
||||
NextAction::array(0,
|
||||
new NextAction("eviscerate", ACTION_HIGH + 1), NULL)));
|
||||
new NextAction("eviscerate", ACTION_HIGH + 1), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"medium threat",
|
||||
NextAction::array(0, new NextAction("vanish", ACTION_HIGH), NULL)));
|
||||
NextAction::array(0, new NextAction("vanish", ACTION_HIGH), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"low health",
|
||||
NextAction::array(0, new NextAction("evasion", ACTION_EMERGENCY), new NextAction("feint", ACTION_EMERGENCY), NULL)));
|
||||
NextAction::array(0, new NextAction("evasion", ACTION_EMERGENCY), new NextAction("feint", ACTION_EMERGENCY), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"kick",
|
||||
NextAction::array(0, new NextAction("kick", ACTION_INTERRUPT + 2), NULL)));
|
||||
NextAction::array(0, new NextAction("kick", ACTION_INTERRUPT + 2), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"kick on enemy healer",
|
||||
NextAction::array(0, new NextAction("kick on enemy healer", ACTION_INTERRUPT + 1), NULL)));
|
||||
NextAction::array(0, new NextAction("kick on enemy healer", ACTION_INTERRUPT + 1), nullptr)));
|
||||
|
||||
// triggers.push_back(new TriggerNode(
|
||||
// "behind target",
|
||||
// NextAction::array(0, new NextAction("backstab", ACTION_NORMAL), NULL)));
|
||||
// NextAction::array(0, new NextAction("backstab", ACTION_NORMAL), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"light aoe",
|
||||
NextAction::array(0, new NextAction("blade flurry", ACTION_HIGH + 3), NULL)));
|
||||
NextAction::array(0, new NextAction("blade flurry", ACTION_HIGH + 3), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"enemy out of melee",
|
||||
@@ -138,15 +142,15 @@ void DpsRogueStrategy::InitTriggers(std::vector<TriggerNode*>& triggers)
|
||||
new NextAction("stealth", ACTION_NORMAL + 9),
|
||||
new NextAction("sprint", ACTION_NORMAL + 8),
|
||||
new NextAction("reach melee", ACTION_NORMAL + 7),
|
||||
NULL)));
|
||||
nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"expose armor",
|
||||
NextAction::array(0, new NextAction("expose armor", ACTION_HIGH + 3), NULL)));
|
||||
NextAction::array(0, new NextAction("expose armor", ACTION_HIGH + 3), nullptr)));
|
||||
|
||||
triggers.push_back(new TriggerNode(
|
||||
"tricks of the trade on main tank",
|
||||
NextAction::array(0, new NextAction("tricks of the trade on main tank", ACTION_HIGH + 7), NULL)));
|
||||
NextAction::array(0, new NextAction("tricks of the trade on main tank", ACTION_HIGH + 7), nullptr)));
|
||||
}
|
||||
|
||||
class StealthedRogueStrategyActionNodeFactory : public NamedObjectFactory<ActionNode>
|
||||
@@ -239,7 +243,7 @@ void RogueAoeStrategy::InitTriggers(std::vector<TriggerNode*>& triggers)
|
||||
triggers.push_back(new TriggerNode("light aoe", NextAction::array(0, new NextAction("blade flurry", ACTION_HIGH), nullptr)));
|
||||
triggers.push_back(new TriggerNode(
|
||||
"medium aoe",
|
||||
NextAction::array(0, new NextAction("fan of knives", ACTION_NORMAL + 5), NULL)));
|
||||
NextAction::array(0, new NextAction("fan of knives", ACTION_NORMAL + 5), nullptr)));
|
||||
}
|
||||
|
||||
void RogueBoostStrategy::InitTriggers(std::vector<TriggerNode*>& triggers)
|
||||
|
||||
Reference in New Issue
Block a user