Python加pyGame實(shí)現(xiàn)的簡(jiǎn)單拼圖游戲?qū)嵗?/h1>
更新時(shí)間:2015年05月15日 15:02:15 作者:songguo
這篇文章主要介紹了Python加pyGame實(shí)現(xiàn)的簡(jiǎn)單拼圖游戲,以一個(gè)完整實(shí)例形式分析了pyGame模塊操作圖片的相關(guān)技巧,需要的朋友可以參考下
本文實(shí)例講述了Python加pyGame實(shí)現(xiàn)的簡(jiǎn)單拼圖游戲。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
import pygame, sys, random
from pygame.locals import *
# 一些常量
WINDOWWIDTH = 500
WINDOWHEIGHT = 500
BACKGROUNDCOLOR = (255, 255, 255)
BLUE = (0, 0, 255)
BLACK = (0, 0, 0)
FPS = 40
VHNUMS = 3
CELLNUMS = VHNUMS*VHNUMS
MAXRANDTIME = 100
# 退出
def terminate():
pygame.quit()
sys.exit()
# 隨機(jī)生成游戲盤面
def newGameBoard():
board = []
for i in range(CELLNUMS):
board.append(i)
blackCell = CELLNUMS-1
board[blackCell] = -1
for i in range(MAXRANDTIME):
direction = random.randint(0, 3)
if (direction == 0):
blackCell = moveLeft(board, blackCell)
elif (direction == 1):
blackCell = moveRight(board, blackCell)
elif (direction == 2):
blackCell = moveUp(board, blackCell)
elif (direction == 3):
blackCell = moveDown(board, blackCell)
return board, blackCell
# 若空白圖像塊不在最左邊,則將空白塊左邊的塊移動(dòng)到空白塊位置
def moveRight(board, blackCell):
if blackCell % VHNUMS == 0:
return blackCell
board[blackCell-1], board[blackCell] = board[blackCell], board[blackCell-1]
return blackCell-1
# 若空白圖像塊不在最右邊,則將空白塊右邊的塊移動(dòng)到空白塊位置
def moveLeft(board, blackCell):
if blackCell % VHNUMS == VHNUMS-1:
return blackCell
board[blackCell+1], board[blackCell] = board[blackCell], board[blackCell+1]
return blackCell+1
# 若空白圖像塊不在最上邊,則將空白塊上邊的塊移動(dòng)到空白塊位置
def moveDown(board, blackCell):
if blackCell < VHNUMS:
return blackCell
board[blackCell-VHNUMS], board[blackCell] = board[blackCell], board[blackCell-VHNUMS]
return blackCell-VHNUMS
# 若空白圖像塊不在最下邊,則將空白塊下邊的塊移動(dòng)到空白塊位置
def moveUp(board, blackCell):
if blackCell >= CELLNUMS-VHNUMS:
return blackCell
board[blackCell+VHNUMS], board[blackCell] = board[blackCell], board[blackCell+VHNUMS]
return blackCell+VHNUMS
# 是否完成
def isFinished(board, blackCell):
for i in range(CELLNUMS-1):
if board[i] != i:
return False
return True
# 初始化
pygame.init()
mainClock = pygame.time.Clock()
# 加載圖片
gameImage = pygame.image.load('pic.bmp')
gameRect = gameImage.get_rect()
# 設(shè)置窗口
windowSurface = pygame.display.set_mode((gameRect.width, gameRect.height))
pygame.display.set_caption('拼圖')
cellWidth = int(gameRect.width / VHNUMS)
cellHeight = int(gameRect.height / VHNUMS)
finish = False
gameBoard, blackCell = newGameBoard()
# 游戲主循環(huán)
while True:
for event in pygame.event.get():
if event.type == QUIT:
terminate()
if finish:
continue
if event.type == KEYDOWN:
if event.key == K_LEFT or event.key == ord('a'):
blackCell = moveLeft(gameBoard, blackCell)
if event.key == K_RIGHT or event.key == ord('d'):
blackCell = moveRight(gameBoard, blackCell)
if event.key == K_UP or event.key == ord('w'):
blackCell = moveUp(gameBoard, blackCell)
if event.key == K_DOWN or event.key == ord('s'):
blackCell = moveDown(gameBoard, blackCell)
if event.type == MOUSEBUTTONDOWN and event.button == 1:
x, y = pygame.mouse.get_pos()
col = int(x / cellWidth)
row = int(y / cellHeight)
index = col + row*VHNUMS
if (index == blackCell-1 or index == blackCell+1 or index == blackCell-VHNUMS or index == blackCell+VHNUMS):
gameBoard[blackCell], gameBoard[index] = gameBoard[index], gameBoard[blackCell]
blackCell = index
if (isFinished(gameBoard, blackCell)):
gameBoard[blackCell] = CELLNUMS-1
finish = True
windowSurface.fill(BACKGROUNDCOLOR)
for i in range(CELLNUMS):
rowDst = int(i / VHNUMS)
colDst = int(i % VHNUMS)
rectDst = pygame.Rect(colDst*cellWidth, rowDst*cellHeight, cellWidth, cellHeight)
if gameBoard[i] == -1:
continue
rowArea = int(gameBoard[i] / VHNUMS)
colArea = int(gameBoard[i] % VHNUMS)
rectArea = pygame.Rect(colArea*cellWidth, rowArea*cellHeight, cellWidth, cellHeight)
windowSurface.blit(gameImage, rectDst, rectArea)
for i in range(VHNUMS+1):
pygame.draw.line(windowSurface, BLACK, (i*cellWidth, 0), (i*cellWidth, gameRect.height))
for i in range(VHNUMS+1):
pygame.draw.line(windowSurface, BLACK, (0, i*cellHeight), (gameRect.width, i*cellHeight))
pygame.display.update()
mainClock.tick(FPS)
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- python pygame實(shí)現(xiàn)五子棋小游戲
- python實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲(pygame版)
- python使用pygame模塊實(shí)現(xiàn)坦克大戰(zhàn)游戲
- python實(shí)現(xiàn)五子棋游戲(pygame版)
- python使用pygame框架實(shí)現(xiàn)推箱子游戲
- 使用Python第三方庫(kù)pygame寫個(gè)貪吃蛇小游戲
- python pygame 憤怒的小鳥(niǎo)游戲示例代碼
- python3 pygame實(shí)現(xiàn)接小球游戲
- Python3+Pygame實(shí)現(xiàn)射擊游戲完整代碼
- python游戲庫(kù)pygame經(jīng)典教程(推薦!)
相關(guān)文章
-
連接pandas以及數(shù)組轉(zhuǎn)pandas的方法
今天小編就為大家分享一篇連接pandas以及數(shù)組轉(zhuǎn)pandas的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧 2019-06-06
-
Python高并發(fā)解決方案實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Python高并發(fā)解決方案實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下 2020-07-07
-
Python實(shí)現(xiàn)冒泡排序算法的完整實(shí)例
這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)冒泡排序算法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧 2020-11-11
-
Python2.7:使用Pyhook模塊監(jiān)聽(tīng)鼠標(biāo)鍵盤事件-獲取坐標(biāo)實(shí)例
這篇文章主要介紹了Python2.7:使用Pyhook模塊監(jiān)聽(tīng)鼠標(biāo)鍵盤事件-獲取坐標(biāo)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧 2020-03-03
-
在unittest中使用 logging 模塊記錄測(cè)試數(shù)據(jù)的方法
今天小編就為大家分享一篇在unittest中使用 logging 模塊記錄測(cè)試數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧 2018-11-11
-
python數(shù)據(jù)結(jié)構(gòu):數(shù)據(jù)類型
這篇文章主要介紹了python數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)類型,在?Python?以及其他所有面向?qū)ο缶幊陶Z(yǔ)言中,類都是對(duì)數(shù)據(jù)的構(gòu)成(狀態(tài))以及數(shù)據(jù)?能做什么(行為)的描述,下面我們就來(lái)你看看python數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)類型商務(wù)詳細(xì)介紹,需要的小伙伴可以參考一下 2021-12-12
最新評(píng)論
本文實(shí)例講述了Python加pyGame實(shí)現(xiàn)的簡(jiǎn)單拼圖游戲。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
import pygame, sys, random
from pygame.locals import *
# 一些常量
WINDOWWIDTH = 500
WINDOWHEIGHT = 500
BACKGROUNDCOLOR = (255, 255, 255)
BLUE = (0, 0, 255)
BLACK = (0, 0, 0)
FPS = 40
VHNUMS = 3
CELLNUMS = VHNUMS*VHNUMS
MAXRANDTIME = 100
# 退出
def terminate():
pygame.quit()
sys.exit()
# 隨機(jī)生成游戲盤面
def newGameBoard():
board = []
for i in range(CELLNUMS):
board.append(i)
blackCell = CELLNUMS-1
board[blackCell] = -1
for i in range(MAXRANDTIME):
direction = random.randint(0, 3)
if (direction == 0):
blackCell = moveLeft(board, blackCell)
elif (direction == 1):
blackCell = moveRight(board, blackCell)
elif (direction == 2):
blackCell = moveUp(board, blackCell)
elif (direction == 3):
blackCell = moveDown(board, blackCell)
return board, blackCell
# 若空白圖像塊不在最左邊,則將空白塊左邊的塊移動(dòng)到空白塊位置
def moveRight(board, blackCell):
if blackCell % VHNUMS == 0:
return blackCell
board[blackCell-1], board[blackCell] = board[blackCell], board[blackCell-1]
return blackCell-1
# 若空白圖像塊不在最右邊,則將空白塊右邊的塊移動(dòng)到空白塊位置
def moveLeft(board, blackCell):
if blackCell % VHNUMS == VHNUMS-1:
return blackCell
board[blackCell+1], board[blackCell] = board[blackCell], board[blackCell+1]
return blackCell+1
# 若空白圖像塊不在最上邊,則將空白塊上邊的塊移動(dòng)到空白塊位置
def moveDown(board, blackCell):
if blackCell < VHNUMS:
return blackCell
board[blackCell-VHNUMS], board[blackCell] = board[blackCell], board[blackCell-VHNUMS]
return blackCell-VHNUMS
# 若空白圖像塊不在最下邊,則將空白塊下邊的塊移動(dòng)到空白塊位置
def moveUp(board, blackCell):
if blackCell >= CELLNUMS-VHNUMS:
return blackCell
board[blackCell+VHNUMS], board[blackCell] = board[blackCell], board[blackCell+VHNUMS]
return blackCell+VHNUMS
# 是否完成
def isFinished(board, blackCell):
for i in range(CELLNUMS-1):
if board[i] != i:
return False
return True
# 初始化
pygame.init()
mainClock = pygame.time.Clock()
# 加載圖片
gameImage = pygame.image.load('pic.bmp')
gameRect = gameImage.get_rect()
# 設(shè)置窗口
windowSurface = pygame.display.set_mode((gameRect.width, gameRect.height))
pygame.display.set_caption('拼圖')
cellWidth = int(gameRect.width / VHNUMS)
cellHeight = int(gameRect.height / VHNUMS)
finish = False
gameBoard, blackCell = newGameBoard()
# 游戲主循環(huán)
while True:
for event in pygame.event.get():
if event.type == QUIT:
terminate()
if finish:
continue
if event.type == KEYDOWN:
if event.key == K_LEFT or event.key == ord('a'):
blackCell = moveLeft(gameBoard, blackCell)
if event.key == K_RIGHT or event.key == ord('d'):
blackCell = moveRight(gameBoard, blackCell)
if event.key == K_UP or event.key == ord('w'):
blackCell = moveUp(gameBoard, blackCell)
if event.key == K_DOWN or event.key == ord('s'):
blackCell = moveDown(gameBoard, blackCell)
if event.type == MOUSEBUTTONDOWN and event.button == 1:
x, y = pygame.mouse.get_pos()
col = int(x / cellWidth)
row = int(y / cellHeight)
index = col + row*VHNUMS
if (index == blackCell-1 or index == blackCell+1 or index == blackCell-VHNUMS or index == blackCell+VHNUMS):
gameBoard[blackCell], gameBoard[index] = gameBoard[index], gameBoard[blackCell]
blackCell = index
if (isFinished(gameBoard, blackCell)):
gameBoard[blackCell] = CELLNUMS-1
finish = True
windowSurface.fill(BACKGROUNDCOLOR)
for i in range(CELLNUMS):
rowDst = int(i / VHNUMS)
colDst = int(i % VHNUMS)
rectDst = pygame.Rect(colDst*cellWidth, rowDst*cellHeight, cellWidth, cellHeight)
if gameBoard[i] == -1:
continue
rowArea = int(gameBoard[i] / VHNUMS)
colArea = int(gameBoard[i] % VHNUMS)
rectArea = pygame.Rect(colArea*cellWidth, rowArea*cellHeight, cellWidth, cellHeight)
windowSurface.blit(gameImage, rectDst, rectArea)
for i in range(VHNUMS+1):
pygame.draw.line(windowSurface, BLACK, (i*cellWidth, 0), (i*cellWidth, gameRect.height))
for i in range(VHNUMS+1):
pygame.draw.line(windowSurface, BLACK, (0, i*cellHeight), (gameRect.width, i*cellHeight))
pygame.display.update()
mainClock.tick(FPS)
希望本文所述對(duì)大家的Python程序設(shè)計(jì)有所幫助。
- python pygame實(shí)現(xiàn)五子棋小游戲
- python實(shí)現(xiàn)飛機(jī)大戰(zhàn)游戲(pygame版)
- python使用pygame模塊實(shí)現(xiàn)坦克大戰(zhàn)游戲
- python實(shí)現(xiàn)五子棋游戲(pygame版)
- python使用pygame框架實(shí)現(xiàn)推箱子游戲
- 使用Python第三方庫(kù)pygame寫個(gè)貪吃蛇小游戲
- python pygame 憤怒的小鳥(niǎo)游戲示例代碼
- python3 pygame實(shí)現(xiàn)接小球游戲
- Python3+Pygame實(shí)現(xiàn)射擊游戲完整代碼
- python游戲庫(kù)pygame經(jīng)典教程(推薦!)
相關(guān)文章
連接pandas以及數(shù)組轉(zhuǎn)pandas的方法
今天小編就為大家分享一篇連接pandas以及數(shù)組轉(zhuǎn)pandas的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-06-06
Python高并發(fā)解決方案實(shí)現(xiàn)過(guò)程詳解
這篇文章主要介紹了Python高并發(fā)解決方案實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
Python實(shí)現(xiàn)冒泡排序算法的完整實(shí)例
這篇文章主要給大家介紹了關(guān)于Python實(shí)現(xiàn)冒泡排序算法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Python2.7:使用Pyhook模塊監(jiān)聽(tīng)鼠標(biāo)鍵盤事件-獲取坐標(biāo)實(shí)例
這篇文章主要介紹了Python2.7:使用Pyhook模塊監(jiān)聽(tīng)鼠標(biāo)鍵盤事件-獲取坐標(biāo)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03
在unittest中使用 logging 模塊記錄測(cè)試數(shù)據(jù)的方法
今天小編就為大家分享一篇在unittest中使用 logging 模塊記錄測(cè)試數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11
python數(shù)據(jù)結(jié)構(gòu):數(shù)據(jù)類型
這篇文章主要介紹了python數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)類型,在?Python?以及其他所有面向?qū)ο缶幊陶Z(yǔ)言中,類都是對(duì)數(shù)據(jù)的構(gòu)成(狀態(tài))以及數(shù)據(jù)?能做什么(行為)的描述,下面我們就來(lái)你看看python數(shù)據(jù)結(jié)構(gòu)中的數(shù)據(jù)類型商務(wù)詳細(xì)介紹,需要的小伙伴可以參考一下2021-12-12

