一个卡片游戏的初步实现

VERSION 5.00
Begin VB.Form TestForm1 
   Caption         =   "TestForm1"
   ClientHeight    =   6555
   ClientLeft      =   60
   ClientTop       =   345
   ClientWidth     =   10560
   LinkTopic       =   "Form1"
   ScaleHeight     =   6555
   ScaleWidth      =   10560
   StartUpPosition =   2  '屏幕中心
   Begin VB.TextBox Text1 
      Height          =   5295
      Left            =   8040
      MultiLine       =   -1  'True
      TabIndex        =   6
      Text            =   "TestForm1.frx":0000
      Top             =   480
      Width           =   2415
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   5
      Left            =   7320
      TabIndex        =   5
      Top             =   6000
      Width           =   1215
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   4
      Left            =   5880
      TabIndex        =   4
      Top             =   6000
      Width           =   1215
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   3
      Left            =   4440
      TabIndex        =   3
      Top             =   6000
      Width           =   1215
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   2
      Left            =   3000
      TabIndex        =   2
      Top             =   6000
      Width           =   1215
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   1
      Left            =   1560
      TabIndex        =   1
      Top             =   6000
      Width           =   1215
   End
   Begin VB.CommandButton Command1 
      Caption         =   "Command1"
      Height          =   495
      Index           =   0
      Left            =   120
      TabIndex        =   0
      Top             =   6000
      Width           =   1215
   End
   Begin VB.Timer Timer1 
      Interval        =   1000
      Left            =   8400
      Top             =   6000
   End
   Begin VB.Label Label3 
      Caption         =   "HP"
      Height          =   255
      Index           =   5
      Left            =   6360
      TabIndex        =   15
      Top             =   3720
      Width           =   1215
   End
   Begin VB.Label Label3 
      Caption         =   "SP"
      Height          =   255
      Index           =   4
      Left            =   6360
      TabIndex        =   14
      Top             =   4080
      Width           =   1215
   End
   Begin VB.Label Label3 
      Caption         =   "HP"
      Height          =   255
      Index           =   3
      Left            =   3600
      TabIndex        =   13
      Top             =   3720
      Width           =   1215
   End
   Begin VB.Label Label3 
      Caption         =   "SP"
      Height          =   255
      Index           =   2
      Left            =   3600
      TabIndex        =   12
      Top             =   4080
      Width           =   1215
   End
   Begin VB.Label Label3 
      Caption         =   "SP"
      Height          =   255
      Index           =   1
      Left            =   840
      TabIndex        =   11
      Top             =   4080
      Width           =   1215
   End
   Begin VB.Label Label3 
      Caption         =   "HP"
      Height          =   255
      Index           =   0
      Left            =   840
      TabIndex        =   10
      Top             =   3720
      Width           =   1215
   End
   Begin VB.Label Label2 
      Caption         =   "SP"
      Height          =   255
      Index           =   1
      Left            =   3480
      TabIndex        =   9
      Top             =   2040
      Width           =   1215
   End
   Begin VB.Label Label2 
      Caption         =   "HP"
      Height          =   255
      Index           =   0
      Left            =   3480
      TabIndex        =   8
      Top             =   1800
      Width           =   1215
   End
   Begin VB.Line Line1 
      BorderWidth     =   2
      Visible         =   0   'False
      X1              =   360
      X2              =   720
      Y1              =   120
      Y2              =   120
   End
   Begin VB.Label Label1 
      Caption         =   "系统状态"
      Height          =   375
      Left            =   8040
      TabIndex        =   7
      Top             =   120
      Width           =   2415
   End
   Begin VB.Shape Shape4 
      FillColor       =   &H0000FF00&
      FillStyle       =   0  'Solid
      Height          =   135
      Left            =   840
      Top             =   5520
      Visible         =   0   'False
      Width           =   1215
   End
   Begin VB.Shape Shape2 
      FillStyle       =   0  'Solid
      Height          =   1095
      Index           =   2
      Left            =   6360
      Top             =   4320
      Width           =   1215
   End
   Begin VB.Shape Shape2 
      FillStyle       =   0  'Solid
      Height          =   1095
      Index           =   1
      Left            =   3600
      Top             =   4320
      Width           =   1215
   End
   Begin VB.Shape Shape3 
      FillColor       =   &H00C0FFFF&
      FillStyle       =   0  'Solid
      Height          =   255
      Left            =   0
      Top             =   0
      Visible         =   0   'False
      Width           =   255
   End
   Begin VB.Shape Shape2 
      FillStyle       =   0  'Solid
      Height          =   1095
      Index           =   0
      Left            =   840
      Top             =   4320
      Width           =   1215
   End
   Begin VB.Shape Shape1 
      BackColor       =   &H000000FF&
      BorderColor     =   &H000000FF&
      FillColor       =   &H000000FF&
      FillStyle       =   0  'Solid
      Height          =   1095
      Left            =   3480
      Top             =   600
      Width           =   1215
   End
End
Attribute VB_Name = "TestForm1"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = True
Attribute VB_Exposed = False
Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)

Private Type wAction
    strAttack As String
    strMagic As String
    strbility As String
    strBack As String
    strOption As String
    strRunAWay As String
    strType As String
    intModel As Integer
End Type
Private Type WFang
    strName As String
    intHP As Integer
    intSP As Integer
    intHPC As Integer
    intSPC As Integer
End Type

Private Type DFang
    intDHP As Integer
    intDSP As Integer
    intDCHP As Integer
    intDCSP As Integer
    strName As String
End Type



Dim boolW As Boolean, boolD As Boolean '布尔值,设置当前状态下,哪一方开始动作
Dim boolWDone As Boolean, boolDDone As Boolean, boolALLWDone As Boolean '布尔值,判断当前图标是否已经动作完成。和我方所有图标的动作是否完成。
Dim boolWAttackNow As Boolean '布尔值,表示我方进入战斗动画播放界面。
Dim DMinJie As Integer, WMinJie As Integer '敌我双方的敏捷
Dim intCurrentW As Integer '当前动作的图标
Dim WElements() As wAction '初始化屏幕上三个战斗图标
Dim strStateText As String '当前状态的文字描述
Dim eWFang() As WFang
Dim eDFang As DFang

Private Sub Command1_Click(Index As Integer)
'

    boolWDone = False
    
    Select Case Index
        Case 0 '攻击
            Call FAttackW(intCurrentW, "GONGJI")
        Case 1 '魔法
        
        Case 2 '技能
        
        Case 3 '回避
        
        Case 4 '选项
        
        Case 5 '逃跑
        
        Case Else
        
    End Select
    
    Call refreshState
    Call closeAllButtom
End Sub

Private Sub Form_Load()
'
    Call initData1      '初始化部分用于测试的数值
    Call initData2
    
End Sub

Private Sub Timer1_Timer()
'

    Call updateDF1  '更新敌方的位子移动
    Call updateWF1  '更新我方的位置移动
    
    Call checkWhoAttack '确定哪一方可以攻击
    Call updateAttackW
    Call fightNowW
        
End Sub

Private Sub updateDF1()
'

    Call refreshPOS
    
End Sub
Private Sub updateWF1()
'

    Call refreshWPOS
    
End Sub
Private Sub refreshWPOS()
'
    Dim l1 As Long, l2 As Long, l3 As Long
    Dim i1 As Integer
    Dim d1 As Double
    d1 = Rnd
    
    d1 = d1 * 10
    l1 = d1
    l2 = d1 * 100
    For i1 = 0 To Me.Shape2.UBound
        Select Case l1
            Case Is >= 8
                Call SMove(Me.Shape2(i1), "left", l2)
            Case Is >= 5
                Call SMove(Me.Shape2(i1), "right", l2)
            Case Is >= 2
                Call SMove(Me.Shape2(i1), "top", l2)
            Case Is >= 0
                Call SMove(Me.Shape2(i1), "buttom", l2)
            Case Else
            
        End Select
    Next i1
End Sub
Private Sub refreshPOS()
'
    Dim l1 As Long, l2 As Long, l3 As Long
    Dim d1 As Double
    d1 = Rnd
    
    d1 = d1 * 10
    l1 = d1
    l2 = d1 * 100
    l3 = d1 * 10
'    Debug.Print l3
'    Debug.Print l2
    Select Case l1
        Case Is >= 8
'            Debug.Print "XIA"
            Me.Shape1.Top = Me.Shape1.Top + l3
            Sleep (l2)
            Me.Shape1.Top = Me.Shape1.Top - l3
        Case Is >= 5
'            Debug.Print "SHANG"
            Me.Shape1.Top = Me.Shape1.Top - l3
            Sleep (l2)
            Me.Shape1.Top = Me.Shape1.Top + l3
        Case Is >= 2
'            Debug.Print "ZUO"
            Me.Shape1.Left = Me.Shape1.Left - l3
            Sleep (l2)
            Me.Shape1.Left = Me.Shape1.Left + l3
        Case Is >= 0
'            Debug.Print "YOU"
            Me.Shape1.Left = Me.Shape1.Left + l3
            Sleep (l2)
            Me.Shape1.Left = Me.Shape1.Left - l3
        Case Else
'            Debug.Print l1
    End Select
    
    Me.Refresh
    
End Sub

Private Sub SMove(ByRef Sp1 As Shape, strTmp1 As String, lTime As Long)
'
    Dim llength As Long
    llength = lTime / 10
    
    Select Case strTmp1
        Case "left"
            Sp1.Left = Sp1.Left - llength
            Sleep (lTime)
            Sp1.Left = Sp1.Left + llength
        Case "right"
            Sp1.Left = Sp1.Left + llength
            Sleep (lTime)
            Sp1.Left = Sp1.Left - llength
        Case "top"
            Sp1.Top = Sp1.Top - llength
            Sleep (lTime)
            Sp1.Top = Sp1.Top + llength
        Case "buttom"
            Sp1.Top = Sp1.Top + llength
            Sleep (lTime)
            Sp1.Top = Sp1.Top - llength
        Case Else
        
    End Select
    
End Sub

'----------------------------------------------------------------
'检查此时段是我方可以战斗了,还是敌方战斗。
Private Sub checkWhoAttack()
'
    If boolWAttackNow = True Then
        Exit Sub
    End If
    
    
    If boolALLWDone = True Or boolWDone = True Then '表示我方还处在战斗当中
        Exit Sub
    ElseIf boolDDone = True Then    '敌方进入战斗状态
        strStateText = ""
        Call refreshState
        Call closeAllButtom
        Exit Sub
    End If
    
    If DMinJie > WMinJie Then '战斗开始界面,判断哪一方的敏捷度高,哪一方开始攻击。
        boolD = True
        Me.Shape4.Visible = False
        intCurrentW = 0
        boolDDone = True
    Else
        boolW = True
        Me.Shape4.Visible = True
        boolALLWDone = True
        boolWDone = False
        Call openAllButtom
    End If
    
End Sub

Private Sub initData1()
'
    DMinJie = 1
    WMinJie = 5
    boolD = False
    boolW = False
    boolWDone = False
    boolDDone = False
    boolALLWDone = False
    boolWAttackNow = False
    Call closeAllButtom
    
End Sub

Private Sub initData2()
'
    Dim i1 As Integer
    ReDim WElements(3)
    
    ReDim eWFang(3)
    
    For i1 = 0 To UBound(eWFang) - 1
        With eWFang(i1)
            .intHP = 1000
            .intHPC = 1000
            .intSP = 500
            .intSPC = 500
            .strName = "我方卡片:" + CStr(i1)
        End With
    Next i1
    
End Sub

Private Sub FAttackW(intCurrentW1 As Integer, strAttack As String)
'
    
    WElements(intCurrentW1).strType = strAttack
    
    Select Case strAttack
        Case "GONGJI"
            WElements(intCurrentW1).intModel = 0
            strStateText = strStateText + "Shape:" + CStr(intCurrentW1) + ", " + strAttack + vbCrLf
        Case Else
        
    End Select
    boolWDone = True
    
    
End Sub

'-----------------------------------------------
'判断我方的所有队员是否全都攻击完毕,如没有攻击完毕,则进入下个队员的动作选择。
Private Sub updateAttackW()
'
    If boolWDone = True Then
        intCurrentW = intCurrentW + 1
        If intCurrentW > 2 Then
            boolWDone = False
            Me.Shape4.Visible = False
            boolWAttackNow = True
            boolALLWDone = False
            Exit Sub
        End If
        Me.Shape4.Left = Me.Shape2(intCurrentW).Left
        Call openAllButtom
        boolWDone = False
    End If
    
End Sub

Private Sub refreshState()
'
    Me.Text1.Text = ""
    strStateText = strStateText + vbCrLf + "intCurrentW:" + CStr(intCurrentW) + vbCrLf
    
    Me.Text1.Text = strStateText
    
End Sub

Private Sub closeAllButtom()
'
    Dim i1 As Integer
    
    For i1 = 0 To Me.Command1.UBound
        Me.Command1(i1).Enabled = False
        
    Next i1
End Sub

Private Sub openAllButtom()
'
    Dim i1 As Integer
    
    For i1 = 0 To Me.Command1.UBound
        Me.Command1(i1).Enabled = True
        
    Next i1
End Sub

Private Sub fightNowW()
'
    Dim i1 As Integer
'    If boolWAttackNow = True Then
'        MsgBox "开始战斗动画的播放"
'        boolWAttackNow = False
'        Me.Timer1.Enabled = False
'    End If
    
    If boolWAttackNow = False Then
        Exit Sub
    End If
    
'    MsgBox "开始战斗动画的播放"
    strStateText = strStateText + "开始战斗动画的播放" + vbCrLf
    boolWAttackNow = False
    Me.Timer1.Enabled = False
    Call refreshState
    
    For i1 = 0 To UBound(WElements) - 1
        Call attackShape(Shape2(i1))
    Next i1
    
    strStateText = strStateText + "我方战斗完成"
    Call refreshState
    Me.Timer1.Enabled = True
    boolDDone = True
End Sub

Private Sub attackShape(ByRef Shape1 As Shape)
'
    
    Shape1.Top = Shape1.Top - (Shape1.Height / 2)
'    Sleep (1000)
    
    Call AdrawLineW(Shape1.Top, Shape1.Left, Shape1.Width)   '画出攻击线
    
'    Sleep (1000)
    Shape1.Top = Shape1.Top + (Shape1.Height / 2)
    Me.Line1.Visible = False
    
End Sub

Private Sub AdrawLineW(intY As Integer, intX As Integer, intWidth As Integer)
'
    Me.Line1.Visible = True
    With Me.Line1
        .X1 = intX + (intWidth / 2)
        .X2 = Me.Shape1.Left + (Me.Shape1.Width / 2)
        .Y1 = intY
        .Y2 = Me.Shape1.Top + Me.Shape1.Height
    End With
    Me.Line1.BorderWidth = 5
    Me.Refresh
    Sleep (1000)
'    Me.Line1.Visible = False

End Sub

编程技巧