Hello! I'm Eugene. This is my educational project for the Spring 2021 version of Stanford University's course CS193p.
Completed tasks
- My game from A2 should no longer select a random theme, but instead, its ViewModel should have a theme var variable that can be set.
- The New button has been changed to restart the game instead of selecting a new theme.
- Now my Memorize Game application shows the "theme selection" interface at startup.
- I was using a list to display the topics.
- Each line in the list shows the name of the theme, the color of the theme, the number of how many cards in the theme, and some sample emojis in the theme.
- Clicking on a theme in the list takes you (i.e. the list is in navigation mode) to the game with that theme.
- Switching from the game to the theme selection and then back to the game does not restart the game unless the game theme has been changed
- A user interface for adding a new theme to the list in the theme selection window has been provided.
- The selector supports an editing mode where themes can be deleted and where clicking on a row brings up the modally presented (i.e., in the form of a sheet or pop-up window) theme editor interface for that theme, rather than navigating to the game with that theme.
- The theme editor uses a form.
- The theme editor allows the user to edit the theme name, add emoticons to the theme, remove emoticons from the theme, specify the number of cards in the theme, and specify the theme colour.
- Themes are persistent (i.e., restarting the application does not cause all the changes made in the theme to be lost).
Below is a list of the concepts I practiced within this assignment.
- List
- Form
- NavigationView
- Modal presentation
- TextField
- EditMode
- Multiple MVVMs
- UserDefaults
- Using new API (Stepper, ColorPicker, etc.)
add animation and a new "Shuffle" button. When the pictures are matched, the card frame shows the match as an identifier and is accompanied by an animation
The goal of this assignment is to continue to recreate the demonstrations given in the first four lectures and then make some bigger enhancements. MVVM was used to improve the previous project. - MemoryGame(Model); - EmojiMemoryGame(ViewModel); - ContentView(View).
Completed tasks
-
I have implemented the Memorize game working as demonstrated in lectures 1 through 4.
-
Remove the buttons for selecting a theme and (optionally) the game's name (see Assignment I).
-
Added a formal concept of "Theme" to the model. A theme is a structure and consists of a theme name, a set of emojis to use, the number of pairs of cards to show, and the appropriate color for drawing cards.
-
At least 6 different themes are supported in your game.
-
Added a "New Game" button to my interface that starts a brand new game.
-
The new game uses a randomly selected theme, and clicking the "New Game" button causes a new random theme to be selected again.
-
The cards in the new game are completely shuffled using randomCase. This means that they are not in any predictable order, that they are chosen from any emoticon in the theme.
-
Entered the score of my game, deducting 1 point for each previously seen card involved in the mismatch and giving 2 points for each match (regardless of whether or not the cards were "previously seen"). The score may be negative if the user has poor memorization. If you first flip 🐧 + 👻, then flip 🤖 + 🏀, then flip two 👻, your score will be 2 because you scored a match (and you will not receive any penalty for flipping 🐧, ✏, or 🏀 because they have not (yet) been involved in a match and 👻 have never been involved in a match). If you flip 🐧 + 🐼 again and then flip 🏀 + 🐧, your score will be reduced by 3 full points to -1 because this 🐧 card was already seen (during the first flip) and subsequently participated in two separate discrepancies (-1 point for each discrepancy), and the 🏀 card was a discrepancy after it was already seen (-1). If you flip the 🐧 + the other 🐧 that you finally found, you get 2 points for the match and return to 1 total point.
-
The score displayed in the interface
Completed tasks
- I have implemented a game called "Memorize" that works as shown in lectures 1 and 2. Enter all the codes.
- I added the caption "Memorize!" to the top of the screen.
- Add at least 3 "Select Theme" buttons to the interface, each of which will replace all cards with new ones containing emojis that match the selected theme.
- The number of cards in each of the 3 themes is different but in no case less than 8.
- The cards that appear when you click the theme button are in an unpredictable (i.e. random) order.
- The topic buttons contain an image representing the topic and text describing the topic, arranged vertically above each other.
- The image of the topic buttons should be created using the SF symbol associated with the topic that is selected (e.g., the car symbol and the topic "Vehicles" as shown in the "Screenshots" section below).
- The text description of the topic selection buttons is written in a noticeably smaller font than the font chosen for the emoji on the cards.
Also, I also did an Extra credit assignment. I made a random number of cards appear each time a theme button is chosen. It always shows at least 4 cards though. I created the randomizer() function specifically for this purpose
This project is built on Xcode 14.2 with the use of Swift 5.7 and SwiftUI 4
My email: demenkoeugene@icloud.com