基于Python-Pycharm實現(xiàn)的猴子摘桃小游戲(源代碼)
更新時間:2021年02月20日 11:54:07 作者:一個超會寫B(tài)ug的安太狼
這篇文章主要介紹了基于Python-Pycharm實現(xiàn)的猴子摘桃小游戲,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
源碼及注釋:
import pygame from sys import exit from random import randint import time import os # 定義窗口分辨率 SCREEN_WIDTH = 700 SCREEN_HEIGHT = 600 current_path = os.path.abspath(os.path.dirname(__file__)) root_path = current_path[:current_path.find("monkey-picking-peach\\") + len("monkey-picking-peach\\")] \ + "resource\\images\\" # 圖片 BACKGROUND_IMAGE_PATH = root_path + "background.jpg" MONKEY_IMAGE_PATH = root_path + "monkey.png" APPLE_IMAGE_PATH = root_path + "apple.png" JUMP_STATUS = False OVER_FLAG = False START_TIME = None offset = {pygame.K_LEFT: 0, pygame.K_RIGHT: 0, pygame.K_UP: 0, pygame.K_DOWN: 0} # 定義畫面幀率 FRAME_RATE = 60 # 定義動畫周期(幀數(shù)) ANIMATE_CYCLE = 30 ticks = 0 clock = pygame.time.Clock() # 猴子類 class Monkey(pygame.sprite.Sprite): # 蘋果的數(shù)量 apple_num = 0 def __init__(self, mon_surface, monkey_pos): pygame.sprite.Sprite.__init__(self) self.image = mon_surface self.rect = self.image.get_rect() self.rect.topleft = monkey_pos self.speed = 5 # 控制猴子的移動 def move(self, _offset): global JUMP_STATUS x = self.rect.left + _offset[pygame.K_RIGHT] - _offset[pygame.K_LEFT] y = self.rect.top + _offset[pygame.K_DOWN] - _offset[pygame.K_UP] if y < 0: self.rect.top = 0 JUMP_STATUS = True elif y >= SCREEN_HEIGHT - self.rect.height: self.rect.top = SCREEN_HEIGHT - self.rect.height JUMP_STATUS = False else: self.rect.top = y JUMP_STATUS = True if x < 0: self.rect.left = 0 elif x > SCREEN_WIDTH - self.rect.width: self.rect.left = SCREEN_WIDTH - self.rect.width else: self.rect.left = x # 接蘋果 def picking_apple(self, app_group): # 判斷接到幾個蘋果 picked_apples = pygame.sprite.spritecollide(self, app_group, True) # 添加分數(shù) self.apple_num += len(picked_apples) # 接到的蘋果消失 for picked_apple in picked_apples: picked_apple.kill() # 蘋果類 class Apple(pygame.sprite.Sprite): def __init__(self, app_surface, apple_pos): pygame.sprite.Sprite.__init__(self) self.image = app_surface self.rect = self.image.get_rect() self.rect.topleft = apple_pos self.speed = 1 def update(self): global START_TIME if START_TIME is None: START_TIME = time.time() self.rect.top += (self.speed * (1 + (time.time() - START_TIME) / 40)) if self.rect.top > SCREEN_HEIGHT: # 蘋果落地游戲結束 global OVER_FLAG OVER_FLAG = True self.kill() # 初始化游戲 pygame.init() screen = pygame.display.set_mode((SCREEN_WIDTH, SCREEN_HEIGHT)) pygame.display.set_caption("猴子接蘋果") # 載入圖片 background_surface = pygame.image.load(BACKGROUND_IMAGE_PATH).convert() monkey_surface = pygame.image.load(MONKEY_IMAGE_PATH).convert_alpha() apple_surface = pygame.image.load(APPLE_IMAGE_PATH).convert_alpha() # 創(chuàng)建猴子 monkey = Monkey(monkey_surface, (200, 500)) # 創(chuàng)建蘋果組 apple_group = pygame.sprite.Group() # 分數(shù)字體 score_font = pygame.font.SysFont("arial", 40) # 主循環(huán) while True: if OVER_FLAG: break # 控制游戲最大幀率 clock.tick(FRAME_RATE) # 繪制背景 screen.blit(background_surface, (0, 0)) if ticks >= ANIMATE_CYCLE: ticks = 0 # 產生蘋果 if ticks % 30 == 0: apple = Apple(apple_surface, [randint(0, SCREEN_WIDTH - apple_surface.get_width()), -apple_surface.get_height()]) apple_group.add(apple) # 控制蘋果 apple_group.update() # 繪制蘋果組 apple_group.draw(screen) # 繪制猴子 screen.blit(monkey_surface, monkey.rect) ticks += 1 # 接蘋果 monkey.picking_apple(apple_group) # 更新分數(shù) score_surface = score_font.render(str(monkey.apple_num), True, (0, 0, 255)) screen.blit(score_surface, (620, 10)) # 更新屏幕 pygame.display.update() for event in pygame.event.get(): if event.type == pygame.QUIT: pygame.quit() exit() # 控制方向 if event.type == pygame.KEYDOWN: if event.key in offset: if event.key == pygame.K_UP: offset[event.key] = 80 else: offset[event.key] = monkey.speed elif event.type == pygame.KEYUP: if event.key in offset: offset[event.key] = 0 # 移動猴子 if JUMP_STATUS: offset[pygame.K_DOWN] = 5 offset[pygame.K_UP] = 0 monkey.move(offset) # 游戲結束推出界面 score_surface = score_font.render(str(monkey.apple_num), True, (0, 0, 255)) over_surface = score_font.render(u"Game Over!", True, (0, 0, 255)) screen.blit(background_surface, (0, 0)) screen.blit(score_surface, (620, 10)) screen.blit(over_surface, (250, 270)) while True: pygame.display.update() for event in pygame.event.get(): if event.type == pygame.QUIT: pygame.quit() exit()
食用指南: 使用的圖片
monkey.png:
background.jpg:
apple.png:
這是我的文件目錄,學習者也可改為自己的:
更改的代碼位置:
root_path = current_path[:current_path.find("monkey-picking-peach\\") + len("monkey-picking-peach\\")] \ + "resource\\images\\"
游戲截圖:
到此這篇關于基于Python-Pycharm實現(xiàn)的猴子摘桃小游戲的文章就介紹到這了,更多相關Python 猴子摘桃小游戲內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
利用pandas將numpy數(shù)組導出生成excel的實例
今天小編就為大家分享一篇利用pandas將numpy數(shù)組導出生成excel的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-06-06高效測試用例組織算法pairwise之Python實現(xiàn)方法
下面小編就為大家?guī)硪黄咝y試用例組織算法pairwise之Python實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07用Python實現(xiàn)一個簡單的能夠上傳下載的HTTP服務器
這篇文章主要介紹了用Python實現(xiàn)一個簡單的能夠上傳下載的HTTP服務器,是Python網絡編程學習當中的基礎,本文示例基于Windows操作系統(tǒng)實現(xiàn),需要的朋友可以參考下2015-05-05Python處理電子表格的Pandas、OpenPyXL、xlrd和xlwt庫
在Python中處理表格數(shù)據(jù),有幾個非常流行且功能強大的庫,Pandas在數(shù)據(jù)分析方面提供了廣泛的功能,而OpenPyXL、xlrd和xlwt則在處理Excel文件方面各有所長,以下是一些最常用的庫及其示例代碼2024-01-01