Skip to content

Latest commit

 

History

History
215 lines (204 loc) · 8.25 KB

README.md

File metadata and controls

215 lines (204 loc) · 8.25 KB

SetGame2020

SwiftUI version of game of SET for iOS as specified in Assignment 3 of Stanford CS193P Spring 2020

Objective

The goal of this assignment is to give you an opportunity to create your first app completely from scratch by yourself. It is similar enough to the first two assignments that you should be able to find your bearings, but different enough to give you the full experience!

Required Tasks

  1. Implement a game of solo (i.e. one player) Set.
+ Status: done
  1. When your game is run for the very first time, there should briefly be no cards showing, but as soon as it appears, it should immediately deal 12 cards by having them “fly in” from random off-screen locations.
+ Status: done
  1. . As the game play progresses, use all the real estate on the screen in an efficient manner. Cards should get smaller (or larger) as more (or fewer) appear on-screen at the same time, while always using as much space as is available and still being “nicely arranged”. All changes to locations and/or sizes of cards must be animated.
+ Status: done
  1. Cards can have any aspect ratio you like, but they must all have the same aspect ratio at all times (no matter their size and no matter how many are on screen at the same time). In other words, cards can be appearing to the user to get larger and smaller as the game goes on, but the cards cannot be “stretching” into different aspect ratios as the game is played.
+ Status: done
  1. The symbols on cards should be proportional to the size of the card (i.e. large cards should have large symbols and smaller cards should have smaller symbols).
+ Status: done
  1. Users must be able to select up to 3 cards by touching on them in an attempt to make a Set (i.e. 3 cards which match, per the rules of Set). It must be clearly visible to the user which cards have been selected so far.
+ Status: done
  1. After 3 cards have been selected, you must indicate whether those 3 cards are a match or mismatch. You can show this any way you want (colors, borders, backgrounds, animation, whatever). Anytime there are 3 cards currently selected, it must be clear to the user whether they are a match or not (and the cards involved in a non-matching trio must look different than the cards look when there are only 1 or 2 cards in the selection).
+ Status: done
  1. Support “deselection” by touching already-selected cards (but only if there are 1 or 2 cards (not 3) currently selected).
+ Status: done
  1. When any card is touched on and there are already 3 matching Set cards selected, then … a. as per the rules of Set, replace those 3 matching Set cards with new ones from the deck
+ Status: done

b. the matched cards should fly away (animated) to random locations off-screen

+ Status: done

c. the replacement cards should fly in (animated) from other random off-screen locations.

+ Status: done

d. if the deck is empty then the space vacated by the matched cards (which cannot be replaced) should be made available to the remaining cards (i.e. they’ll likely get bigger)

+ Status: done

e. if the touched card was not part of the matching Set, then select that card

+ Status: done
  1. When any card is touched and there are already 3 non-matching Set cards selected, deselect those 3 non-matching cards and select the touched-on card (whether or not it was part of the non-matching trio of cards).
+ Status: done
  1. You will need to have a “Deal 3 More Cards” button (per the rules of Set). a. when it is touched, replace the selected cards if the selected cards make a Set (with fly-in/fly-away as described above)
+ Status: done

b. or, if the selected cards do not make a Set (or if there are fewer than 3 cards selected, including none), fly in (i.e. animate the arrival of) 3 new cards to join the ones already on screen (and do not affect the selection)

+ Status: done

c. disable this button if the deck is empty

+ Status: done
  1. You also must have a “New Game” button that starts a new game (i.e. back to 12 randomly chosen cards). Cards should fly in and out when this happens as well.
+ Status: done
  1. To make your life a bit easier, you can replace the “squiggle” appearance in the Set game with a rectangle.
+ Status: created a squiggle-like shape for this (see extra credit)
  1. You must author your own Shape struct to do the diamond.
+ Status: Done
  1. Another life-easing change is that you can use a semi-transparent color to represent the “striped” shading. Be sure to pick a transparency level that is clearly distinguishable from “solid”.
+ Status: created striped shading (see extra credit)
  1. You can use any 3 colors as long as they are clearly distinguishable from each other.
+ Status: Done
  1. You must use an enum as a meaningful part of your solution.
+ Status: Done
  1. You must use a closure (i.e. a function as an argument) as a meaningful part of your solution.
+ Status: Done. See StandardSetGame.swift (the vie model file) for use with the function that does a depth-first search for a match with the "Cheat" button
  1. Your UI should work in portrait or landscape on any iOS device. This probably will not require any work on your part (that’s part of the power of SwiftUI), but be sure to experiment with running on different simulators in Xcode to be sure.
+ Status: Done

Extra Credit

  1. Have your cards fly in from a deck View located somewhere on screen. This is a little bit more difficult than flying to a random location because figuring out where some other View is will require some investigation on your part.
! Status: In progress
  1. If you deal from a deck, have the cards be “face down” while on the deck and then flip over as they fly out to their locations when they are dealt.
! Status: In progress
  1. Draw the actual squiggle instead of using a rectangle.
+ Status: Done. It is not quite the squiggle used in the official version, but more of tilde. I think I could get it to be the same squiggle by playing around the Bezier curves a bit.
  1. Draw the actual striped “shading” instead of using a semi-transparent color.
+ Status: Done
  1. When cards match, provide some exciting animation. In other words, use animation to show that cards are matched in Required Task 7.
# Status: Not yet started
  1. Make your fly away more exciting (maybe the cards spin as they fly away?).
# Status: Not yet started
  1. Keep score somehow in your Set game. You can decide what sort of scoring would make the most sense.
+ Status: Done. Right now it simply keeps track of the number of matched sets and displays it at the bottom of the screen.
  1. Give higher scores to players who choose matching Sets faster (i.e. incorporate a time component into your scoring system).
# Status: Not yet started
  1. Figure out how to penalize players who chose Deal 3 More Cards when a Set was actually available to be chosen.
# Status: Not yet started
  1. Add a “cheat” button to your UI.
+ Status: Done. Pressing the button automatically selects two of the three cards in a possible set, if such a set exists on the screen. If no such set exists, no cards are selected. Button is disabled while a match is currently showing.
  1. Support two players. No need to go overboard here. Maybe just a button for each user (one upside-down at the top of the screen maybe?) to claim that they see a Set on the board. Then that player gets a (fairly short) amount of time to actually choose the Set or the other person gets as much time as they want to try to find a Set (or maybe they get a longer, but not unlimited amount of time?). Maybe hitting “Deal 3 More Cards” by one user gives the other some medium amount of time to choose a Set without penalty? You will need to figure out how to use Timer to do these timelimited things.
# Status: Not yet started