python實(shí)現(xiàn)人人對(duì)戰(zhàn)的五子棋游戲
python五子棋之人人對(duì)戰(zhàn),供大家參考,具體內(nèi)容如下
checkerboard.py
from collections import namedtuple Chessman = namedtuple('Chessman', 'Name Value Color') Point = namedtuple('Point', 'X Y') BLACK_CHESSMAN = Chessman('黑子', 1, (45, 45, 45)) WHITE_CHESSMAN = Chessman('白子', 2, (219, 219, 219)) offset = [(1, 0), (0, 1), (1, 1), (1, -1)] class Checkerboard: ? ? def __init__(self, line_points): ? ? ? ? self._line_points = line_points ? ? ? ? self._checkerboard = [[0] * line_points for _ in range(line_points)] ? ? def _get_checkerboard(self): ? ? ? ? return self._checkerboard ? ? checkerboard = property(_get_checkerboard) ? ? # 判斷是否可落子 ? ? def can_drop(self, point): ? ? ? ? return self._checkerboard[point.Y][point.X] == 0 ? ? def drop(self, chessman, point): ? ? ? ? """ ? ? ? ? 落子 ? ? ? ? :param chessman: ? ? ? ? :param point:落子位置 ? ? ? ? :return:若該子落下之后即可獲勝,則返回獲勝方,否則返回 None ? ? ? ? """ ? ? ? ? print(f'{chessman.Name} ({point.X}, {point.Y})') ? ? ? ? self._checkerboard[point.Y][point.X] = chessman.Value ? ? ? ? if self._win(point): ? ? ? ? ? ? print(f'{chessman.Name}獲勝') ? ? ? ? ? ? return chessman ? ? # 判斷是否贏了 ? ? def _win(self, point): ? ? ? ? cur_value = self._checkerboard[point.Y][point.X] ? ? ? ? for os in offset: ? ? ? ? ? ? if self._get_count_on_direction(point, cur_value, os[0], os[1]): ? ? ? ? ? ? ? ? return True ? ? def _get_count_on_direction(self, point, value, x_offset, y_offset): ? ? ? ? count = 1 ? ? ? ? for step in range(1, 5): ? ? ? ? ? ? x = point.X + step * x_offset ? ? ? ? ? ? y = point.Y + step * y_offset ? ? ? ? ? ? if 0 <= x < self._line_points and 0 <= y < self._line_points and self._checkerboard[y][x] == value: ? ? ? ? ? ? ? ? count += 1 ? ? ? ? ? ? else: ? ? ? ? ? ? ? ? break ? ? ? ? for step in range(1, 5): ? ? ? ? ? ? x = point.X - step * x_offset ? ? ? ? ? ? y = point.Y - step * y_offset ? ? ? ? ? ? if 0 <= x < self._line_points and 0 <= y < self._line_points and self._checkerboard[y][x] == value: ? ? ? ? ? ? ? ? count += 1 ? ? ? ? ? ? else: ? ? ? ? ? ? ? ? break ? ? ? ? return count >= 5
ManAndMan.py
import sys import pygame from pygame.locals import * import pygame.gfxdraw from checkerboard import Checkerboard, BLACK_CHESSMAN, WHITE_CHESSMAN, Point SIZE = 30 ?# 棋盤(pán)每個(gè)點(diǎn)時(shí)間的間隔 Line_Points = 19 ?# 棋盤(pán)每行/每列點(diǎn)數(shù) Outer_Width = 20 ?# 棋盤(pán)外寬度 Border_Width = 4 ?# 邊框?qū)挾? Inside_Width = 4 ?# 邊框跟實(shí)際的棋盤(pán)之間的間隔 Border_Length = SIZE * (Line_Points - 1) + Inside_Width * 2 + Border_Width ?# 邊框線的長(zhǎng)度 Start_X = Start_Y = Outer_Width + int(Border_Width / 2) + Inside_Width ?# 網(wǎng)格線起點(diǎn)(左上角)坐標(biāo) SCREEN_HEIGHT = SIZE * (Line_Points - 1) + Outer_Width * 2 + Border_Width + Inside_Width * 2 ?# 游戲屏幕的高 SCREEN_WIDTH = SCREEN_HEIGHT + 200 ?# 游戲屏幕的寬 Stone_Radius = SIZE // 2 - 3 ?# 棋子半徑 Stone_Radius2 = SIZE // 2 + 3 Checkerboard_Color = (0xE3, 0x92, 0x65) ?# 棋盤(pán)顏色 BLACK_COLOR = (0, 0, 0) WHITE_COLOR = (255, 255, 255) RED_COLOR = (200, 30, 30) BLUE_COLOR = (30, 30, 200) BLACK_STONE_COLOR = (45, 45, 45) WHITE_STONE_COLOR = (219, 219, 219) RIGHT_INFO_POS_X = SCREEN_HEIGHT + Stone_Radius2 * 2 + 10 def print_text(screen, font, x, y, text, fcolor=(255, 255, 255)): ? ?imgText = font.render(text, True, fcolor) ? ?screen.blit(imgText, (x, y)) def main(): ? ?pygame.init() ? ?screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT)) ? ?pygame.display.set_caption('五子棋') ? ?font1 = pygame.font.SysFont('SimHei', 36) ? ?font2 = pygame.font.SysFont('SimHei', 72) ? ?fwidth, fheight = font2.size('黑方獲勝') ? ?checkerboard = Checkerboard(Line_Points) ? ?cur_runner = BLACK_CHESSMAN ? ?winner = None ? ?while True: ? ? ? ?for event in pygame.event.get(): ? ? ? ? ? ?if event.type == QUIT: ? ? ? ? ? ? ? ?sys.exit() ? ? ? ? ? ?elif event.type == KEYDOWN: ? ? ? ? ? ? ? ?if event.key == K_RETURN: ? ? ? ? ? ? ? ? ? ?if winner is not None: ? ? ? ? ? ? ? ? ? ? ? ?winner = None ? ? ? ? ? ? ? ? ? ? ? ?cur_runner = BLACK_CHESSMAN ? ? ? ? ? ? ? ? ? ? ? ?checkerboard = Checkerboard(Line_Points) ? ? ? ? ? ?elif event.type == MOUSEBUTTONDOWN: ? ? ? ? ? ? ? ?if winner is None: ? ? ? ? ? ? ? ? ? ?pressed_array = pygame.mouse.get_pressed() ? ? ? ? ? ? ? ? ? ?if pressed_array[0]: ? ? ? ? ? ? ? ? ? ? ? ?mouse_pos = pygame.mouse.get_pos() ? ? ? ? ? ? ? ? ? ? ? ?click_point = _get_clickpoint(mouse_pos) ? ? ? ? ? ? ? ? ? ? ? ?if click_point is not None: ? ? ? ? ? ? ? ? ? ? ? ? ? ?if checkerboard.can_drop(click_point): ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?winner = checkerboard.drop(cur_runner, click_point) ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?if cur_runner == BLACK_CHESSMAN: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?cur_runner = WHITE_CHESSMAN ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?else: ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?cur_runner = BLACK_CHESSMAN ? ? ? ? ? ? ? ? ? ? ? ?else: ? ? ? ? ? ? ? ? ? ? ? ? ? ?print('超出棋盤(pán)區(qū)域') ? ? ? ?# 畫(huà)棋盤(pán) ? ? ? ?_draw_checkerboard(screen) ? ? ? ?# 畫(huà)棋盤(pán)上已有的棋子 ? ? ? ?for i, row in enumerate(checkerboard.checkerboard): ? ? ? ? ? ?for j, cell in enumerate(row): ? ? ? ? ? ? ? ?if cell == BLACK_CHESSMAN.Value: ? ? ? ? ? ? ? ? ? ?_draw_chessman(screen, Point(j, i), BLACK_CHESSMAN.Color) ? ? ? ? ? ? ? ?elif cell == WHITE_CHESSMAN.Value: ? ? ? ? ? ? ? ? ? ?_draw_chessman(screen, Point(j, i), WHITE_CHESSMAN.Color) ? ? ? ?_draw_chessman_pos(screen, (SCREEN_HEIGHT + Stone_Radius2, Start_X + 20), BLACK_STONE_COLOR) ? ? ? ?_draw_chessman_pos(screen, (SCREEN_HEIGHT + Stone_Radius2, Start_X + 20 + Stone_Radius2 * 3), WHITE_STONE_COLOR) ? ? ? ?if winner: ? ? ? ? ? ?print_text(screen, font2, (SCREEN_WIDTH - fwidth)//2, (SCREEN_HEIGHT - fheight)//2, winner.Name + '獲勝', RED_COLOR) ? ? ? ?if cur_runner == BLACK_CHESSMAN: ? ? ? ? ? ?print_text(screen, font1, RIGHT_INFO_POS_X, Start_X, '獲勝' if winner else '落子中', BLUE_COLOR) ? ? ? ?else: ? ? ? ? ? ?print_text(screen, font1, RIGHT_INFO_POS_X, Start_X + Stone_Radius2 * 3, '獲勝' if winner else '落子中', BLUE_COLOR) ? ? ? ?pygame.display.flip() # 畫(huà)棋盤(pán) def _draw_checkerboard(screen): ? ?# 填充棋盤(pán)背景色 ? ?screen.fill(Checkerboard_Color) ? ?# 畫(huà)棋盤(pán)網(wǎng)格線外的邊框 ? ?pygame.draw.rect(screen, BLACK_COLOR, (Outer_Width, Outer_Width, Border_Length, Border_Length), Border_Width) ? ?# 畫(huà)網(wǎng)格線 ? ?for i in range(Line_Points): ? ? ? ?pygame.draw.line(screen, BLACK_COLOR, ? ? ? ? ? ? ? ? ? ? ? ? (Start_Y, Start_Y + SIZE * i), ? ? ? ? ? ? ? ? ? ? ? ? (Start_Y + SIZE * (Line_Points - 1), Start_Y + SIZE * i), ? ? ? ? ? ? ? ? ? ? ? ? 1) ? ?for j in range(Line_Points): ? ? ? ?pygame.draw.line(screen, BLACK_COLOR, ? ? ? ? ? ? ? ? ? ? ? ? (Start_X + SIZE * j, Start_X), ? ? ? ? ? ? ? ? ? ? ? ? (Start_X + SIZE * j, Start_X + SIZE * (Line_Points - 1)), ? ? ? ? ? ? ? ? ? ? ? ? 1) ? ?# 畫(huà)星位和天元 ? ?for i in (3, 9, 15): ? ? ? ?for j in (3, 9, 15): ? ? ? ? ? ?if i == j == 9: ? ? ? ? ? ? ? ?radius = 5 ? ? ? ? ? ?else: ? ? ? ? ? ? ? ?radius = 3 ? ? ? ? ? ?# pygame.draw.circle(screen, BLACK, (Start_X + SIZE * i, Start_Y + SIZE * j), radius) ? ? ? ? ? ?pygame.gfxdraw.aacircle(screen, Start_X + SIZE * i, Start_Y + SIZE * j, radius, BLACK_COLOR) ? ? ? ? ? ?pygame.gfxdraw.filled_circle(screen, Start_X + SIZE * i, Start_Y + SIZE * j, radius, BLACK_COLOR) # 畫(huà)棋子 def _draw_chessman(screen, point, stone_color): ? ?# pygame.draw.circle(screen, stone_color, (Start_X + SIZE * point.X, Start_Y + SIZE * point.Y), Stone_Radius) ? ?pygame.gfxdraw.aacircle(screen, Start_X + SIZE * point.X, Start_Y + SIZE * point.Y, Stone_Radius, stone_color) ? ?pygame.gfxdraw.filled_circle(screen, Start_X + SIZE * point.X, Start_Y + SIZE * point.Y, Stone_Radius, stone_color) def _draw_chessman_pos(screen, pos, stone_color): ? ?pygame.gfxdraw.aacircle(screen, pos[0], pos[1], Stone_Radius2, stone_color) ? ?pygame.gfxdraw.filled_circle(screen, pos[0], pos[1], Stone_Radius2, stone_color) # 根據(jù)鼠標(biāo)點(diǎn)擊位置,返回游戲區(qū)坐標(biāo) def _get_clickpoint(click_pos): ? ?pos_x = click_pos[0] - Start_X ? ?pos_y = click_pos[1] - Start_Y ? ?if pos_x < -Inside_Width or pos_y < -Inside_Width: ? ? ? ?return None ? ?x = pos_x // SIZE ? ?y = pos_y // SIZE ? ?if pos_x % SIZE > Stone_Radius: ? ? ? ?x += 1 ? ?if pos_y % SIZE > Stone_Radius: ? ? ? ?y += 1 ? ?if x >= Line_Points or y >= Line_Points: ? ? ? ?return None ? ?return Point(x, y) if __name__ == '__main__': ? ?main()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Pytorch 如何訓(xùn)練網(wǎng)絡(luò)時(shí)調(diào)整學(xué)習(xí)率
這篇文章主要介紹了Pytorch 如何訓(xùn)練網(wǎng)絡(luò)時(shí)調(diào)整學(xué)習(xí)率的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05python3 中時(shí)間戳、時(shí)間、日期的轉(zhuǎn)換和加減操作
這篇文章主要介紹了python3 中時(shí)間戳、時(shí)間、日期的轉(zhuǎn)換和加減操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07python實(shí)現(xiàn)圖書(shū)館搶座(自動(dòng)預(yù)約)功能的示例代碼
這篇文章主要介紹了python實(shí)現(xiàn)圖書(shū)館搶座(自動(dòng)預(yù)約)功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09win10環(huán)境下python3.5安裝步驟圖文教程
本文通過(guò)圖文并茂的形式給大家介紹了win10環(huán)境下python3.5安裝步驟,需要的朋友可以參考下2017-02-02Python數(shù)據(jù)分析?Pandas?Series對(duì)象操作
這篇文章主要介紹了Python數(shù)據(jù)分析之Pandas?Series對(duì)象,文章基于python的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-05-05Python單元測(cè)試工具doctest和unittest使用解析
這篇文章主要介紹了Python單元測(cè)試工具doctest和unittest使用解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09apache部署python程序出現(xiàn)503錯(cuò)誤的解決方法
這篇文章主要給大家介紹了關(guān)于在apahce部署python程序出現(xiàn)503錯(cuò)誤的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)同樣遇到這個(gè)問(wèn)題的朋友們具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-07-07Python3.6+selenium2.53.6自動(dòng)化測(cè)試_讀取excel文件的方法
這篇文章主要介紹了Python3.6+selenium2.53.6自動(dòng)化測(cè)試_讀取excel文件的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09