This is a simple game, which will introduce you to Methods, Multiple Picture Boxes, Labels, Random Numbers, Drawing and more!
Printer Friendly Download Tutorial (183KB) Download Source Code (7KB)
Step 1
Load Microsoft Visual Studio.NET then select Visual Basic Projects, Windows Application, enter a name for the Project and then click OK, see below:
data:image/s3,"s3://crabby-images/71333/71333a6559f6a25f15c0fc451bee6a7512508e0c" alt="New Project"
Step 2
A Blank Form named Form1 should then appear, see below:
data:image/s3,"s3://crabby-images/79729/79729464cdae29c2b9b08fc3b131df0a7df948fa" alt="Form1"
Step 3
Then from the Windows Forms components tab select the PictureBox control:
data:image/s3,"s3://crabby-images/8145d/8145d067cd5d330135b8a3bac693695e1f649382" alt="PictureBox Component"
Step 4
Draw two PictureBoxes on the Form, see below:
data:image/s3,"s3://crabby-images/47bc4/47bc45a07c7788ad9323e0bf39273c8dc09cc5aa" alt="Form1 with two PictureBoxes"
Step 5
Select PictureBox1 and then go to the Properties box and change the BackColor property from Control to White, see below:
data:image/s3,"s3://crabby-images/9f68d/9f68db3827961a7784e1b16a66b729adaacbd48e" alt="PictureBox Property"
Step 6
Select PictureBox2 and then go to the Properties box and change the BackColor property from Control to White, so the form appears as below:
data:image/s3,"s3://crabby-images/76fc4/76fc4788bfc65e8cbd5045d521070548d1dca4c8" alt="Form1 with White PictureBoxes"
Step 7
Then from the Windows Forms components tab select the Button control:
data:image/s3,"s3://crabby-images/b6a67/b6a678464a1ba2805e8010feb45e33dfaef18b10" alt="Button Component"
Step 8
Draw three Buttons on the Form, see below:
data:image/s3,"s3://crabby-images/1f214/1f214fb5b851a79871ca0844c3750b69ac53db9f" alt="Form1 with PictureBoxes and Three Buttons"
Step 9
Click on Button1 and then go to the Properties box and change the Text Property to Roll, see below:
data:image/s3,"s3://crabby-images/231e6/231e696e915d82f07651fcd0cf18e725585d0c48" alt="Button1 Property"
Step 10
Click on Button2, change its Text Property to New Game, click on Button3 and change its Text Property to Exit until the form is as below:
data:image/s3,"s3://crabby-images/d599e/d599ebc15e3f50e7dfb109a2732fe742fa6497a9" alt="Form1 Dice Buttons"
Step 11
Then from the Windows Forms components tab select the Label control:
data:image/s3,"s3://crabby-images/17889/17889805d9c4f21b8f86e7a994cccb6dbb224269" alt="Label Component"
Step 12
Draw a Label on the Form, see below:
data:image/s3,"s3://crabby-images/3f89d/3f89da3d9fb6e1f260ae982b2a83df338e1f0b5c" alt="Form1 with Label Buttons and PictureBoxes"
Step 13
Right click on the Form and select the view Code option then in the code view type in below the Windows Form Designer generated code section:
Dim MyBrush As SolidBrush Dim DrawBitmap As Bitmap Dim DrawGraphics As Graphics Dim Turn As Integer Dim DiceColor As Color
See Below:
data:image/s3,"s3://crabby-images/c76fa/c76fa0148da346db2d86947e468bf0c91d5b6e0c" alt="Dice Declarations"
Step 14
Double Click on Form1 and type in the Form1_Load Sub:
Label1.TextAlign = ContentAlignment.MiddleCenter Label1.Text = "Player 1" Turn = 1 DiceColor = Color.Black
See Below:
data:image/s3,"s3://crabby-images/0f1f0/0f1f09f2c4d3121b4daa41f6a6ec356706db8cb2" alt="Form1 Load"
Step 15
Right click on the Form and select the view Code option then in the code view type in below the end of the Form1_Load sub (after end sub):
Private Sub Center(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, CInt(pic.Width / 2 - 6), _ CInt(pic.Height / 2 - 6), 12, 12) End Sub Private SubTopLeft(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, 6, 6, 12, 12) End Sub Private Sub CenterLeft(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, 6, _ CInt(pic.Height / 2 - 6), 12, 12) End Sub Private Sub BottomLeft(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, 6, pic.Height - 18, 12, 12) End Sub Private Sub TopRight(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, pic.Width - 18, 6, 12, 12) End Sub Private Sub CenterRight(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, pic.Width - 18, _ CInt(pic.Height / 2 - 6), 12, 12) End Sub Private Sub BottomRight(ByVal b As SolidBrush, _ ByVal pic As PictureBox, ByVal g As Graphics) g.FillEllipse(b, pic.Width - 18, _ pic.Height - 18, 12, 12) End Sub
See Below:
data:image/s3,"s3://crabby-images/83577/83577cc9a8f275ab3a1dca0ef50cb35ad44e91d1" alt="Dice Dots Methods"
Step 16
While still in the code view add the following below the end of the BottomRight(...) sub (after end sub):
Private Sub RenderDice(ByVal Value As Integer, _ ByVal pic As PictureBox, ByVal g As Graphics, _ ByVal ForeColor As Color) myBrush = New SolidBrush(ForeColor) Select Case Value Case 0 ' Draw Nothing Case 1 Center(myBrush, pic, g) Case 2 TopLeft(myBrush, pic, g) BottomRight(myBrush, pic, g) Case 3 TopLeft(myBrush, pic, g) Center(myBrush, pic, g) BottomRight(myBrush, pic, g) Case 4 TopLeft(myBrush, pic, g) BottomLeft(myBrush, pic, g) TopRight(myBrush, pic, g) BottomRight(myBrush, pic, g) Case 5 TopLeft(myBrush, pic, g) BottomLeft(myBrush, pic, g) Center(myBrush, pic, g) TopRight(myBrush, pic, g) BottomRight(myBrush, pic, g) Case 6 TopLeft(myBrush, pic, g) CenterLeft(myBrush, pic, g) BottomLeft(myBrush, pic, g) TopRight(myBrush, pic, g) CenterRight(myBrush, pic, g) BottomRight(myBrush, pic, g) End Select End Sub
See Below:
data:image/s3,"s3://crabby-images/a2d52/a2d524f3e4ef2f70730e8b7b7167901e9300d84c" alt="Render Dice Method"
Step 17
Also in the code view add these paint routines for the PictureBoxes:
Private Sub PictureBox1_Paint(ByVal sender As Object, _ ByVal e As System.Windows.Forms.PaintEventArgs) _ Handles PictureBox1.Paint RenderDice(DiceOne, PictureBox1, e.Graphics, DiceColor) End Sub Private Sub PictureBox2_Paint(ByVal sender As Object, _ ByVal e As System.Windows.Forms.PaintEventArgs) _ Handles PictureBox2.Paint RenderDice(DiceTwo, PictureBox1, e.Graphics, DiceColor) End Sub
See Below:
data:image/s3,"s3://crabby-images/6c479/6c479ef472ee2f5f1ee18fcd2fd837adcc56f42d" alt="PictureBox 1 and 2 Paint Methods"
Step 18
Double Click on the Button Labeled Roll (Button1) and type in the Button1_Click() Sub:
If Turn = 1 Then Randomize() DiceOne = CInt(Int((6 * Rnd()) + 1)) PictureBox1.Refresh() Label1.Text = "Player 2" Turn = 2 Else Randomize() DiceTwo = CInt(Int((6 * Rnd()) + 1)) PictureBox2.Refresh() Label1.Text = "Player 1" Turn = 1 End If
See Below:
data:image/s3,"s3://crabby-images/eb9c9/eb9c90f7f58f379d153a8dbc03615dfae38e7a46" alt="Button1 Click Event"
Step 19
Double Click on the Button Labeled New Game (Button2) and type in the Button2_Click() Sub:
DiceOne = 0 DiceTwo = 0 PictureBox1.Refresh() PictureBox2.Refresh() Label1.Text = "Player 1" Turn = 1
See Below:
data:image/s3,"s3://crabby-images/08b7b/08b7bd117189312d5568cd72952b0f0ab042e225" alt="Button2 Click Event"
Step 20
Double Click on the Button Labeled Exit (Button3) and type in the Button3_Click() Sub:
End
See Below:
data:image/s3,"s3://crabby-images/dc5c2/dc5c29983cc1c43d4a12779d40b84f895209db27" alt="Button3 Click Event"
Step 21
Save the Project as you have now finished the application, select Release and Click on Start:
data:image/s3,"s3://crabby-images/689ff/689ffab27fdbc96e0672cba0c3f6eda0e242231e" alt="Start (Release)"
When you do the following will appear:
data:image/s3,"s3://crabby-images/70912/70912b38cc06b78ecd39a008f620b615b7895875" alt="Application Running"
Step 22
Click on Roll to roll the dice for Player One by clicking on Roll, see below:
data:image/s3,"s3://crabby-images/01457/014572afbb68d97c77e7d8877ba1759ce44f78f2" alt="Dice One Rolled"
Step 23
Just Click on Ok and then click on the Close button
on the top right of Form1 to end the application.
By clicking on the Roll button it will alternate between Player 1 and Player 2 (Left & Right). You have just created a simple Dice Game, but what about scoring and proper dice rules, you'll have to wait, try and make it have a scoring system/rules yourself and see what else you can achieve with this simple program.