Visual_Basic 板


LINE

Imports System.Text 'Encode會用到 Public Class MainForm #Region "Variables Declaration" '儲存狀態用變數 Public UserName As String '使用者名稱 '遊戲用變數 Private createTime As Integer '要產生地鼠的剩餘時間 Private userColor As Color '玩家和按鈕顏色 Private score As Integer '玩家分數 #End Region #Region "Game Functions" Private Delegate Sub DelegateInitialize() '初始化遊戲狀態 Public Sub Initialize() '初始化 score = 0 Label_UserScoreNum.Text = "0" '將所有洞清空 Dim i As Integer For i = 0 To Panel_GameArea.Controls.Count - 1 If Panel_GameArea.Controls(i).Name.Substring(0, 4) = "Hole" Then Dim tmpPic As PictureBox = Panel_GameArea.Controls(i) tmpPic.Image = ImageList_Rat.Images.Item(0) tmpPic.Tag = 0 End If Next End Sub '開始計時 Private Delegate Sub DelegateStartTimer() Private Sub StartTimer() Label_Time.Text = "20" Timer_Game.Enabled = True Timer_Thief.Enabled = True Timer_elag.Enabled = True End Sub '停止計時 Private Sub StopTimer() Label_Time.Text = "-" Timer_Game.Enabled = False '將所有洞清空 Dim i As Integer For i = 0 To Panel_GameArea.Controls.Count - 1 If Panel_GameArea.Controls(i).Name.Substring(0, 4) = "Hole" Then Dim tmpPic As PictureBox = Panel_GameArea.Controls(i) tmpPic.Image = ImageList_Rat.Images.Item(0) tmpPic.Tag = 0 End If Next End Sub '每秒遊戲計時以及隨機產生地鼠 Private Sub Timer_Game_Tick(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Timer_Game.Tick UpdateRatLiveTime() '更新每個地鼠存活時間 CreateRandomRat() '邀請方產生地鼠 CheckGame() '檢查遊戲是否結束 End Sub Private Sub UpdateRatLiveTime() '每秒遞減每個地鼠的剩餘時間,若為0則變為空洞 If Integer.Parse(Label_Time.Text) <> 0 Then Dim i As Integer For i = 0 To Panel_GameArea.Controls.Count - 1 If Panel_GameArea.Controls(i).Name.Substring(0, 4) = "Hole" Then Dim tmpPic As PictureBox = Panel_GameArea.Controls(i) If tmpPic.Tag <> 0 Then tmpPic.Tag -= 1 Else tmpPic.Image = ImageList_Rat.Images.Item(0) tmpPic.Refresh() End If End If Next Label_Time.Text = (Integer.Parse(Label_Time.Text) - 1).ToString ElseIf Integer.Parse(Label_Time.Text) = 0 Then StopTimer() End If End Sub '受邀者產生地鼠 Private Sub CreateRat(ByVal CreateName As String) Dim i As Integer For i = 0 To Panel_GameArea.Controls.Count - 1 If Panel_GameArea.Controls(i).Name = CreateName Then Dim tmpPic As PictureBox = Panel_GameArea.Controls(i) tmpPic.Image = My.Resources.peace tmpPic.Refresh() tmpPic.Tag = 3 ElseIf Panel_GameArea.Controls(i).Name = CreateName Then Dim tmpPic2 As PictureBox = Panel_GameArea.Controls(i) tmpPic2.Image = My.Resources.elag tmpPic2.Refresh() tmpPic2.Tag = 3 Exit For End If Next End Sub Private Sub CreateRandomRat() Dim index As Integer If createTime = 0 Then Randomize() createTime = Rnd() * 5 Else createTime -= 1 End If If createTime <> 0 Then While True Randomize() index = Rnd() * 4 Dim tmpPic As PictureBox = Panel_GameArea.Controls(index) Dim tmpPic2 As PictureBox = Panel_GameArea.Controls(index) '假如是空洞,才產生地鼠 If tmpPic.Tag = 0 Then tmpPic.Image = My.Resources.peace tmpPic.Refresh() tmpPic.Tag = 1 Else : tmpPic2.Tag = 0 tmpPic2.Image = My.Resources.elag tmpPic2.Refresh() tmpPic2.Tag = 0 Exit While End If End While End If End Sub '檢查遊戲是否結束 ' Private Sub CheckGame() If Integer.Parse(Label_Time.Text) = 0 Then StopTimer() MsgBox("您的成績:" + score.ToString) End If End Sub '當玩家打中地鼠時事件 Public Sub ratClick(ByVal sender As Object, ByVal e As System.EventArgs) Handles Hole1.Click, Hole2.Click, _ Hole3.Click, Hole4.Click, Hole5.Click, Hole6.Click, Hole7.Click, Hole8.Click, Hole9.Click Dim tmpPic As PictureBox = sender Dim tmpPic2 As PictureBox = sender '以地鼠的時間標籤來判斷 (也可以用圖片判斷) If tmpPic.Tag <> 0 Then '加分 score += 50 Label_UserScoreNum.Text = score.ToString '清空地洞 tmpPic.Tag = 0 tmpPic.Image = ImageList_Rat.Images.Item(0) ElseIf tmpPic2.Tag <> 0 Then '加分 score -= 50 Label_UserScoreNum.Text = score.ToString '清空地洞 tmpPic2.Tag = 0 tmpPic2.Image = ImageList_Rat.Images.Item(0) End If End Sub '遊戲結束,回覆之前狀態 Private Sub EndGame() score = 0 Label_UserScoreNum.Text = "0" StopTimer() End Sub #End Region '當遊戲視窗載入便開始遊戲 Private Sub MainForm_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Initialize() StartTimer() End Sub End Class 我自己改後,還是沒有辦法有這樣的效果,反而是只有小偷的圖片是加分的,是哪裡改錯 嗎?也謝謝之前的兩位大大的回答了! --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 59.115.103.179
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Visual_Basic/M.1464155366.A.3C4.html
1F:→ MOONRAKER: 改了tag當然別的地方也要改阿 05/25 14:18
2F:→ MOONRAKER: 計分的地方要對應tag阿 你去游泳池會只脫上衣嗎 05/25 14:19







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Tech_Job站內搜尋

TOP