我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python怎么实现推箱子游戏

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python怎么实现推箱子游戏

小编给大家分享一下Python怎么实现推箱子游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1.游戏规则

推箱子游戏是一款可玩性极高的策略解谜手游,游戏中玩家将扮演一名可爱Q萌的角色,

我们需通过将场景内的箱子,推送到合适的位置上进行摆放,才可以轻松获得游戏胜利。

整个过程虽然极其简单,但极需玩家动脑思考,充分的利用有效地空间,合理得将箱子推送到指定位置,从而获得游戏胜利。

不仅如此,游戏整体画风十分简洁清爽,采用了简单和程式化的图形设计,给予了玩家前所未有的体验感哦。

2.材料准备

玩家、箱子、背景等图片素材:

Python怎么实现推箱子游戏

3.环境安装

Python3.6、pycharm、pygame游戏模块不能少。

pip install pygame

**导入游戏的素材,**增加游戏元素

 def addElement(self, elem_type, col, row):        if elem_type == 'wall':            self.walls.append(elementSprite('wall.png', col, row, cfg))        elif elem_type == 'box':            self.boxes.append(elementSprite('box.png', col, row, cfg))        elif elem_type == 'target':            self.targets.append(elementSprite('target.png', col, row, cfg))

4.游戏开始、结束界面设置

def startInterface(screen, cfg):    screen.fill(cfg.BACKGROUNDCOLOR)    clock = pygame.time.Clock()    while True:        button_1 = Button(screen, (95, 150), '开始游戏', cfg)        button_2 = Button(screen, (95, 305), '退出游戏', cfg)        for event in pygame.event.get():            if event.type == pygame.QUIT:                pygame.quit()                sys.exit()            if event.type == pygame.MOUSEBUTTONDOWN:                if button_1.collidepoint(pygame.mouse.get_pos()):                    return                elif button_2.collidepoint(pygame.mouse.get_pos()):                    pygame.quit()                    sys.exit(0)        clock.tick(60)        pygame.display.update() def endInterface(screen, cfg):    screen.fill(cfg.BACKGROUNDCOLOR)    clock = pygame.time.Clock()    font_path = os.path.join(cfg.FONTDIR, 'simkai.ttf')    text = '机智如你~恭喜通关!'    font = pygame.font.Font(font_path, 30)    text_render = font.render(text, 1, (255, 255, 255))    while True:        for event in pygame.event.get():            if event.type == pygame.QUIT:                pygame.quit()                sys.exit()        screen.blit(text_render, (120, 200))        clock.tick(60)        pygame.display.update()

如下:

Python怎么实现推箱子游戏

******设置游戏的界面,**导入关卡地图

class gameInterface():    def __init__(self, screen):        self.screen = screen        self.levels_path = cfg.LEVELDIR        self.initGame()    def loadLevel(self, game_level):        with open(os.path.join(self.levels_path, game_level), 'r') as f:            lines = f.readlines()        # 游戏地图        self.game_map = gameMap(max([len(line) for line in lines]) - 1, len(lines))        # 游戏surface        height = cfg.BLOCKSIZE * self.game_map.num_rows        width = cfg.BLOCKSIZE * self.game_map.num_cols        self.game_surface = pygame.Surface((width, height))        self.game_surface.fill(cfg.BACKGROUNDCOLOR)        self.game_surface_blank = self.game_surface.copy()        for row, elems in enumerate(lines):            for col, elem in enumerate(elems):                if elem == 'p':                    self.player = pusherSprite(col, row, cfg)                elif elem == '*':                    self.game_map.addElement('wall', col, row)                elif elem == '#':                    self.game_map.addElement('box', col, row)                elif elem == 'o':                    self.game_map.addElement('target', col, row)

因为游戏界面面积>游戏窗口界面, 所以需要根据人物位置滚动。

 def scroll(self):        x, y = self.player.rect.center        width = self.game_surface.get_rect().w        height = self.game_surface.get_rect().h        if (x + cfg.SCREENSIZE[0] // 2) > cfg.SCREENSIZE[0]:            if -1 * self.scroll_x + cfg.SCREENSIZE[0] < width:                self.scroll_x -= 2        elif (x + cfg.SCREENSIZE[0] // 2) > 0:            if self.scroll_x < 0:                self.scroll_x += 2        if (y + cfg.SCREENSIZE[1] // 2) > cfg.SCREENSIZE[1]:            if -1 * self.scroll_y + cfg.SCREENSIZE[1] < height:                self.scroll_y -= 2        elif (y + 250) > 0:            if self.scroll_y < 0:                self.scroll_y += 2

设置玩家的精灵类,可上下左右移动等

class pusherSprite(pygame.sprite.Sprite):    def __init__(self, col, row, cfg):        pygame.sprite.Sprite.__init__(self)        self.image_path = os.path.join(cfg.IMAGESDIR, 'player.png')        self.image = pygame.image.load(self.image_path).convert()        color = self.image.get_at((0, 0))        self.image.set_colorkey(color, pygame.RLEACCEL)        self.rect = self.image.get_rect()        self.col = col        self.row = row    '''移动'''    def move(self, direction, is_test=False):        # 测试模式代表模拟移动        if is_test:            if direction == 'up':                return self.col, self.row - 1            elif direction == 'down':                return self.col, self.row + 1            elif direction == 'left':                return self.col - 1, self.row            elif direction == 'right':                return self.col + 1, self.row        else:            if direction == 'up':                self.row -= 1            elif direction == 'down':                self.row += 1            elif direction == 'left':                self.col -= 1            elif direction == 'right':                self.col += 1    '''将人物画到游戏界面上'''    def draw(self, screen):        self.rect.x = self.rect.width * self.col        self.rect.y = self.rect.height * self.row        screen.blit(self.image, self.rect)  '''游戏元素精灵类'''class elementSprite(pygame.sprite.Sprite):    def __init__(self, sprite_name, col, row, cfg):        pygame.sprite.Sprite.__init__(self)        # 导入box.png/target.png/wall.png        self.image_path = os.path.join(cfg.IMAGESDIR, sprite_name)        self.image = pygame.image.load(self.image_path).convert()        color = self.image.get_at((0, 0))        self.image.set_colorkey(color, pygame.RLEACCEL)        self.rect = self.image.get_rect()        # 元素精灵类型        self.sprite_type = sprite_name.split('.')[0]        # 元素精灵的位置        self.col = col        self.row = row    '''将游戏元素画到游戏界面上'''    def draw(self, screen):        self.rect.x = self.rect.width * self.col        self.rect.y = self.rect.height * self.row        screen.blit(self.image, self.rect)    '''移动游戏元素'''    def move(self, direction, is_test=False):        if self.sprite_type == 'box':            # 测试模式代表模拟移动            if is_test:                if direction == 'up':                    return self.col, self.row - 1                elif direction == 'down':                    return self.col, self.row + 1                elif direction == 'left':                    return self.col - 1, self.row                elif direction == 'right':                    return self.col + 1, self.row            else:                if direction == 'up':                    self.row -= 1                elif direction == 'down':                    self.row += 1                elif direction == 'left':                    self.col -= 1                elif direction == 'right':                    self.col += 1

游戏关卡循环,当某个关卡过不去的时候,想重新来按住R键即可返回本关卡

def runGame(screen, game_level):    clock = pygame.time.Clock()    game_interface = gameInterface(screen)    game_interface.loadLevel(game_level)    font_path = os.path.join(cfg.FONTDIR, 'simkai.ttf')    text = '按R键重新开始本关'    font = pygame.font.Font(font_path, 15)    text_render = font.render(text, 1, (255, 255, 255))    while True:        for event in pygame.event.get():            if event.type == pygame.QUIT:                pygame.quit()                sys.exit(0)            elif event.type == pygame.KEYDOWN:                if event.key == pygame.K_LEFT:                    next_pos = game_interface.player.move('left', is_test=True)                    if game_interface.game_map.isValidPos(*next_pos):                        game_interface.player.move('left')                    else:                        box = game_interface.game_map.getBox(*next_pos)                        if box:                            next_pos = box.move('left', is_test=True)                            if game_interface.game_map.isValidPos(*next_pos):                                game_interface.player.move('left')                                box.move('left')                    break                if event.key == pygame.K_RIGHT:                    next_pos = game_interface.player.move('right', is_test=True)                    if game_interface.game_map.isValidPos(*next_pos):                        game_interface.player.move('right')                    else:                        box = game_interface.game_map.getBox(*next_pos)                        if box:                            next_pos = box.move('right', is_test=True)                            if game_interface.game_map.isValidPos(*next_pos):                                game_interface.player.move('right')                                box.move('right')                    break                if event.key == pygame.K_DOWN:                    next_pos = game_interface.player.move('down', is_test=True)                    if game_interface.game_map.isValidPos(*next_pos):                        game_interface.player.move('down')                    else:                        box = game_interface.game_map.getBox(*next_pos)                        if box:                            next_pos = box.move('down', is_test=True)                            if game_interface.game_map.isValidPos(*next_pos):                                game_interface.player.move('down')                                box.move('down')                    break                if event.key == pygame.K_UP:                    next_pos = game_interface.player.move('up', is_test=True)                    if game_interface.game_map.isValidPos(*next_pos):                        game_interface.player.move('up')                    else:                        box = game_interface.game_map.getBox(*next_pos)                        if box:                            next_pos = box.move('up', is_test=True)                            if game_interface.game_map.isValidPos(*next_pos):                                game_interface.player.move('up')                                box.move('up')                    break                if event.key == pygame.K_r:                    game_interface.initGame()                    game_interface.loadLevel(game_level)        game_interface.draw(game_interface.player, game_interface.game_map)        if game_interface.game_map.levelCompleted():            return        screen.blit(text_render, (5, 5))        pygame.display.flip()        clock.tick(100)

如下:

Python怎么实现推箱子游戏

判断****该关卡中所有的箱子是否都在指定位置, 在的话就是通关了

 def levelCompleted(self):        for box in self.boxes:            is_match = False            for target in self.targets:                if box.col == target.col and box.row == target.row:                    is_match = True                    break            if not is_match:                return False        return True

效果图第二关卡如下:

Python怎么实现推箱子游戏

以上是“Python怎么实现推箱子游戏”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python怎么实现推箱子游戏

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python怎么实现推箱子游戏

小编给大家分享一下Python怎么实现推箱子游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.游戏规则推箱子游戏是一款可玩性极高的策略解谜手游,游戏中玩家将扮
2023-06-22

C++怎么实现推箱子小游戏

这篇文章主要介绍“C++怎么实现推箱子小游戏”,在日常操作中,相信很多人在C++怎么实现推箱子小游戏问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++怎么实现推箱子小游戏”的疑惑有所帮助!接下来,请跟着小编
2023-06-20

HTML+JS实现经典推箱子游戏

今天,这篇文章将利用HTML,CSS,JS的知识编写一个童年经典游戏 - 推箱子,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2022-11-13

如何用C++实现推箱子小游戏

本篇内容主要讲解“如何用C++实现推箱子小游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用C++实现推箱子小游戏”吧!前言推箱子小游戏相信是很多人的同年记忆了,今天用c++语言来尝试下,
2023-06-20

C语言如何实现推箱子小游戏

本篇内容介绍了“C语言如何实现推箱子小游戏”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本文实例为大家分享了C语言实现推箱子代码的具体代码,
2023-06-20

android自定义view实现推箱子小游戏

本文实例为大家分享了android推箱子游戏的具体实现代码,供大家参考,具体内容如下自定义view:package com.jisai.materialdesigndemo.tuixiangzhi; import android.cont
2022-06-06

使用C/C++怎么实现一个推箱子小游戏

这篇文章给大家介绍使用C/C++怎么实现一个推箱子小游戏,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。如何实现1.首先思考要保存箱子,小猪等信息,添加多个map可以用到三维数组。2.定义小猪,箱子,墙,空地等信息在三维
2023-06-15

怎么用C语言实现游戏项目推箱子效果

本篇内容主要讲解“怎么用C语言实现游戏项目推箱子效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用C语言实现游戏项目推箱子效果”吧!直接开始吧首先是我们用二维数组特定的数字描绘出这个地图i
2023-06-25

如何使用Java实现经典游戏推箱子

这篇文章将为大家详细讲解有关如何使用Java实现经典游戏推箱子,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。主要设计1、游戏面板生成显示2、地图生成算法3、人物移动算法4、播放背景音乐5、箱子移动算法6、
2023-06-29

如何使用C语言实现推箱子游戏

这篇文章主要为大家展示了“如何使用C语言实现推箱子游戏”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用C语言实现推箱子游戏”这篇文章吧。1.前言推箱子是c语言的一个经典的项目2.游戏效果展
2023-06-29

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录