导语

“ 急速奔跑——享受生活中的美好时光!”

——梦想

重磅消息!木木子今天又要给大家介绍一款新游戏啦!

期待不期待呀来我们先来看看是什么游戏让大家这么沸腾

《天天酷跑》这款游戏有好几年的历史了,当初确实是十分火爆,还记得自己第一次接触这款游戏

是在高考后的暑假,因为那个假期比较长,就去一家服装店打工了,闲下来的时候店里的人就在玩游戏

天天酷跑,为了能有话题聊就入坑了,后来发现还有不少同学也都在玩,而且分数比自己高好多。

现在算算大概过去六七年了,自己早已放弃天天酷跑了。

可能因为天天酷跑是自己接触的第一款手游吧,印象比较深刻——现在好不容易下载进去发现很多

规则都改了,捂脸.jpg

完全不会操作了。这不?准备做一款Python版简易的《天天跑酷》小游戏,顺便回一下童年撒!

小简介:

《​天天酷跑》是腾讯移动游戏平台专为海量微信和手机QQ用户量身打造的一款精品手机游戏。

在沿袭传统玩法的基础上,特别加入了闪靓坐骑、萌动宠物等一系列心动设计,为玩家带来最为得

心应手的跑酷体验。随时随地与微信、QQ好友一起玩,抢占排行榜、爱心送不停、高分炫出来!贴

心交互让你和好友亲密无间,分享炫耀让你备受好友关注,成为酷跑达人!

大声告诉你的好友:跑酷从此不一样!

​正文

​本文是Pygame游戏模块制作的《天天跑酷》小游戏啦~

一、准备中

好啦!我们正式开始准备小游戏所需要的素材、环境吧!

图片素材:

环境安装:

Python3.6、Pycharm2019(大部分版本都是可以运行的)、Pygame部分内置模块。

模块安装:pip install -i https://pypi.douban.com/simple/ +模块名

游戏规则:

按空格键跳跃、按一次短跳跃、按二次长跳跃,中间会出现很多障碍物,还有相应的金币等,游戏失败后按空格键重新开始。

二、游戏步骤

1).游戏初始化

  • 利用pygame创建特定大小的游戏窗口。
  • 显示游戏的初始界面,提示用户开始游戏
  • 在游戏界面中设置背景图片,并显示人物、障碍物和金币等物体。

2).游戏控制

  • 人物自动向前奔跑,按空格键控制人物跳跃。
  • 利用addObstacle函数创建障碍物。
  • 利用updateScreen函数不断更新界面中物体的显示。

3).碰撞检测

  • 利用ListenKeyBoard函数监控用户的键盘输入,并检测人物和障碍物金币等是否碰撞。
  • 人物和障碍物碰撞:当检测到人物和障碍物的位置信息有交集时,判断为碰撞,人物生命值减一,障碍物消灭。
  • 人物和金币碰撞:当人物撞到金币时,金币消灭,得分+100。
  • 当人物成功躲避障碍物时,得分+10。
  • 利用judgeState函数来判断游戏是否结束。
  • 游戏结束时显示最终得分,并提示用户按“Enter”键重新开始游戏。

三、正式敲代码

import pygame,sysimport random
# 游戏配置width = 1200
#窗口宽度height = 508
#窗口高度size = width, height   score=None
#分数myFont=myFont1=None
#字体surObject=None
#障碍物图片
surGameOver=None
#游戏结束图片bg=None
#背景对象role=None
#人物对象object=None
#障碍物对象
objectList=[]
#障碍物对象数组clock=None
#时钟gameState=None
#游戏状态(0,1)表示(游戏中,游戏结束)class Role:
#人物    def __init__(self,surface=None,y=None):
self.surface=surface
self.y=y
self.w=(surface.get_width())/12
self.h=surface.get_height()/2
self.currentFrame=-1
self.state=0
#0代表跑步状态,1代表跳跃状态,2代表连续跳跃
self.g=1
#重力加速度
self.vy=0
#y轴速度
self.vy_start=-20
#起跳开始速度
def getRect(self):
return (0,self.y+12,self.w,self.h)class Object:
#障碍物    def __init__(self,surface,x=0,y=0):
self.surface=surface
self.x=x
self.y=y
self.w=surface.get_width()
self.h=surface.get_height()
self.currentFrame=random.randint(0,6)
self.w = 100
self.h = 100
def getRect(self):
return (self.x,self.y,self.w,self.h)
def collision(self,rect1,rect2):
#碰撞检测
if (rect2[0]>=rect1[2]-20) or (rect1[0]+40>=rect2[2])or (rect1[1]+rect1[3]<rect2[1]+20) or (rect2[1]+rect2[3]<rect1[1]+20):
return False       return True
class Bg:
#背景
def __init__(self,surface):
self.surface=surface
self.dx=-10
self.w=surface.get_width()
self.rect=surface.get_rect()
def initGame():
global bg,role,clock,gameState,surObject,surGameOver,score,myFont,myFont1,objectList
#分数初始化
score=0
#初始化
objectList=[]
#加载字体
myFont=pygame.font.Font("./freesansbold.ttf",32)    myFont1=pygame.font.Font("./freesansbold.ttf",64)
# 创建时钟对象 (可以控制游戏循环频率)
clock = pygame.time.Clock()
#初始化游戏状态
gameState=0
#游戏背景
surBg=pygame.image.load("image/bg.bmp").convert_alpha()
bg=Bg(surBg)
#结束画面
surGameOver=pygame.image.load("image/gameover.bmp").convert_alpha()
#人物图片
surRole=pygame.image.load("image/role.png").convert_alpha()
role=Role(surRole,508-85)
#障碍物图片
surObject=pygame.image.load("image/object.png").convert_alpha()
def addObject():
global surObject,object,objectList,object
rate=4
#是否生成障碍物
if not random.randint(0,300)<rate:
return
y=random.choice([height-100,height-200,height-300,height-400])    object=Object(surObject,width+40,y)
objectList.append(object)def updateLogic():
global gameState,score
#键盘事件处理    for event in pygame.event.get():
if event.type == pygame.QUIT:
sys.exit()
elif event.type==pygame.KEYDOWN:
#空格键跳跃
if gameState==0:
if event.key==pygame.K_SPACE:
if role.state==0:
role.state=1
role.vy=role.vy_start
elif role.state==1:
role.state=2
role.vy=role.vy_start
elif gameState==1:
if event.key==pygame.K_SPACE:
#重新开始游戏
initGame()
if gameState==0:
#背景的移动
bg.dx+=10
if bg.dx==1200:
bg.dx=0
#人物的移动
if role.state==0:
role.currentFrame+=1
if role.currentFrame==12:
role.currentFrame=0
else:
role.y+=role.vy
role.vy+=role.g
if role.y>=508-85:
role.y=508-85
role.state=0
#障碍物的移动
addObject()
for object in objectList:
object.x-=10
#障碍物移动
# 障碍物超出屏幕,移除障碍物
if object.x+object.w<=0:
objectList.remove(object)
score+=10
#避开障碍物,加10分
print("移除了一个目标")
#碰撞检测
if object.collision(role.getRect(),object.getRect()):               if(object.currentFrame==6):
objectList.remove(object)
score+=100
#吃金币加100分
print(score)
print("吃了一个金币")
else:
gameState=1   #游戏失败
print("发生了碰撞!")
def updateView(screen):
#背景的贴图
screen.blit(bg.surface,[-bg.dx,0])
screen.blit(bg.surface,[1200-bg.dx,0])
#分数的贴图
textSur=myFont.render("score:%d"%score, True, (128, 128, 128))
screen.blit(textSur, (500,20))
del textSur
#人物的贴图    screen.blit(role.surface, [0, role.y], [int(role.currentFrame) * role.w, 0, role.w, role.h])
#障碍物的贴图
for object in objectList:
screen.blit(object.surface, [object.x, object.y], [int(object.currentFrame) * object.w, 0, object.w, object.h])
def judgeState(screen):
global gameState
if gameState==0:
updateView(screen)
return    elif gameState==1:
screen.blit(surGameOver,[0,0])
textSur = myFont1.render("GameOver Score:%d"%score, True, (255, 0, 0))        screen.blit(textSur, (width/2-350, height/2+150))
def main():
pygame.init()
screen = pygame.display.set_mode(size)
pygame.display.set_caption('天天跑酷——CSDN:梦想)
initGame()
screen.blit(bg.surface,[0,0])
while True:
#设置时钟频率
clock.tick(60)
judgeState(screen)
updateLogic()
pygame.display.flip()main()

​四、效果展示

视频展示——

游戏全面“入侵”生活:Python发布“酷跑+”计划!

截图展示——

游戏开始:

跳跃、障碍物:

​游戏结束:

总结

看完这款游戏,是不是涌出满满的回忆呢:趁爸妈不在家时,偷偷打开电脑玩游戏

刚买智能手机时,下载一两个最火爆的游戏……

现在看来,每一款游戏,都是时光的印记,你还有什么游戏回忆杀呢?之前也写过很多童年经典游

戏可以去看看哈!

完整的项目源码:

(私信我06即可免费拿)

​​

游戏全面“入侵”生活:Python发布“酷跑+”计划相关推荐

  1. 模拟天天酷跑游戏java_cocos2d 简单高仿天天酷跑游戏

    1.先直接上视频来看下这个游戏的样子(GIF已经不能满足这个游戏的展示了) 跑酷游戏最纠结的是地图,碰撞倒是简单,可以自己写或者使用box2d等物理引擎.跑酷游戏地图的特点就是随机性.但是随机中又有策 ...

  2. 【Python游戏】基于Python的pygame模块实现的天天酷跑游戏 | 附带源码

    前言 我相信很多小伙伴都玩过的第一个腾讯游戏,那就是天天酷跑,还记得之前为了凑齐钻石买小单车.人物.坐骑,小编可是花费了老长时间去弄这个的!!不过现在的天天酷跑随便冲个钱都能上大几百万分,没有了以前的 ...

  3. 牛逼,两百行Python代码带你打造一款《天天酷跑》游戏!

    公众号关注 "菜鸟学Python" 第431篇原创,设为 "星标",带你一起学编程! 最近一段时间,小编发现已经好久没有给大家带来趣味游戏的案例展示了.刚好小编 ...

  4. 用python写跑酷游戏脚本,用Python写一个天天酷跑

    感觉上次写的植物大战僵尸与俄罗斯方块的反应还不错,这次这个文章就更有动力了 这次就写一个天天酷跑吧 写出来的效果图就是这样了 下面就更新一下全部的代码吧 还是老样子先定义`import pygame, ...

  5. 天天酷跑小游戏,Python帮你实现

    天天酷跑小游戏 首先安装PYcharm软件,python3.7解释器 先展示效果图如 分享代码: 首先导入库: #库定义: import pygame,sys import random #游戏配置 ...

  6. 天天酷跑Python

    天天酷跑小游戏 (Python) 目 录 一.选题背景----------------1 二.设计流程----------------2 2.1算法思想------------------------ ...

  7. 用 Python 写一个天天酷跑,在线摸鱼不烦恼

    来源丨Python小二 写出来的效果图就是这样了: 下面就更新一下全部的代码吧~ 还是老样子先定义 import pygame,sys import random 写一下游戏配置 width = 12 ...

  8. 用Python写一个天天酷跑

    感觉上次写的植物大战僵尸与俄罗斯方块的反应还不错,这次这个文章就更有动力了 这次就写一个天天酷跑吧 Python源码.问题解答学习交流群:773162165 写出来的效果图就是这样了 下面就更新一下全 ...

  9. 用 Python 写一个天天酷跑 | 内附源码

    写出来的效果图就是这样了: 相关文件 小伙伴们可以关注小编的Python源码.问题解答&学习交流群:733089476 有很多的资源可以白嫖的哈,需要源码的小伙伴可以在+君羊领取 下面就更新一 ...

最新文章

  1. 通过微信公众号获取用户信息(java版)
  2. mysqlclient==1.3.7对应mysql版本_Python通过MySQLdb访问操作MySQL数据库
  3. Docker中运行命令时提示:Cannot connect to the Docker daemony...以及设置docker开机启动
  4. 牛客题霸 [滑动窗口的最大值] C++题解/答案
  5. String类与其他数据类型得转换
  6. 【Linux】查看文件内容的相关命令总结
  7. Qt文档阅读笔记|Qt实践| HTTPS知识点-获取某站点SSL证书
  8. SpringBoot2.0整合jsp
  9. 小白能读懂的 《手把手教你学DSP(TMS320X281X)》第四章 2020-12-29 完整工程
  10. FishC笔记—29 讲 文件:一个任务
  11. OpenCV 视频捕捉
  12. 大数据最核心的价值是什么?
  13. 单招软件职业技能测试,招生信息网-2019年单独招生《职业技能测试》考试大纲...
  14. 电商项目高并发下库存处理redisson
  15. c语言 椭圆,C语言画圆椭圆
  16. Node.js Websocket 井字棋游戏
  17. zxing 二维码、带logo二维码生成
  18. Excel手机号如何查询实名认证?
  19. 无线安全专题_破解篇03--打造个人字典
  20. 扫盲:云计算、大数据和人工智能

热门文章

  1. 文件夹的隐藏选项为灰色,无法更改
  2. ScriptManager和UpdatePanel控件的使用
  3. 服务器怎么识别swf文件,不能可靠地从服务器加载SWF文件
  4. python 爬虫 数据抓取的三种方式
  5. 远程控制 远程监控软件2013年终极排行榜
  6. 透过管理帧保护看WAPI协议安全性
  7. Unity3D深入浅出 - 新版动画系统(Mecanim)
  8. NTFS转FAT32,FAT32转NTFS
  9. CAD梦想画图中“PLAN命令”
  10. 怎么把多张图片做成动图?一分钟教你多图合成gif