2011-03-17 70 views
3

我写了下面的代码来构建一个基本的游戏,使两辆赛车(randomgenerator),并让用户选择他们对最终结果的赌注。我在某个地方犯了一个错误,我的赛车只是半路赛跑,然后卡在起跑线后面,程序不停地重复哔哔声和messsagebox.show,并将结果添加到“错误”框中。我花了三天的时间试图找出我出错的地方,我只是想念它。感谢您花时间看这个。我非常感谢任何建议。VB.net计时器滴答事件问题

终止应用程序的唯一方法是点击“停止调试”。

Screen shot of application

Option Explicit On 
Option Strict On 

Public Class MainForm 

    Private Sub exitButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles exitButton.Click 
     Me.Close() 
    End Sub 


    Private Sub MainForm_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load 
     'fills the list box with items, then selects the first item 
     resultListBox.Items.Add("No guess") 
     resultListBox.Items.Add("Tie") 
     resultListBox.Items.Add("Red Car wins") 
     resultListBox.Items.Add("White car wins") 
     resultListBox.SelectedIndex = 0 
    End Sub 

    Private Sub startButton_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles startButton.Click 
     raceTimer.Enabled = True 

    End Sub 

    Private Sub raceTimer_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles raceTimer.Tick 
     ' moves two cars from a starting line to a finish line on the form 
     ' displays a message indicating the race results 
     ' calculates and displays the number of times the user selects the 
     ' correct race result from the resultlistbox, and the number 
     ' of times the user selects an incorrect race result 

     Dim randomgenerator As New Random 
     Dim whitenewlocation As Integer 
     Dim rednewlocation As Integer 
     Dim raceresult As String 
     Dim userchoice As String 
     Dim finishline As Integer = finishTextBox.Left + 1 
     Static numbercorrect As Integer 
     Static numberincorrect As Integer 

     ' save the user's list box selection, then disable the list box 
     userchoice = resultListBox.SelectedItem.ToString 
     resultListBox.Enabled = False 

     'calculate the new location of each picture box's right border 
     ' don't allow the right border to go beyond the finish line 
     whitenewlocation = whitePictureBox.Right + randomgenerator.Next(0, 11) 
     If whitenewlocation > finishline Then 
      whitenewlocation = finishline 
     End If 
     rednewlocation = redPictureBox.Right + randomgenerator.Next(0, 11) 
     If rednewlocation > finishline Then 
      rednewlocation = finishline 
     End If 

     'move each picture box toward the finish line 
     whitePictureBox.SetBounds(whitenewlocation - whitePictureBox.Width, 0, 0, 0, BoundsSpecified.X) 
     redPictureBox.SetBounds(rednewlocation - redPictureBox.Width, 0, 0, 0, BoundsSpecified.X) 

     'the following selection structure is processed only when at least 
     ' one of the picture boxes is at the finish line 
     If whitePictureBox.Right = finishline _ 
      OrElse redPictureBox.Right = finishline Then 
      'disable the timer 
      raceTimer.Enabled = False 
     End If 

     'sound a beep to indicate the end of the race 
     For x As Integer = 1 To 5 
      Console.Beep(100, 100) 
     Next x 

     'store the result of the race in a variable 
     If whitenewlocation = rednewlocation Then 
      raceresult = "Tie" 
     ElseIf whitenewlocation > rednewlocation Then 
      raceresult = "White car wins" 
     Else 
      raceresult = "red car wins" 
     End If 

     'display the race results 
     MessageBox.Show("Race Over!" & ControlChars.NewLine & raceresult, _ 
     "Car Race", MessageBoxButtons.OK, MessageBoxIcon.Information) 

     'move the picture boxes back to the starting line 
     whitePictureBox.SetBounds(12, 0, 0, 0, BoundsSpecified.X) 
     redPictureBox.SetBounds(12, 0, 0, 0, BoundsSpecified.X) 


     'if the user did not want to guess the race results, then 
     'don't update or display the counter values; otherwise, 
     'compare the race results to the user's selection and update 
     ' the appropriate counter, then display both counter values 
     If userchoice <> "no guess" Then 
      If raceresult = userchoice Then 
       numbercorrect = numbercorrect + 1 
      Else 
       numberincorrect = numberincorrect + 1 
      End If 
      correctLabel.Text = Convert.ToString(numbercorrect) 
      incorrectLabel.Text = Convert.ToString(numberincorrect) 
     End If 

     'enable the list box 
     resultListBox.Enabled = True 
    End Sub 
End Class 

回答

1

你的计时器是做每个替一切。处理比赛结束的代码将在计时器的每个时间点进行处理。它应该包含在处理比赛结束的if逻辑中。

评论“发出蜂鸣声来表示比赛结束”后

的allmost eveything应该是检查比赛结束内部:

If whitePictureBox.Right = finishline OrElse redPictureBox.Right = finishline Then 
    'put all logic of the "ending" of the race here 
end if 

所以这个代码将作为你的预期:

Private Sub raceTimer_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles RaceTimer.Tick 
    ' moves two cars from a starting line to a finish line on the form 
    ' displays a message indicating the race results 
    ' calculates and displays the number of times the user selects the 
    ' correct race result from the resultlistbox, and the number 
    ' of times the user selects an incorrect race result 

    Dim randomgenerator As New Random 
    Dim whitenewlocation As Integer 
    Dim rednewlocation As Integer 
    Dim raceresult As String 
    Dim userchoice As String 
    Dim finishline As Integer = finishTextBox.Left + 1 
    Static numbercorrect As Integer 
    Static numberincorrect As Integer 

    ' save the user's list box selection, then disable the list box 
    userchoice = resultListBox.SelectedItem.ToString 
    resultListBox.Enabled = False 

    'calculate the new location of each picture box's right border 
    ' don't allow the right border to go beyond the finish line 
    whitenewlocation = whitePictureBox.Right + randomgenerator.Next(0, 11) 
    If whitenewlocation > finishline Then 
     whitenewlocation = finishline 
    End If 
    rednewlocation = redPictureBox.Right + randomgenerator.Next(0, 11) 
    If rednewlocation > finishline Then 
     rednewlocation = finishline 
    End If 

    'move each picture box toward the finish line 
    whitePictureBox.SetBounds(whitenewlocation - whitePictureBox.Width, 0, 0, 0, BoundsSpecified.X) 
    redPictureBox.SetBounds(rednewlocation - redPictureBox.Width, 0, 0, 0, BoundsSpecified.X) 

    'the following selection structure is processed only when at least 
    ' one of the picture boxes is at the finish line 
    If whitePictureBox.Right = finishline _ 
     OrElse redPictureBox.Right = finishline Then 
     'disable the timer 
     RaceTimer.Enabled = False 
     'sound a beep to indicate the end of the race 
     For x As Integer = 1 To 5 
      Console.Beep(100, 100) 
     Next x 

     'store the result of the race in a variable 
     If whitenewlocation = rednewlocation Then 
      raceresult = "Tie" 
     ElseIf whitenewlocation > rednewlocation Then 
      raceresult = "White car wins" 
     Else 
      raceresult = "red car wins" 
     End If 

     'display the race results 
     MessageBox.Show("Race Over!" & ControlChars.NewLine & raceresult, _ 
     "Car Race", MessageBoxButtons.OK, MessageBoxIcon.Information) 

     'move the picture boxes back to the starting line 
     whitepicturebox.SetBounds(12, 0, 0, 0, BoundsSpecified.X) 
     redpicturebox.SetBounds(12, 0, 0, 0, BoundsSpecified.X) 


     'if the user did not want to guess the race results, then 
     'don't update or display the counter values; otherwise, 
     'compare the race results to the user's selection and update 
     ' the appropriate counter, then display both counter values 
     If userchoice <> "no guess" Then 
      If raceresult = userchoice Then 
       numbercorrect = numbercorrect + 1 
      Else 
       numberincorrect = numberincorrect + 1 
      End If 
      correctlabel.Text = Convert.ToString(numbercorrect) 
      incorrectlabel.Text = Convert.ToString(numberincorrect) 
     End If 

     'enable the list box 
     Resultlistbox.Enabled = True 
    End If 


End Sub 
+0

没办法!非常感谢。我非常关注逻辑错误,所以我完全忽略了决策结构!这对我来说是一个巨大的学习曲线。非常感谢Stefan! – Wannabe 2011-03-17 10:41:17

相关问题