欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python pygame實(shí)現(xiàn)五子棋小游戲

 更新時(shí)間:2020年10月26日 08:50:50   作者:披星戴月觀日  
這篇文章主要為大家詳細(xì)介紹了python pygame實(shí)現(xiàn)五子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

今天學(xué)習(xí)了如何使用pygame來(lái)制作小游戲,下面是五子棋的代碼,我的理解都寫(xiě)在注釋里了

import pygame
# 導(dǎo)入pygame模塊
print(pygame.ver)
# 檢查pygame的版本,檢查pygame有沒(méi)有導(dǎo)入成功

EMPTY = 0
BLACK = 1
WHITE = 2
# 定義三個(gè)常量函數(shù),用來(lái)表示白棋,黑棋,以及 空

black_color = [0, 0, 0]
# 定義黑色(黑棋用,畫(huà)棋盤(pán))
white_color = [255, 255, 255]
# 定義白色(白棋用)

# 定義棋盤(pán)這個(gè)類(lèi)
class RenjuBoard(object):

 def __init__(self):
 # self._board = board = [[EMPTY] * 15 for _ in range(15)]
 # 將棋盤(pán)每一個(gè)交叉點(diǎn)都看作列表的一個(gè)元素位,一共有15*15共225個(gè)元素
 self._board = [[]] * 15
 self.reset()
 #重置棋盤(pán)
 def reset(self):
 for row in range(len(self._board)):
 self._board[row] = [EMPTY] * 15
 #定義棋盤(pán)上的下棋函數(shù),row表示行,col表示列,is_black表示判斷當(dāng)前點(diǎn)位該下黑棋,還是白棋
 def move(self, row, col, is_black):
 if self._board[row][col] == EMPTY:
 self._board[row][col] = BLACK if is_black else WHITE
 return True
 return False
 # 給棋盤(pán)定義一個(gè)函數(shù)將自己在screen上面畫(huà)出來(lái),使用pygame.draw()函數(shù)。并且順便將下了的棋子也畫(huà)出來(lái)
 def draw(self, screen):
 for h in range(1, 16):
 pygame.draw.line(screen, black_color,
  [40, h * 40], [600, h * 40], 1)
 pygame.draw.line(screen, black_color,
 # 給棋盤(pán)加一個(gè)外框,使美觀
 pygame.draw.rect(screen, black_color, [36, 36, 568, 568], 3)
 # 在棋盤(pán)上標(biāo)出,天元以及另外4個(gè)特殊點(diǎn)位
 pygame.draw.circle(screen, black_color, [320, 320], 5, 0)
 pygame.draw.circle(screen, black_color, [160, 160], 3, 0)
 pygame.draw.circle(screen, black_color, [160, 480], 3, 0)
 pygame.draw.circle(screen, black_color, [480, 160], 3, 0)
 pygame.draw.circle(screen, black_color, [480, 480], 3, 0)
 #做2次for循環(huán)取得棋盤(pán)上所有交叉點(diǎn)的坐標(biāo)
 for row in range(len(self._board)):
 for col in range(len(self._board[row])):
 # 將下在棋盤(pán)上的棋子畫(huà)出來(lái)
 if self._board[row][col] != EMPTY:
  ccolor = black_color \
  if self._board[row][col] == BLACK else white_color
  # 取得這個(gè)交叉點(diǎn)下的棋子的顏色,并將棋子畫(huà)出來(lái)
  pos = [40 * (col + 1), 40 * (row + 1)]
  # 畫(huà)出棋子
  pygame.draw.circle(screen, ccolor, pos, 18, 0)

# 定義函數(shù),傳入當(dāng)前棋盤(pán)上的棋子列表,輸出結(jié)果,不管黑棋白棋勝,都是傳回False,未出結(jié)果則為T(mén)rue
def is_win(board):
 for n in range(15):
 # 判斷垂直方向勝利
 flag = 0
 # flag是一個(gè)標(biāo)簽,表示是否有連續(xù)以上五個(gè)相同顏色的棋子
 for b in board._board:
 if b[n] == 1:
 flag += 1
 if flag == 5:
  print('黑棋勝')
  return False
 else:
 # else表示此時(shí)沒(méi)有連續(xù)相同的棋子,標(biāo)簽flag重置為0
 flag = 0

 flag = 0
 for b in board._board:
 if b[n] == 2:
 flag += 1
 if flag == 5:
  print('白棋勝')
  return False
 else:
 flag = 0

 # 判斷水平方向勝利
 flag = 0
 for b in board._board[n]:
 if b == 1:
 flag += 1
 if flag == 5:
  print('黑棋勝')
  return False
 else:
 flag = 0

 flag = 0
 for b in board._board[n]:
 if b == 2:
 flag += 1
 if flag == 5:
  print('白棋勝')
  return False
 else:
 flag = 0

 # 判斷正斜方向勝利

 for x in range(4, 25):
 flag = 0
 for i,b in enumerate(board._board):
 if 14 >= x - i >= 0 and b[x - i] == 1:
  flag += 1
  if flag == 5:
  print('黑棋勝')
  return False
 else:
  flag = 0

 for x in range(4, 25):
 flag = 0
 for i,b in enumerate(board._board):
 if 14 >= x - i >= 0 and b[x - i] == 2:
  flag += 1
  if flag == 5:
  print('白棋勝')
  return False
 else:
  flag = 0

 #判斷反斜方向勝利
 for x in range(11, -11, -1):
 flag = 0
 for i,b in enumerate(board._board):
 if 0 <= x + i <= 14 and b[x + i] == 1:
  flag += 1
  if flag == 5:
  print('黑棋勝')
  return False
 else:
  flag = 0

 for x in range(11, -11, -1):
 flag = 0
 for i,b in enumerate(board._board):
 if 0 <= x + i <= 14 and b[x + i] == 2:
  flag += 1
  if flag == 5:
  print('白棋勝')
  return False
 else:
  flag = 0

 return True


def main():
 # 創(chuàng)建棋盤(pán)對(duì)象
 board = RenjuBoard()
 # 用于判斷是下黑棋還是白棋
 is_black = True
 # pygame初始化函數(shù),固定寫(xiě)法
 pygame.init()
 pygame.display.set_caption('五子棋') # 改標(biāo)題
 # pygame.display.set_mode()表示建立個(gè)窗口,左上角為坐標(biāo)原點(diǎn),往右為x正向,往下為y軸正向
 screen = pygame.display.set_mode((640,640))
 # 給窗口填充顏色,顏色用三原色數(shù)字列表表示
 screen.fill([125,95,24])
 board.draw(screen) # 給棋盤(pán)類(lèi)發(fā)命令,調(diào)用draw()函數(shù)將棋盤(pán)畫(huà)出來(lái)
 pygame.display.flip() # 刷新窗口顯示

 running = True
 # while 主循環(huán)的標(biāo)簽,以便跳出循環(huán)
 while running:
 # 遍歷建立窗口后發(fā)生的所有事件,固定寫(xiě)法
 for event in pygame.event.get():
 # 根據(jù)事件的類(lèi)型,進(jìn)行判斷
 if event.type == pygame.QUIT:
 running = False

 elif event.type == pygame.KEYUP:
 pass
 # pygame.MOUSEBUTTONDOWN表示鼠標(biāo)的鍵被按下
 elif event.type == pygame.MOUSEBUTTONDOWN and \
  event.button == 1:# button表示鼠標(biāo)左鍵
 x, y = event.pos # 拿到鼠標(biāo)當(dāng)前在窗口上的位置坐標(biāo)
 # 將鼠標(biāo)的(x, y)窗口坐標(biāo),轉(zhuǎn)化換為棋盤(pán)上的坐標(biāo)
 row = round((y - 40) / 40) 
 col = round((x - 40) / 40)
 if board.move(row, col, is_black):
  is_black = not is_black
  screen.fill([125, 95, 24])
  board.draw(screen)
  pygame.display.flip()
  # 調(diào)用判斷勝負(fù)函數(shù)
  if not is_win(board):
  #break
  running = False
  # 這里我有個(gè)bug沒(méi)找到解決辦法,就是判斷出勝負(fù)后,使用break跳出事件遍歷的for循環(huán),但是老是不能跳出來(lái),導(dǎo)致勝負(fù)分出來(lái)了還可以繼續(xù)下,這里我采用判斷勝負(fù)后就將running標(biāo)簽賦值為False,跳出主循環(huán),但是這樣棋盤(pán)的窗口也沒(méi)了。明天再找找bug在哪

 pygame.quit()

if __name__ == '__main__':
 main()

更多關(guān)于python游戲的精彩文章請(qǐng)點(diǎn)擊查看以下專(zhuān)題:

python俄羅斯方塊游戲集合

python經(jīng)典小游戲匯總

python微信跳一跳游戲集合

更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專(zhuān)題,分享給大家:

C++經(jīng)典小游戲匯總

JavaScript經(jīng)典游戲 玩不停

java經(jīng)典小游戲匯總

javascript經(jīng)典小游戲匯總

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • FP-growth算法發(fā)現(xiàn)頻繁項(xiàng)集——發(fā)現(xiàn)頻繁項(xiàng)集

    FP-growth算法發(fā)現(xiàn)頻繁項(xiàng)集——發(fā)現(xiàn)頻繁項(xiàng)集

    常見(jiàn)的挖掘頻繁項(xiàng)集算法有兩類(lèi),一類(lèi)是Apriori算法,另一類(lèi)是FP-growth。Apriori通過(guò)不斷的構(gòu)造候選集、篩選候選集挖掘出頻繁項(xiàng)集,需要多次掃描原始數(shù)據(jù),當(dāng)原始數(shù)據(jù)較大時(shí),磁盤(pán)I/O次數(shù)太多,效率比較低下
    2021-06-06
  • Python數(shù)據(jù)可視化之Seaborn的使用詳解

    Python數(shù)據(jù)可視化之Seaborn的使用詳解

    Seaborn庫(kù)是python中基于matplotlib庫(kù)的可視化工具庫(kù),通過(guò)sns我們可以更方便地繪制出更美觀的圖表。本文將分享python基于Seaborn庫(kù)的一系列繪圖操作,感興趣的可以了解一下
    2022-04-04
  • Python字符串查找基本操作代碼案例

    Python字符串查找基本操作代碼案例

    這篇文章主要介紹了Python字符串查找基本操作代碼案例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Android應(yīng)用開(kāi)發(fā)中Action bar編寫(xiě)的入門(mén)教程

    Android應(yīng)用開(kāi)發(fā)中Action bar編寫(xiě)的入門(mén)教程

    這篇文章主要介紹了Android應(yīng)用開(kāi)發(fā)中ActionBar編寫(xiě)的入門(mén)教程,Action Bar可以實(shí)現(xiàn)的功能很多,比如導(dǎo)航菜單和標(biāo)簽頁(yè)切換等,需要的朋友可以參考下
    2016-02-02
  • python使用pandas實(shí)現(xiàn)篩選功能方式

    python使用pandas實(shí)現(xiàn)篩選功能方式

    在數(shù)據(jù)分析的過(guò)程中通常要對(duì)數(shù)據(jù)進(jìn)行清洗與處理,而其中比較重要和常見(jiàn)的操作就有對(duì)數(shù)據(jù)進(jìn)行篩選與查詢(xún),下面這篇文章主要給大家介紹了關(guān)于python使用pandas實(shí)現(xiàn)篩選功能方式的相關(guān)資料,需要的朋友可以參考下
    2022-06-06
  • Python基于輾轉(zhuǎn)相除法求解最大公約數(shù)的方法示例

    Python基于輾轉(zhuǎn)相除法求解最大公約數(shù)的方法示例

    這篇文章主要介紹了Python基于輾轉(zhuǎn)相除法求解最大公約數(shù)的方法,結(jié)合實(shí)例形式分析了Python使用輾轉(zhuǎn)相除法求解最大公約數(shù)的實(shí)現(xiàn)方法與優(yōu)化操作技巧,需要的朋友可以參考下
    2018-04-04
  • python迭代器,生成器詳解

    python迭代器,生成器詳解

    這篇文章主要介紹了Python中的迭代器和生成器,涉及到Python中很多重要的特性,小編覺(jué)得這篇文章寫(xiě)的還不錯(cuò),需要的朋友可以參考下
    2021-10-10
  • linecache模塊加載和緩存文件內(nèi)容詳解

    linecache模塊加載和緩存文件內(nèi)容詳解

    這篇文章主要介紹了linecache模塊加載和緩存文件內(nèi)容詳解,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • pytorch之深度神經(jīng)網(wǎng)絡(luò)概念全面整理

    pytorch之深度神經(jīng)網(wǎng)絡(luò)概念全面整理

    這篇文章主要介紹了pytorch之深度神經(jīng)網(wǎng)絡(luò)概念,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-09-09
  • pyqt5制作登錄窗口的詳細(xì)過(guò)程

    pyqt5制作登錄窗口的詳細(xì)過(guò)程

    這篇文章主要介紹了pyqt5制作登錄窗口的詳細(xì)過(guò)程,本文通過(guò)實(shí)例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10

最新評(píng)論