Please note, this blog entry is from a previous course. You might want to check out the current one.
Lecture #2 provides a short walk through of the Xcode developing environment. The first half of the lecture discusses the various classes of the model for the playing card game. The second is a life demonstration on how to start a project in Xcodes, placing buttons and labels in Storyboard and connecting them to the view controller.
At the end of the lecture the app called Matchismo displays a playing card and allows to flip it to show both sides of the card.
Assignment #0 is to follow the steps from the demonstration, add the model classes from the first half of the lecture and finally allow to flip through all cards of a deck.
To implement this last step, add a new property to hold the model of the game – the card deck – to the view controller. Don’t forget to include the model class:
#import "PlayingCardDeck.h" ... @property (strong, nonatomic) PlayingCardDeck *deck;
Initialize the deck using lazy instantiation:
- (PlayingCardDeck *)deck { if (!_deck) { _deck = [[PlayingCardDeck alloc] init]; } return _deck; }
And finally draw a new card before you are showing a new one:
- (IBAction)flipCard:(UIButton *)sender { if (!sender.isSelected) { [sender setTitle:[self.deck drawRandomCard].contents forState:UIControlStateSelected]; } sender.selected = !sender.selected; self.flipCount++; }
A drawback of this method is that after the last card of the deck has been displayed, flipping does not show a new card …
The code for this lecture including assignment #0 is available at github.
Slides have not been released yet, … Slides are available on iTunes providing a detailed walk through of the demo.
The lecture is available at iTunes and is named “2. Xcode 4 (January 10, 2013)”.
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"
Hi,
Thank you very much! This was very helpful for me.
I started to learn iOS programming with iTunes U and was stucked in this homework where I had to create a deck initialization. I managed it to work the way that it always did a new deck (so same card could always come again and again) when I created a new object instance in flipCard but I didn’t find the way to make already created deck stay on the memory (so I don’t have to initialize a new one always).
I had forgot that I can do that with – (PlayingCardDeck *) deck -style like you did here. This was very helpful, thanks 🙂