Cards
simple list
For any default sprite, create a new type of variable called a list (and name the listcards
):data:image/s3,"s3://crabby-images/4f3ab/4f3ab56ce4c526bd9210ed06e936b9bab304109f" alt=""
A list is still a variable, but makes working with a collection of values easier. Attach this script to the default sprite once you have created the 'cards' list shown above:
data:image/s3,"s3://crabby-images/803e4/803e4f490bc376b1e7b841b596004a7d67a7d444" alt=""
Try the above script out before continuing, and answer this question: Could you modify the simple list script so far so that it displays a random dice roll, e.g. "ONE", "FIVE", "SIX" etc.
more complex use of lists - shuffling
We will use this algorithm to help us shuffle the card deck:for each of the card positions in the deck, counting backwards from the last position: choose a random card from somewhere between the beginning of the deck and my current position swap the random card i have chosen with the card from the position i am currently looking at
To implement this algorithm, create another list variable called
temp
(you should already have a list variable named cards
at this point). We will use the 'temp' list to hold temporary values while we process through the main deck of 'cards':data:image/s3,"s3://crabby-images/57793/577936afedab0200a4e78c3a7e69b3eaefdb64fe" alt=""
Attach this script to the default sprite (you can replace any script you had previously):
data:image/s3,"s3://crabby-images/60159/601595cbce39a6bc33fa85241989afda5746a626" alt=""
questions - these are difficult
Can you add:- A full deck of cards (all 52) in the
populate_deck
event? There is an easier way to do this.. the following script is in addition to the above script but modifies thepopulate_deck
event used earlier. It also uses two extra lists and two extra variables: - A third list variable, named
my_hand
, and deal the first five cards from the (shuffled)cards
list variable tomy_hand
? Hint: - Can you turn this into any card game?
- If you have time remaining, add animations and improve the user experience.
data:image/s3,"s3://crabby-images/c90ea/c90ea5685c3393ed1b76252d642763289423b285" alt=""
data:image/s3,"s3://crabby-images/6af3d/6af3de375dd666a700f4273e9d64f5b54d0c7776" alt=""
data:image/s3,"s3://crabby-images/bda2d/bda2d3e0aa810dee708c607d658c493570e1ad67" alt=""