private void ReRollEvents() { int cEventsToInclude = 0; int cEventRemaining = 20; int totalKingdomCount = Dominion.Cards.AllKingdomCards().Count(); for (int i = 0; i < 10; ++i) { int roll = MainPage.random.Next(totalKingdomCount); if (roll <= cEventRemaining) { cEventsToInclude++; cEventRemaining--; i--; continue; } totalKingdomCount--; } var allEventsCards = Dominion.Cards.AllCards().Where(c => c.isEvent).Select(c => DominionCard.Create(c)).ToArray(); var selectedItems = this.EventCardsListView.SelectedItems.Select(item => (DominionCard)item).ToArray <DominionCard>(); var cardPicker = new UniqueCardPicker(allEventsCards.Select(c => c.dominionCard)); DominionCard baneCard = null; this.appDataContext.EventCards.Clear(); this.appDataContext.EventCards.GenerateRandom(cEventsToInclude, ref baneCard, allEventsCards, itemsToReplace: selectedItems); }
public CardConstraintMatcher( bool requirePlusBuy, bool requireVillage, bool requirePlusCard, bool requireTrashing, bool requireAttack, bool requireReactionWhenAttack, bool requireAtLeast3FromAnExpansion, Dominion.Card[] requiredCards, Dominion.Card[] restrictedCards, Dominion.Card[] startingCards, IEnumerable <Dominion.Card> allCards ) { this.requirePlusBuy = requirePlusBuy; this.requireVillage = requireVillage; this.requirePlusCard = requirePlusCard; this.requireTrashing = requireTrashing; this.requireAttack = requireAttack; this.requireReactionWhenAttack = requireReactionWhenAttack; this.requireAtLeast3FromAnExpansion = requireAtLeast3FromAnExpansion; this.RequiredCards = requiredCards; this.RestrictedCards = restrictedCards; this.enabledExpansions = new List <Dominion.Expansion>(); this.currentCards = new List <Dominion.Card>(); this.missingRequiredCards = new List <Dominion.Card>(); this.uniqueCardPicker = new UniqueCardPicker(allCards); this.uniqueCardPicker.ExcludeCards(requiredCards); this.uniqueCardPicker.ExcludeCards(restrictedCards); this.uniqueCardPicker.ExcludeCards(startingCards); foreach (var card in startingCards) { this.currentCards.Add(card); } foreach (var card in requiredCards) { if (!this.currentCards.Contains(card)) { this.missingRequiredCards.Add(card); } } }
internal static void Generate10Random(IList <DominionCard> resultList, IList <DominionCard> sourceList, IList <DominionCard> allCards, IList <DominionCard> itemsToReplace) { bool isReplacingItems = itemsToReplace != null && itemsToReplace.Count > 0 && sourceList.Count <= 10; bool isReducingItems = itemsToReplace != null && itemsToReplace.Count > 0 && sourceList.Count > 10; var cardPicker = new UniqueCardPicker(allCards); if (isReplacingItems) { cardPicker.ExcludeCards(itemsToReplace); if (itemsToReplace != null) { foreach (DominionCard cardToReplace in itemsToReplace) { for (int i = 0; i < resultList.Count; ++i) { if (resultList[i] == cardToReplace) { var nextCard = cardPicker.GetCard(c => true); if (nextCard == null) { resultList.Remove(cardToReplace); i--; // do this index again } else { resultList[i] = nextCard; } } } } } } else if (sourceList.Count < 10) { var listRemoved = new List <DominionCard>(); foreach (var card in resultList) { if (!sourceList.Contains(card)) { listRemoved.Add(card); } } foreach (var card in listRemoved) { resultList.Remove(card); } } else if (isReducingItems) { foreach (var card in itemsToReplace) { resultList.Remove(card); } } else { resultList.Clear(); } while (resultList.Count < 10) { DominionCard currentCard = cardPicker.GetCard(c => true); if (currentCard == null) { break; } resultList.Add(currentCard); } }
internal static bool GenerateRandom( int targetCount, ref DominionCard baneCard, IList <DominionCard> resultList, IList <DominionCard> sourceList, IEnumerable <DominionCard> allCards, IEnumerable <DominionCard> itemsToReplace) { bool isReplacingItems = itemsToReplace != null && itemsToReplace.Any() && sourceList.Count <= targetCount; bool isReducingItems = itemsToReplace != null && itemsToReplace.Any() && sourceList.Count > targetCount; var cardPicker = new UniqueCardPicker(allCards.Select(c => c.dominionCard)); bool isCleanRoll = false; if (isReplacingItems) { cardPicker.ExcludeCards(itemsToReplace.Select(c => c.dominionCard)); } baneCard = DominionCard.Create(cardPicker.GetCard(c => c.DefaultCoinCost == 2 || c.DefaultCoinCost == 3)); if (isReplacingItems) { foreach (DominionCard cardToReplace in itemsToReplace) { for (int i = 0; i < resultList.Count; ++i) { if (resultList[i] == cardToReplace) { var nextCard = cardPicker.GetCard(c => true); if (nextCard == null) { resultList.Remove(cardToReplace); i--; // do this index again } else { resultList[i] = DominionCard.Create(nextCard); } } } } } else if (sourceList.Count < targetCount && sourceList.Count > 0) { var listRemoved = new List <DominionCard>(); foreach (var card in resultList) { if (!sourceList.Contains(card)) { listRemoved.Add(card); } } foreach (var card in listRemoved) { resultList.Remove(card); } } else if (isReducingItems) { foreach (var card in itemsToReplace) { resultList.Remove(card); } } else { resultList.Clear(); isCleanRoll = true; } while (resultList.Count < targetCount) { Dominion.Card currentCard = cardPicker.GetCard(c => true); if (currentCard == null) { break; } resultList.Add(DominionCard.Create(currentCard)); } return(isCleanRoll); }