基于Python-Pycharm实现的猴子摘桃小游戏(源代码)
作者:一个超会写Bug的安太狼 发布时间:2023-07-07 06:31:22
标签:Python,Pycharm,猴子摘桃,小游戏
源码及注释:
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
# 定义动画周期(帧数)
ANIMATE_CYCLE = 30
ticks = 0
clock = pygame.time.Clock()
# 猴子类
class Monkey(pygame.sprite.Sprite):
# 苹果的数量
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)
# 添加分数
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()
# 创建猴子
monkey = Monkey(monkey_surface, (200, 500))
# 创建苹果组
apple_group = pygame.sprite.Group()
# 分数字体
score_font = pygame.font.SysFont("arial", 40)
# 主循环
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)
# 更新分数
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\\"
游戏截图:
来源:https://blog.csdn.net/m0_46278037/article/details/113872428


猜你喜欢
- 现在Django 3.0附带了对ASGI的支持,将Websockets添加到Django应用中不需要任何额外的依赖关系。 在本文中,您将学习
- 每个进行过较大型的ASP-Web应用程序设计的开发人员大概都有如下的经历:ASP代码与页面HTML混淆难分,业务逻辑与显示方式绞合,使得代码
- 本文实例讲述了ES6新特性中的let和const命令。分享给大家供大家参考,具体如下:1. let 命令① 在js中是没有块级作用域的,va
- 本文实例为大家分享了python实现快递价格查询系统的具体代码,供大家参考,具体内容如下一、代码#--author--张俊杰@Nick#系统
- 1.颜色空间转换使用cv2.cvtColor(input_image ,flag),flag为转换类型常用的转换类型有:BGR和灰度图的转换
- 问题你要通过网络连接发送和接受连续数据的大型数组,并尽量减少数据的复制操作。解决方案下面的函数利用 memoryviews 来发送和接受大数
- 很久笔者没有来这里写东西了,因为真的很忙。最近笔者一直在使用Win2008系统,不过发现一个很奇怪的问题,那就是在该系统上安装了SQL200
- 一、意义:当我们使用一个数据库时,总希望数据库的内容是可靠的、正确的,但由于计算机系统的故障(硬件故障、网络故障、进程故障和系统故障)影响数
- Kubernetes的控制器模式是其非常重要的一个设计模式,整个Kubernetes定义的资源对象以及其状态都保存在etcd数据库中,通过a
- 1.file--->settings:2.搜索temlates,点击File and Code Templates,点击右侧的Pyth
- # 基础版,不依赖环境import timeimport base64import hashlibclass Token_hander():
- 写爬虫有一个绕不过去的问题就是验证码,现在验证码分类大概有4种:图像类滑动类点击类语音类今天先来看看图像类,这类验证码大多是数字、字母的组合
- 这篇文章利用的是matplotlib.pyplot.plot的工具来绘制折线图,这里先给出一个段代码和结果图:# -*- coding: U
- 本文实例讲述了PHP实现登录,注册及密码修改功能的方法。分享给大家供大家参考,具体如下:这里介绍注册,登录,修改密码的界面布局与功能实现:1
- 先导上一期讲了在ABAP中,ALV的普通写法,流程以及相关属性,还讲了基本DEMO ,但是在真正开发中,不会写这么多的代码.原则上是一切从简
- __getattr__函数的作用: 如果属性查找(attribute lookup)在实例以及对应的类中(通过__dict__)失败, 那么
- 利用OpenCV练习读取图片的时候,图片总是一闪而过,不利于观察,这个时候需要利用到waitKey函数。waitKey函数:用来等待按键,当
- 在家里windows环境下搞了一次见 python MySQLdb在windows环境下的快速安装、问题解决方式ht
- 什么是装饰器从字面意思上来看,装饰器是用来装饰其他东西的工具。在python中装饰器分为函数装饰器和类装饰器。简而言之,函数装饰器是用来装饰
- 索引是加速表内容访问的主要手段,特别对涉及多个表的连接的查询更是如此。这是数据库优化中的一个重要内容,我们要了解为什么需要索引,索引如何工作