Please note, this blog entry is from a previous course. You might want to check out the current one.
Make this a two player game. There’s no need to go overboard here. Think of a simple UI and a straightforward implementation that make sense.
Create a new property to hold the separate scores of the players and another one to know the current player:
@property (strong, nonatomic) NSMutableArray *playerScores; // of NSNumber @property (nonatomic) int currentPlayer; ... - (NSMutableArray *)playerScores { if (!_playerScores) { _playerScores = [NSMutableArray arrayWithObjects:@0, @0, nil]; } return _playerScores; }
The score for the current player derives from the game score minus the score of the other player. When the score has decreased, the current player looses the turn …
- (void)calculateMultiPlayerScore { int otherPlayer = (self.currentPlayer + 1) % 2; int newScore = self.game.score - [self.playerScores[otherPlayer] intValue]; if (newScore < [self.playerScores[self.currentPlayer] intValue]) { self.playerScores[self.currentPlayer] = @(newScore); self.currentPlayer = otherPlayer; } else { self.playerScores[self.currentPlayer] = @(newScore); } }
It is calculated when a card has been flipped, or when cards have been added:
- (IBAction)flipCard:(UITapGestureRecognizer *)gesture { ... [self calculateMultiPlayerScore]; ... } - (IBAction)addCardsButtonPressed:(UIButton *)sender { if ([[self.game matchingCards] count]) { ... [self calculateMultiPlayerScore]; ... } }
The scores are displayed in the current score label, where the score of the current player is highlighted using attributed strings:
- (void)updateUI { ... NSString *text = [NSString stringWithFormat:@"P1: %@ P2: %@", self.playerScores[0], self.playerScores[1]]; NSMutableAttributedString *label = [[NSMutableAttributedString alloc] initWithString:text]; NSRange range = ]]; if (range.location != NSNotFound) { [label addAttributes:@{ NSStrokeWidthAttributeName : @-3, NSForegroundColorAttributeName : [UIColor blueColor] } range:range]; } self.scoreLabel.attributedText = label; self.resultOfLastFlipLabel.alpha = 1; self.resultOfLastFlipLabel.text = self.game.descriptionOfLastFlip; [self updateSliderRange]; }
… and the scores need to be reset when a new deck is dealt:
- (IBAction)dealButtonPressed:(UIButton *)sender { ... self.playerScores = nil; self.currentPlayer = 0; ... }
Finally you might need to adjust the size of the label and/or its content-hugging setting.
Because we should not go overboard … the game concept is a little bit flawed. There could be better ways to determine who is the current player … Also the high scores are still saved for the “complete” game and not for the individual player … but we did not want to go overboard 😉
The complete code is available on github.
data:image/s3,"s3://crabby-images/0463e/0463e68a5d77bbec630deb1cc37d4d49d1933e77" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/93960/93960774b56bccf62f288efe326475d585239d8b" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/0c920/0c920341ab12cbcb5a3b1d2fb88f22374f2db577" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/d89b8/d89b80500f1626baf2ffa1e4369c261e01677d36" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/e9270/e92707689a9d88fc53f343370506e7f2aaedb7d1" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/f159f/f159fb333858fef1148f2a558ee7fa6a6881800a" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/c7ab2/c7ab2f6c43fffe17aac7f185fd64ee95565487b9" alt="Share by email mail"
data:image/s3,"s3://crabby-images/6d85a/6d85a390df03e0c75624ac0579180ad35a62eeac" alt="Share on Facebook Facebook"
data:image/s3,"s3://crabby-images/e5f0c/e5f0cd4639d7b3d76b66c05981935f6c2bb06c71" alt="Share on Twitter twitter"
data:image/s3,"s3://crabby-images/40b77/40b7752481674a140035def4b6339fa4accc753f" alt="Share on Reddit reddit"
data:image/s3,"s3://crabby-images/1393f/1393f0291ffd80beac5e1f70b986671c6635d8b7" alt="Pin it with Pinterest pinterest"
data:image/s3,"s3://crabby-images/aa22d/aa22de91a0cd30772c623a5c7979ee81fe426013" alt="Share on Linkedin linkedin"
data:image/s3,"s3://crabby-images/5dc32/5dc32b39b30592e11870503bb4e8e715d50b21a0" alt="Share on tumblr tumblr"
data:image/s3,"s3://crabby-images/56655/56655b42634351b14f9d7507dacc4e33f64b90af" alt="Share by email mail"