taught AI basic attack and block cost.
added functionality to send specific abilities to AI "selectAbility" to have it find mana, targets, and use a selected ability at our command.
This commit is contained in:
@@ -1369,7 +1369,7 @@ int AIPlayerBaka::selectHintAbility()
|
||||
return 0;
|
||||
}
|
||||
|
||||
int AIPlayerBaka::selectAbility()
|
||||
int AIPlayerBaka::selectAbility(MTGAbility * Specific)
|
||||
{
|
||||
if(observer->mExtraPayment && observer->mExtraPayment->source && observer->mExtraPayment->source->controller() == this)
|
||||
{
|
||||
@@ -1410,12 +1410,14 @@ int AIPlayerBaka::selectAbility()
|
||||
for (size_t i = 1; i < observer->mLayers->actionLayer()->mObjects.size(); i++)
|
||||
{ //0 is not a mtgability...hackish
|
||||
MTGAbility * a = ((MTGAbility *) observer->mLayers->actionLayer()->mObjects[i]);
|
||||
if (Specific && Specific != a)
|
||||
continue;
|
||||
//Skip mana abilities for performance
|
||||
if (dynamic_cast<AManaProducer*> (a))
|
||||
continue;
|
||||
//Make sure we can use the ability
|
||||
for (int j = 0; j < game->inPlay->nb_cards; j++)
|
||||
{
|
||||
{//zeth fox: note to self, this is where I can teach it suspend and other cost types.
|
||||
MTGCardInstance * card = game->inPlay->cards[j];
|
||||
if(a->getCost() && !a->isReactingToClick(card, totalPotentialMana))//for performance reason only look for specific mana if the payment couldnt be made with potential.
|
||||
{
|
||||
@@ -1444,7 +1446,32 @@ int AIPlayerBaka::selectAbility()
|
||||
ManaCost * pMana = getPotentialMana(card);
|
||||
pMana->add(this->getManaPool());
|
||||
if (a->isReactingToClick(card, pMana))
|
||||
{
|
||||
createAbilityTargets(a, card, ranking);
|
||||
if (Specific)
|
||||
{
|
||||
if (!Specific->getCost())
|
||||
{
|
||||
//attackcost, blockcost
|
||||
if (a->aType == MTGAbility::ATTACK_COST)
|
||||
{
|
||||
ManaCost * specificCost = NEW ManaCost(ManaCost::parseManaCost("{0}", NULL, NULL));
|
||||
specificCost->add(0, card->attackCostBackup);
|
||||
abilityPayment = canPayMana(card, specificCost);
|
||||
SAFE_DELETE(specificCost);
|
||||
}
|
||||
else if (a->aType == MTGAbility::BLOCK_COST)
|
||||
{
|
||||
ManaCost * specificCost = NEW ManaCost(ManaCost::parseManaCost("{0}", NULL, NULL));
|
||||
specificCost->add(0, card->blockCostBackup);
|
||||
abilityPayment = canPayMana(card, specificCost);
|
||||
SAFE_DELETE(specificCost);
|
||||
}
|
||||
}
|
||||
delete (pMana);
|
||||
break;
|
||||
}
|
||||
}
|
||||
delete (pMana);
|
||||
}
|
||||
}
|
||||
@@ -1458,6 +1485,8 @@ int AIPlayerBaka::selectAbility()
|
||||
if (!forceBestAbilityUse)
|
||||
chance = 1 + randomGenerator.random() % 100;
|
||||
int actionScore = action.getEfficiency();
|
||||
if (Specific)
|
||||
actionScore = 95;
|
||||
if(action.ability->getCost() && action.ability->getCost()->hasX() && this->game->hand->cards.size())
|
||||
actionScore = actionScore/int(this->game->hand->cards.size());//reduce chance for "x" abilities if cards are in hand.
|
||||
if (actionScore >= chance)
|
||||
@@ -1469,6 +1498,35 @@ int AIPlayerBaka::selectAbility()
|
||||
DebugTrace(" Ai knows exactly what mana to use for this ability.");
|
||||
}
|
||||
DebugTrace("AIPlayer:Using Activated ability");
|
||||
if (Specific)
|
||||
{
|
||||
if (!Specific->getCost())
|
||||
{
|
||||
//attackcost, blockcost
|
||||
if (action.ability->aType == MTGAbility::ATTACK_COST)
|
||||
{
|
||||
ManaCost * specificCost = NEW ManaCost(ManaCost::parseManaCost("{0}", NULL, NULL));
|
||||
specificCost->add(0, action.click->attackCostBackup);
|
||||
if (payTheManaCost(specificCost, action.click, abilityPayment))
|
||||
clickstream.push(NEW AIAction(action));
|
||||
SAFE_DELETE(specificCost);
|
||||
}
|
||||
else if (action.ability->aType == MTGAbility::BLOCK_COST)
|
||||
{
|
||||
ManaCost * specificCost = NEW ManaCost(ManaCost::parseManaCost("{0}", NULL, NULL));
|
||||
specificCost->add(0, action.click->blockCostBackup);
|
||||
if (payTheManaCost(specificCost, action.click, abilityPayment))
|
||||
clickstream.push(NEW AIAction(action));
|
||||
SAFE_DELETE(specificCost);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
if (payTheManaCost(action.ability->getCost(), action.click, abilityPayment))
|
||||
clickstream.push(NEW AIAction(action));
|
||||
}
|
||||
}
|
||||
else
|
||||
if (payTheManaCost(action.ability->getCost(), action.click,abilityPayment))
|
||||
clickstream.push(NEW AIAction(action));
|
||||
}
|
||||
@@ -2624,8 +2682,19 @@ int AIPlayerBaka::chooseAttackers()
|
||||
MTGCardInstance * card = NULL;
|
||||
while ((card = cd.nextmatch(game->inPlay, card)))
|
||||
{
|
||||
if(hints && hints->HintSaysAlwaysAttack(observer,card))
|
||||
observer->cardClick(card, MTGAbility::MTG_ATTACK_RULE);
|
||||
if (hints && hints->HintSaysAlwaysAttack(observer, card))
|
||||
{
|
||||
if (!card->isAttacker())
|
||||
{
|
||||
if (card->attackCost)
|
||||
{
|
||||
MTGAbility * a = observer->mLayers->actionLayer()->getAbility(MTGAbility::ATTACK_COST);
|
||||
selectAbility(a);
|
||||
observer->cardClick(card, MTGAbility::ATTACK_COST);
|
||||
}
|
||||
}
|
||||
observer->cardClick(card, MTGAbility::MTG_ATTACK_RULE);
|
||||
}
|
||||
}
|
||||
|
||||
if (attack)
|
||||
@@ -2638,8 +2707,16 @@ int AIPlayerBaka::chooseAttackers()
|
||||
{
|
||||
if(hints && hints->HintSaysDontAttack(observer,card))
|
||||
continue;
|
||||
if(!card->isAttacker())
|
||||
if (!card->isAttacker())
|
||||
{
|
||||
if (card->attackCost)
|
||||
{
|
||||
MTGAbility * a = observer->mLayers->actionLayer()->getAbility(MTGAbility::ATTACK_COST);
|
||||
selectAbility(a);
|
||||
observer->cardClick(card, MTGAbility::ATTACK_COST);
|
||||
}
|
||||
observer->cardClick(card, MTGAbility::MTG_ATTACK_RULE);
|
||||
}
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
@@ -2716,6 +2793,12 @@ int AIPlayerBaka::chooseBlockers()
|
||||
}
|
||||
else
|
||||
{
|
||||
if (card->blockCost)
|
||||
{
|
||||
MTGAbility * a = observer->mLayers->actionLayer()->getAbility(MTGAbility::BLOCK_COST);
|
||||
selectAbility(a);
|
||||
observer->cardClick(card, MTGAbility::BLOCK_COST);
|
||||
}
|
||||
observer->cardClick(card, MTGAbility::MTG_BLOCK_RULE);
|
||||
}
|
||||
}
|
||||
@@ -2746,6 +2829,11 @@ int AIPlayerBaka::chooseBlockers()
|
||||
continue;
|
||||
if (!card->defenser)
|
||||
{
|
||||
if (card->blockCost)
|
||||
{
|
||||
MTGAbility * a = observer->mLayers->actionLayer()->getAbility(MTGAbility::BLOCK_COST);
|
||||
selectAbility(a);
|
||||
}
|
||||
observer->cardClick(card, MTGAbility::MTG_BLOCK_RULE);
|
||||
int set = 0;
|
||||
while (!set)
|
||||
@@ -2760,6 +2848,11 @@ int AIPlayerBaka::chooseBlockers()
|
||||
if (opponentsToughness[attacker] <= 0 || (card->toughness <= attacker->power && opponentForce * 2 < life
|
||||
&& !canFirstStrikeKill(card, attacker)) || attacker->nbOpponents() > 1)
|
||||
{
|
||||
if (card->blockCost)
|
||||
{
|
||||
MTGAbility * a = observer->mLayers->actionLayer()->getAbility(MTGAbility::BLOCK_COST);
|
||||
selectAbility(a);
|
||||
}
|
||||
observer->cardClick(card, MTGAbility::MTG_BLOCK_RULE);
|
||||
}
|
||||
else
|
||||
|
||||
Reference in New Issue
Block a user