亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? winmine.cls

?? visual basic課程設(shè)計案例精編
?? CLS
?? 第 1 頁 / 共 3 頁
字號:
VERSION 1.0 CLASS
BEGIN
  MultiUse = 0   'False
  Persistable = 0  'NotPersistable
  DataBindingBehavior = 0  'vbNone
  DataSourceBehavior  = 0  'vbNone
  MTSTransactionMode  = 0  'NotAnMTSObject
END
Attribute VB_Name = "clsWinMine"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = True
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
Option Explicit

' 設(shè)置鼠標左鍵常數(shù)
Private Const LEFT_BUTTON As Byte = 1

' 標明空格的標記
Private Const NONE As Byte = 0
' 標明帶有地雷的方格的標記
Private Const MINE As Byte = 243
' 標明已經(jīng)被打開的方格的標記
Private Const BEEN As Byte = 244
' 標明已經(jīng)被標定為有地雷的方格的標記
Private Const FLAGGED As Byte = 2
' 標明不明確方格的標記
Private Const QUESTION As Byte = 1

' 最大、最小的地雷數(shù)、行數(shù)、列數(shù)
Private Const MIN_MINES As Byte = 10
Private Const MAX_MINES As Byte = 99
Private Const MIN_ROWS As Integer = 8
Private Const MAX_ROWS As Integer = 24
Private Const MIN_COLS As Integer = 8
Private Const MAX_COLS As Integer = 36

' 方格的寬度
Private Const mintButtonWidth As Byte = 16
' 方格的高度
Private Const mintButtonHeight As Byte = 16

' 現(xiàn)在游戲難度的地雷總數(shù)
Private mbytNumMines As Byte
' 被正確標明為帶有地雷的方格的數(shù)目
Private mbytCorrectHits As Byte
' 已被標明的空格總數(shù)(包括錯誤標記的)
Private mbytTotalHits As Byte

' 現(xiàn)在游戲難度的行數(shù)和列數(shù)
Private mintRows As Integer
Private mintCols As Integer

' 正在被執(zhí)行的行數(shù)和列數(shù)
Private mintRow As Integer
Private mintCol As Integer

' 表明一個新游戲的時間
Public mblnNewGame As Boolean
' 表明一個鼠標點擊動作正在執(zhí)行
Private mblnHitTestBegun As Boolean
' 控制總顯示格數(shù)的變量
Private mfrmDisplay As Form
Private mbytMineStatus() As Byte

' 動態(tài)的2D隊列,用來跟蹤一個方格的現(xiàn)在狀態(tài)
' 是否被標記,或者是否被標記正確
Private mbytMarked() As Byte

' 動態(tài)的2D隊列,用來跟蹤一個含有地雷的方格的行數(shù)和列數(shù)
Private mbytMineLocations() As Byte

Private mcolWrongLocations As New Collection

Public Sub BeginHitTest(intButton As Integer, intX As Single, intY As Single)
    
    ' 如果現(xiàn)在的游戲結(jié)束,開始新的游戲
    ' 當?shù)乩讌^(qū)被點擊
    If mblnNewGame Then
        NewGame
    End If
    
    ' 表明鼠標點擊動作正在執(zhí)行
    mblnHitTestBegun = True
    
    ' 通過鼠標的坐標確定實際方格的坐標
    intX = Int(intX / mintButtonWidth)
    intY = Int(intY / mintButtonHeight)

    ' 如果坐標位于游戲界面外邊,則取消
    If intX >= mintCols Or intY >= mintRows Or intX < 0 Or intY < 0 Then
        Exit Sub
    End If

    ' 通過柵格坐標確定空格坐標
    mintCol = intX * mintButtonWidth
    mintRow = intY * mintButtonHeight

    ' 如果方格已點開,則取消
    If mbytMineStatus(intY, intX) >= BEEN Then Exit Sub

    Dim blnLeftDown As Boolean
    blnLeftDown = (intButton And LEFT_BUTTON) > 0

    ' 如果鼠標左鍵點擊...
    If blnLeftDown Then
        
        ' 如果方格已經(jīng)標記了,不能打開,則取消
        If mbytMarked(intY, intX) >= FLAGGED Then Exit Sub
        
        ' 臨時圖形顯示控制
        If mbytMarked(intY, intX) = QUESTION Then
            mfrmDisplay.imgPressed.Visible = False
            mfrmDisplay.imgQsPressed.Visible = False
            mfrmDisplay.imgQsPressed.Left = mintCol
            mfrmDisplay.imgQsPressed.Top = mintRow
            mfrmDisplay.imgQsPressed.Visible = True
        Else
            mfrmDisplay.imgQsPressed.Visible = False
            mfrmDisplay.imgPressed.Visible = False
            mfrmDisplay.imgPressed.Left = mintCol
            mfrmDisplay.imgPressed.Top = mintRow
            mfrmDisplay.imgPressed.Visible = True
        End If
        
    Else    '如果鼠標右鍵點擊....
        
        Dim Msg As String
        Dim CRLF As String

        CRLF = Chr$(13) & Chr$(10)
        
        Select Case mbytMarked(intY, intX)
    
            Case NONE:      ' 如果所有的空格都被標注...
                            If mbytTotalHits = mbytNumMines Then
                                Msg = "Can't Mark Any More Mines!" & CRLF
                                Msg = Msg & "One or more Mines have been wrongly marked." & CRLF
                                Msg = Msg & "UnMark one or more mines with the right mouse button."
                                    
                                MsgBox Msg, vbCritical, "WinMine: Error!"
                                Exit Sub
                            End If
                                    
                            ' 如果沒有標注,顯示一個標記表示標注
                            mfrmDisplay.PaintPicture mfrmDisplay.imgFlag, mintCol, mintRow
                            ' 增加已被標注的方格數(shù)量
                            mbytTotalHits = mbytTotalHits + 1

                            ' 更新剩余地雷的顯示
                            mfrmDisplay.lblMinesLeft = "Mines Left : " & mbytNumMines - mbytTotalHits
                            
                            ' 如果正確標記
                            If mbytMineStatus(intY, intX) = MINE Then
                                mbytCorrectHits = mbytCorrectHits + 1
                                mbytMarked(intY, intX) = FLAGGED
                            Else    ' 如果錯誤標記
                                Dim objCoords As New clsCoords
                                    
                                ' 在新文件中存儲錯誤標記的坐標
                                objCoords.mintX = intX
                                objCoords.mintY = intY
                                    
                                ' 將它加入到收集
                                mcolWrongLocations.Add objCoords
                                
                                ' 存儲被錯誤標注的方格的總數(shù)
                                mbytMarked(intY, intX) = mbytTotalHits - mbytCorrectHits + 2
                            End If
                                
                            ' 如果所有的地雷都被正確標注...
                            If mbytCorrectHits = mbytNumMines Then
                                Msg = "Congratulations!" & CRLF
                                Msg = Msg & "You have won." & CRLF
                                
                                MsgBox Msg, vbInformation, "WinMine"
                                
                                ' 準備新游戲
                                mblnNewGame = True
                            End If
            
            Case QUESTION:  ' 如果模糊標注,則不標注
                            mbytMarked(intY, intX) = NONE
                            ' 顯示原始方格
                            mfrmDisplay.PaintPicture mfrmDisplay.imgButton, mintCol, mintRow

            Case Else:      ' 如果以前用“紅旗”標注,則更改為空標注
                            ' 顯示用“?”標注的方格
                            mfrmDisplay.PaintPicture mfrmDisplay.imgQuestion, mintCol, mintRow
                            
                            ' 減少已標注方格的總數(shù)
                            mbytTotalHits = mbytTotalHits - 1
                                
                            ' 更新剩余地雷的顯示
                            mfrmDisplay.lblMinesLeft = "Mines Left : " & mbytNumMines - mbytTotalHits
                            
                            ' 如果以前標注的方格含有地雷
                            If mbytMineStatus(intY, intX) = MINE Then
                                ' 同時減少正確標注的方格數(shù)目
                                mbytCorrectHits = mbytCorrectHits - 1
                            Else    ' 如果是錯誤的標注方格
                                ' 取消這個錯誤的坐標
                                mcolWrongLocations.Remove mbytMarked(intY, intX) - 2
                                    
                                Dim intXwm As Integer   ' 錯誤地點的X坐標
                                Dim intYwm As Integer   ' 錯誤地點的Y坐標
                                Dim i As Integer        ' 循環(huán)計算
                                    
                                ' 更新其它錯誤標注的坐標指數(shù)
                                For i = mbytMarked(intY, intX) - 2 To mcolWrongLocations.Count
                                    intXwm = mcolWrongLocations(i).mintX
                                    intYwm = mcolWrongLocations(i).mintY
                                    mbytMarked(intYwm, intXwm) = mbytMarked(intYwm, intXwm) - 1
                                Next
                                    
                            End If

                            mbytMarked(intY, intX) = QUESTION
                
        End Select
    
    End If

End Sub

Public Sub EndHitTest(intButton As Integer, intX As Single, intY As Single)
    
    ' 如果正在執(zhí)行一個鼠標的點擊動作.
    If mblnHitTestBegun Then
        ' 重新設(shè)置標記
        mblnHitTestBegun = False
    Else
        ' 如果不是,則取消
        ' 當鼠標被點擊
        Exit Sub
    End If
    
    Dim blnLeftDown As Boolean
    blnLeftDown = (intButton And LEFT_BUTTON) > 0

    '  如果鼠標左鍵被點擊
    If blnLeftDown Then
        
        '通過鼠標的坐標確定方格的坐標
        intX = Int(intX / mintButtonWidth)
        intY = Int(intY / mintButtonHeight)

        ' 如果坐標位于游戲界面外,則取消
        If intX >= mintCols Or intY >= mintRows Or intX < 0 Or intY < 0 Then
            Exit Sub
        End If

        ' 如果當前點擊的方格已被標注,則取消
        If mbytMarked(intY, intX) >= FLAGGED Then Exit Sub

        ' 通過鼠標坐標確定方格坐標
        intX = mintCol \ mintButtonWidth
        intY = mintRow \ mintButtonHeight
    
        If mbytMarked(intY, intX) = QUESTION Then
            mfrmDisplay.imgQsPressed.Visible = False
        Else
            mfrmDisplay.imgPressed.Visible = False
        End If
        
        Select Case mbytMineStatus(intY, intX)

            Case Is >= BEEN:    ' 如果當前的方格已被打開,則取消
                                Exit Sub
            
            Case NONE:  ' 如果當前的方格是空的,則打開周圍所有的空方格
                        OpenBlanks intX, intY
                        
            Case MINE:  ' 如果當前的空格含有地雷,則引爆地雷
                        Dim intXm As Integer        ' 地雷的X坐標
                        Dim intYm As Integer        ' 地雷的Y坐標
                        Dim vntCoord As Variant     ' 每個循壞使用的變量
                        Dim i As Integer            ' 循環(huán)計數(shù)
                
                        ' 展示所有包含地雷的方格
                        For i = 0 To mbytNumMines - 1
                            
                            intYm = mbytMineLocations(i, 0)
                            intXm = mbytMineLocations(i, 1)

                            If mbytMarked(intYm, intXm) < FLAGGED Then
                                mfrmDisplay.PaintPicture mfrmDisplay.imgMine, intXm * mintButtonWidth, intYm * mintButtonHeight
                            End If
                        
                        Next

                        ' 用一個爆炸的地雷顯示現(xiàn)在的方格
                        mfrmDisplay.PaintPicture mfrmDisplay.imgBlown, mintCol, mintRow
                        
                        ' 顯示所有被錯誤的確定為地雷的方格
                        For Each vntCoord In mcolWrongLocations

                            intYm = vntCoord.mintY
                            intXm = vntCoord.mintX

                            mfrmDisplay.PaintPicture mfrmDisplay.imgWrongMine, intXm * mintButtonWidth, intYm * mintButtonHeight
                        
                        Next
                        
                        ' 準備新游戲
                        mblnNewGame = True
                        

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av资源下载| 日本网站在线观看一区二区三区| 国产精品中文字幕日韩精品 | 国产精品色哟哟| 成人自拍视频在线| 一区视频在线播放| 一本大道av一区二区在线播放| 亚洲女女做受ⅹxx高潮| 欧美日本在线观看| 青青青爽久久午夜综合久久午夜| 日韩免费电影网站| 高清不卡一区二区| 亚洲人亚洲人成电影网站色| 日本电影欧美片| 丝瓜av网站精品一区二区| 制服丝袜日韩国产| 国产一区二区三区四| 国产精品久久久一本精品 | 91猫先生在线| 视频一区二区三区入口| 久久久久久久久99精品| 东方aⅴ免费观看久久av| 亚洲欧美日韩一区二区 | 一区二区三区小说| 5858s免费视频成人| 国产一区二区毛片| 亚洲精品你懂的| 欧美大片在线观看一区二区| 成人综合日日夜夜| 亚洲女人小视频在线观看| 欧美精品九九99久久| 粉嫩av一区二区三区| 亚洲成av人片在线观看无码| 国产亚洲欧美中文| 欧美精品三级在线观看| 高清不卡在线观看| 人人精品人人爱| 国产精品入口麻豆原神| 91精品福利在线一区二区三区| 国产白丝精品91爽爽久久| 偷拍自拍另类欧美| 亚洲三级久久久| 亚洲精品一区二区三区四区高清| 色综合久久中文字幕| 美腿丝袜亚洲综合| 亚洲欧美日韩在线播放| 国产日韩精品一区二区三区在线| 7777精品伊人久久久大香线蕉的 | 成人av网址在线| 蜜桃视频在线观看一区二区| 香蕉影视欧美成人| 久久午夜电影网| 日韩一级欧美一级| 欧美亚洲国产一区在线观看网站| 国产mv日韩mv欧美| 国产一区二区三区久久悠悠色av| 日韩电影一二三区| 亚洲午夜一二三区视频| 亚洲男人天堂一区| 成人欧美一区二区三区小说| 久久久综合精品| 精品国产伦一区二区三区观看方式 | 精品综合久久久久久8888| 亚洲成人av免费| 亚洲综合免费观看高清完整版 | 国产精品一卡二卡| 美女视频免费一区| 日韩av午夜在线观看| 伊人色综合久久天天| 亚洲免费观看高清完整版在线观看熊 | 欧美少妇bbb| 一本色道久久加勒比精品| 99精品欧美一区二区三区综合在线| 国产精品综合在线视频| 国内成人精品2018免费看| 蜜臂av日日欢夜夜爽一区| 日韩福利视频网| 日韩国产精品久久久久久亚洲| 亚洲国产乱码最新视频| 亚洲国产成人91porn| 亚洲一二三四区| 肉丝袜脚交视频一区二区| 日本美女一区二区| 欧美aaa在线| 国产原创一区二区三区| 国产精品自在欧美一区| 国产成人8x视频一区二区| 懂色av中文一区二区三区| 国产成人精品一区二区三区四区| 高清在线成人网| 一本大道久久a久久综合婷婷| 91免费小视频| 欧美亚洲高清一区| 在线不卡一区二区| xfplay精品久久| 日本一区二区综合亚洲| 亚洲欧美日本韩国| 亚洲成人免费影院| 美女诱惑一区二区| 国产一级精品在线| 成人看片黄a免费看在线| 国产在线精品一区在线观看麻豆| 在线观看不卡一区| 久久疯狂做爰流白浆xx| 久久国产免费看| 成人小视频免费在线观看| 91香蕉视频污| 欧美日韩电影在线播放| 91精品国产91综合久久蜜臀| 欧美日韩电影在线播放| 日韩精品一区二区三区视频在线观看| 欧美三级资源在线| 精品处破学生在线二十三| 亚洲电影在线播放| 99久久er热在这里只有精品15| 久久久亚洲欧洲日产国码αv| 日本不卡免费在线视频| 欧美日韩卡一卡二| 一区av在线播放| 99精品在线观看视频| 日本一区二区三区四区在线视频| 精品一区二区av| 欧美一区二区大片| 午夜精品视频在线观看| 在线观看视频一区二区欧美日韩| 中文av一区特黄| 成人av资源网站| 亚洲欧洲另类国产综合| 成人三级伦理片| 亚洲国产精品精华液2区45| 国产精品123区| 欧美电影免费观看高清完整版| 爽好久久久欧美精品| 欧美日韩在线播| 午夜精品爽啪视频| 6080yy午夜一二三区久久| 青青国产91久久久久久| 欧美一级日韩不卡播放免费| 爽爽淫人综合网网站| 日韩视频一区在线观看| 麻豆精品视频在线| 精品欧美一区二区三区精品久久| 久久国内精品自在自线400部| 欧美一区二区视频在线观看| 奇米在线7777在线精品| 精品久久久久久久久久久院品网| 激情文学综合网| 久久久99精品免费观看| 粉嫩高潮美女一区二区三区| 中文字幕一区二区三区在线观看| 99精品热视频| 午夜激情一区二区三区| 91精品婷婷国产综合久久性色| 日韩av网站免费在线| 精品少妇一区二区三区在线播放| 国产经典欧美精品| 一色屋精品亚洲香蕉网站| 欧美综合亚洲图片综合区| 亚洲www啪成人一区二区麻豆| 日韩免费电影一区| 成人午夜av电影| 亚洲午夜久久久久久久久电影院 | 久久亚洲精华国产精华液 | 欧美一级久久久| 国产精品一区二区在线播放| 亚洲欧洲国产专区| 欧美日韩国产123区| 日本特黄久久久高潮| 国产亚洲一区二区三区在线观看| 99国产精品久久久久久久久久久| 亚洲国产精品自拍| 精品国产伦理网| 色哟哟国产精品免费观看| 日韩国产欧美在线视频| 国产欧美日韩三级| 欧美男生操女生| 国产成人在线免费观看| 亚洲综合成人在线视频| 久久久亚洲欧洲日产国码αv| 99久久99久久久精品齐齐| 日韩不卡一区二区| 国产精品久久久久久久久果冻传媒 | 精品美女在线观看| 色综合久久88色综合天天6| 久久激情五月激情| 一区二区三区在线免费播放| 精品久久久久久久久久久久久久久久久 | 亚洲国产乱码最新视频| 久久精品亚洲麻豆av一区二区| 色综合久久久久| 国产精品456| 视频一区视频二区在线观看| 国产精品免费视频观看| 欧美日韩国产bt| 91亚洲精品乱码久久久久久蜜桃| 麻豆精品在线看| 亚洲第四色夜色| 1区2区3区精品视频| 久久久www成人免费无遮挡大片| 欧美性欧美巨大黑白大战|