用python设计小游戏_用python写一个桌面弹球小游戏

2023-10-14 03:20

本文主要是介绍用python设计小游戏_用python写一个桌面弹球小游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用python写一个桌面弹球小游戏

学python已经有两三周的时间了,看完两本书,基础知识都已基本掌握,按照书上的例子实践一下吧,虽然书上的例子bug一大堆。我猜是作者自己也没实验过吧( ̄▽ ̄)...

游戏功能设计

游戏需要的功能就以下几个小组件

一张画布

一个小球

一个返弹板

计分

控制

功能比较简单,挺没意思的,我觉得可以对接服务器,然后增加一个排行板啥的...

基于python3.5 来实现的,python2.x应该也不会差太多

窗口

制作一个大小长500px宽400px的窗口,当然我们需要导入tkinter 库

from tkinter import *

tk = Tk()

tk.title("Python Game")

tk.resizable(0, 0)

tk.wm_attributes("-topmost", 1)

tk.update()

canvas = Canvas(tk, width=500, height=400, bd=0, highlightthickness=0)

canvas.pack()

1280

小球

生成小球:

这里我们创建一个 Ball类,构造方法如下:

def __init__(self, canvas, paddle, color):

"""

初始化球

:param canvas: Canvas

:param paddle: Paddle

:param color: string

"""

self.canvas = canvas

self.paddle = paddle

self.id = canvas.create_oval(10, 10, 25, 25, fill=color)

self.canvas.move(self.id, 245, 100)

starts = [-3, -2, -1, 1, 2, 3]

random.shuffle(starts)

self.x = starts[0]

self.y = -3

self.canvas_height = self.canvas.winfo_height()

self.canvas_width = self.canvas.winfo_width()

self.hit_bottom = False

创建红色小球,并把它移动到接近中间偏上的位置,随机生成好球运动的方向。同时获取窗口大小赋给变量。

返弹板

创建返弹板:

创建一个 Paddle类,构造方法如下:

def __init__(self, canvas, color):

"""

初始化返弹板并绑定事件

:param canvas:

:param color:

"""

self.canvas = canvas

self.id = canvas.create_rectangle(0, 0, 100, 10, fill=color)

self.canvas.move(self.id, 200, 300)

self.x = 0

self.canvas_width = self.canvas.winfo_width()

self.canvas.bind_all(sequence='', func=self.turn_left)

self.canvas.bind_all(sequence='', func=self.turn_right)

画好返弹板,并且把它移动到中间偏下的位置,获取窗口的宽度。

绑定事件,也就是监听键盘的左右键,当监听到后调用turn_left或turn_right方法

动起来

初始化好相关模块后,咱们就得开始让各个组件动起来了...

思路就是,循环移动小球的位置自己增,当遇到窗口边界时,x或y轴自增或自减,如此循环

当小球遇到返弹板的位置时x或y轴自己增或自减。

当小球的y轴等于0时,游戏结束

返弹板控制

控制返弹板向左或向右:

def turn_left(self, event):

"""

向左

:return:

"""

self.x = -2

def turn_right(self, event):

"""

向右

:return:

"""

self.x = 2

在上面的Paddle初始化的时候有绑定这两个事件...

其他

我创建了一个“锁”,目前没有想到更好的方法,就先这么做吧,当鼠标点击窗口后,开始运行程序...

class Lock:

lock = False

def __init__(self):

self.lock = False

@classmethod

def getLock(self):

return self.lock

@classmethod

def setLock(self, lock):

self.lock = lock

return self

锁的作用就是当你多次点击的时候不会进行操作。

start_begin 函数就是开始游戏,也就是开始让游戏动起来

使用while死循环,让程序不停的在画板上绘制出小球及画板的位置...

def start_begin(event):

if Lock.getLock() == True:

return

Lock.setLock(True)

paddle = Paddle(canvas=canvas, color="blue")

ball = Ball(canvas=canvas, paddle=paddle, color='red')

time.sleep(1)

while True:

if ball.hit_bottom == False:

ball.draw()

paddle.draw()

tk.update_idletasks()

tk.update()

time.sleep(0.001)

time.sleep 每0.001秒执行一次

增加计分板

张当小球成功返弹一次 分数+1,当小球的x轴等于0时,游戏结束,显示相当信息

在Ball类的初始化函数增加文字信息:

def __init__(self, canvas, paddle, color):

"""

初始化球

:param canvas: Canvas

:param paddle: Paddle

:param color: string

"""

self.fraction = 0

self.canvas_id = self.canvas.create_text(10, 10, anchor="nw")

text = "得分: 0"

self.canvas.itemconfig(self.canvas_id, fill="blue", text=text)

然后在控制球的返弹模块增加以下代码:

def hit_paddle(self, pos):

"""

判断返弹板

:param pos: list

:return: bool

"""

paddle_pos = self.canvas.coords(self.paddle.id)

if pos[2] >= paddle_pos[0] and pos[0] <= paddle_pos[2]:

if pos[3] >= paddle_pos[1] and pos[3] <= paddle_pos[3]:

self.fraction += 1

self.canvas.delete(self.canvas_id)

self.canvas_id = self.canvas.create_text(10, 10, anchor="nw")

self.canvas.itemconfig(self.canvas_id, fill="blue", text="得分: ")

self.canvas.insert(self.canvas_id, 12, self.fraction)

return True

return False

这样分数就是动态显示了...

完整代码

#!/usr/bin/env python3

# encoding: utf-8

from tkinter import *

import random

import time

class Ball:

def __init__(self, canvas, paddle, color):

"""

初始化球

:param canvas: Canvas

:param paddle: Paddle

:param color: string

"""

self.canvas = canvas

self.paddle = paddle

self.id = canvas.create_oval(10, 10, 25, 25, fill=color)

self.canvas.move(self.id, 245, 100)

starts = [-3, -2, -1, 1, 2, 3]

random.shuffle(starts)

self.x = starts[0]

self.y = -3

self.canvas_height = self.canvas.winfo_height()

self.canvas_width = self.canvas.winfo_width()

self.hit_bottom = False

self.fraction = 0

self.canvas_id = self.canvas.create_text(10, 10, anchor="nw")

text = "得分: 0"

self.canvas.itemconfig(self.canvas_id, fill="blue", text=text)

def hit_paddle(self, pos):

"""

判断返弹板

:param pos: list

:return: bool

"""

paddle_pos = self.canvas.coords(self.paddle.id)

if pos[2] >= paddle_pos[0] and pos[0] <= paddle_pos[2]:

if pos[3] >= paddle_pos[1] and pos[3] <= paddle_pos[3]:

self.fraction += 1

self.canvas.delete(self.canvas_id)

self.canvas_id = self.canvas.create_text(10, 10, anchor="nw")

self.canvas.itemconfig(self.canvas_id, fill="blue", text="得分: ")

self.canvas.insert(self.canvas_id, 12, self.fraction)

return True

return False

def draw(self):

"""

:return:

"""

self.canvas.move(self.id, self.x, self.y)

pos = self.canvas.coords(self.id)

if pos[1] <= 0:

self.y = 3

if pos[3] >= self.canvas_height:

self.hit_bottom = True

self.canvas.create_text(100, 300, text=("游戏结束! 得分: %d") % self.fraction, fill="red")

if self.hit_paddle(pos) == True:

self.y = -3

if pos[0] <= 0:

self.x = 3

if pos[2] >= self.canvas_width:

self.x = -3

class Paddle:

def __init__(self, canvas, color):

"""

初始化返弹板并绑定事件

:param canvas:

:param color:

"""

self.canvas = canvas

self.id = canvas.create_rectangle(0, 0, 100, 10, fill=color)

self.canvas.move(self.id, 200, 300)

self.x = 0

self.canvas_width = self.canvas.winfo_width()

self.canvas.bind_all(sequence='', func=self.turn_left)

self.canvas.bind_all(sequence='', func=self.turn_right)

def turn_left(self, event):

"""

向左

:return:

"""

self.x = -2

def turn_right(self, event):

"""

向右

:return:

"""

self.x = 2

def draw(self):

"""

:return:

"""

self.canvas.move(self.id, self.x, 0)

pos = self.canvas.coords(self.id)

if pos[0] <= 0:

self.x = 0

elif pos[2] >= self.canvas_width:

self.x = 0

class Lock:

lock = False

def __init__(self):

self.lock = False

@classmethod

def getLock(self):

return self.lock

@classmethod

def setLock(self, lock):

self.lock = lock

return self

if "__main__" == __name__:

tk = Tk()

tk.title("Python Game")

tk.resizable(0, 0)

tk.wm_attributes("-topmost", 1)

tk.update()

canvas = Canvas(tk, width=500, height=400, bd=0, highlightthickness=0)

canvas.pack()

def start_begin(event):

if Lock.getLock() == True:

return

Lock.setLock(True)

paddle = Paddle(canvas=canvas, color="blue")

ball = Ball(canvas=canvas, paddle=paddle, color='red')

time.sleep(1)

while True:

if ball.hit_bottom == False:

ball.draw()

paddle.draw()

tk.update_idletasks()

tk.update()

time.sleep(0.001)

canvas.bind_all(sequence="", func=start_begin)

tk.mainloop()

最终效果

1280

视频演示

您的浏览器不支持此种视频格式。

这篇关于用python设计小游戏_用python写一个桌面弹球小游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/207800

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',