Blackjack Step By Step

 
Listing your server has never been easier! The first step in getting your server listed is by logging in RuneAd,which can be done by navigating to the top of RuneAd.com and clicking the 'Sign in/ Register' button.We require a Discord account in order to use our services. Once logged in, you will notice your discord usernameat the top right of the webpage, hover over your name in and you will see 'My Profile'.This is your RuneAd profile page that you will see different information based on your RuneAd time.To add your RSPS from your profile page, simply click 'Add Server', which will bring you to a form to fill outwith your server information. Private information about your servers such as the IP and Port will be hiddenfrom the public, but viewable only by the owner of the server listing. Once you are finished filling out theform for your server, click the 'create listing' button and this will put your listing on RuneAd.
There are two ways to use the backend voting of RuneAd. We have our own API which can be foundHere. RuneAd is also listed onEverythingRS, information on how to set that up is listed on their website.

Blackjack 21 is one of the hottest casino games in the market. Download and play for fun with your friends Xsolla is an authorized global distributor of BLACKJACKIST. Interested in programming? Like to read about programming without seeing a constant flow of technology and political news into your proggit? That's what /r/coding is for. Must be 21 or older to purchase or redeem tickets. Overall odds vary by game. All sales are final. In accordance with ADA, these materials may be made available in an alternative format. Gambling problem? Call 1.800.NEXT STEP (1-800-639-8783) or VISIT SITE. Please Play Responsibly™.

In the previous posts in this series, we have built our Blackjack in Blazor demo app up to a point where we have many of the pieces we need to make a functioning implementation. In this post, we're going to finish it off.

Lucky for us, we did the markup and method definitions for the last piece of this implementation, the main Blazor component, in the previous part. Now all we need to do is write the C# code that will make it work.

Catching Up

You'll probably want to read the first three parts of this series before reading this one.

As always, there's a sample repository over on GitHub that has all of the code used in this series. Check it out!

A Quick Recap

Here's the markup for the main Blackjack Blazor component that we coded up in the previous post.

Also in the previous post, we defined a set of methods that needed to be implemented:

Blackjack Step By Step
  • InitializeHand()
  • NewHand()
  • Stand()
  • Hit()
  • Insurance()
  • DoubleDown()
  • Bet(int amount)

Let's get started implementing those methods!

Useful Custom Method: Delay()

In order to force the application to take 'pauses' at certain times, we're going to make use of a special method called Delay(), which looks like this:

The method StateHasChanged() in Blazor is a special method that tells the renderer to re-render the display. Therefore every time we delay, the display will be re-rendered.

Blackjack Step By Step

From here on out, the methods we need to implement follow a rough order.

Step 1: Start a New Hand

The method InitializeHand() is invoked whenever a new hand is started.

In the real world, if the dealer is only playing with one deck of cards, they would need to check if the deck needs to be shuffled, and do so. So this method will also need to do that check, and set the game state to Shuffling while that is happening. If the deck does not need to be shuffled, then the player will be able to make a bet for the new hand, so the GameState will need to be set to Betting.

Here's the code for our method:

Step 2: Placing a Bet

Setting the GameState to Betting means the buttons to place a bet are available.

The player cannot bet more than they have funds for. After the bet is placed, the dealer can make the initial deal. Our Bet() method will take these into account, and be written like this:

Step 3: The Initial Deal

After the bet is placed, the Dealer makes the initial deal by dealing a card to the player first, then a face-down card to him/herself, then another card to the Player, then a face-up card to him/herself. After each card is dealt, we will call StateHasChanged() so the display will render the dealt card.

Once all the cards are dealt, the GameState will be set to InProgress.

Step 3.1: Player Has Blackjack

At this point, there's only one condition in which the player is not offered the choice to stand or hit: if they have a blackjack.

Let's modify the Deal() method to take this situation into account:

Step 4: Dealer's Turn

The Dealer does not take their turn until the Player completes theirs. Before we can build out the methods for the Player's actions, we need to have a method for the dealer to take their turn.

In Blackjack, the dealer will always hit if their total score is 16 or less, and will always stand on 17 or more. We can use a recursive method to make the Dealer take a turn until their score is 17 or greater:

Step 5: Player Actions

When the GameState is set to InProgress, the player is now able to choose which action to take. During each hand, they can either hit or stand; in some circumstances, they can use the double down or insurance special plays.

The implementation of the player action methods assumes the existence of a method EndHand(), which we will implement later.

Let's deal with each of the player actions one at a time.

Step 5.1: Hit

If the player chooses to hit, the Dealer will give them a new card. At that point, if the player is busted, the hand is over. Otherwise, the GameState does not change; the player may still choose to hit or stand.

Craps Step By Step

Step 5.2: Stand

How to play blackjack step by step

If the player chooses to stand, the Dealer reveals their hidden card and takes their turn. Afterward, the hand is over.

Step 5.3: Double Down

If the player has a 9, 10, or 11 score and exactly two cards, the Double Down special play is available. On this play, the following things happen:

  • The player's bet is doubled
  • The player gets one additional card, and is forced to stand after that.

This results in a DoubleDown() method that looks like this:

Step 5.4: Insurance

If the dealer's visible card is an Ace, the player make make a special Insurance bet. During this play, the GameState is set to Insurance.

If the player chooses to use this play, the insurance bet will be half of the original bet. The dealer will then look at their hidden card. If the hidden card is a ten-card, the player loses their original bet but wins the insurance bet at 2-1; in effect, the player loses no money.

However, if the dealer's hidden card is NOT a ten-card, the player immediately loses their insurance bet, and play continues normally.

Step 6: End Hand and Payouts

We now need a method to handle the end of a hand and payouts or collections. During this time, the GameState is Payout.

At the end of a hand of Blackjack, the following things can happen:

  • If the player has Blackjack, they get paid 1.5 times their original bet.
  • If the player has a higher score and neither is bust, OR the dealer has gone bust, the player wins the bet.
  • If the player is bust, OR the dealer has a higher score and neither is bust, the player loses their bet.
  • If there's a push, no money changes hands.

In order to determine how to write up this method, let's consider what the 'normal' outcome is for the player. To put it simply, the player's normal outcome is a loss. After all, casinos don't really want you to beat them.

How To Play Blackjack Step By Step

So, let's create conditions for a player win or a push, and leave the loss condition as the default.

Note that all of these conditions are modifying the Change property of the Player object; the player does not actually collect their winnings or payout their losses here.

Because the GameState is set to Payout, the button for 'Keep Going' will be visible to the player, and will invoke our last method: NewHand().

Step 7: New Hand

This last method needs to do the following things:

  • Payout (or collect) the player's bets.
  • Reset the player's bets and change values.
  • Reset the GameState
  • Call InitializeHand() to start a new hand.

Here's the code:

Try It Out!

You can play this implementation of Blackjack for yourself right now, over at my sister project site BlazorGames.net.

Or, you can just watch this GIF of me playing Blackjack in Blazor:

Summary

In this final part of our Blackjack in Blazor series, we put all of our C# and Blazor pieces together to make the final, working game.

Poker Step By Step How To

Got ideas on how to improve this implementation? Can you figure out how to model a split play? I want to hear your suggestions! Leave them in the comments below.

Blackjack Step By Step

Thanks for playing, and Happy Coding!