当前位置: 首页 > news >正文

pygame7 弹球游戏2

上节课我们做到当球静止下来后在第0号球上画一个球杆

本节课我们将会让这个球杆将球打出来

1、鼠标事件

pygame.mouse.get_pressed():返回鼠标左键,中间,右键的情况

2、键盘事件:

pygame.key.get_pressed(): 返回所有键盘的情况

3、pygame.Rect:

pygame提供的矩形类,这个类我们在之前有学过,这次主要是用到其初始化的功能

rect = Rect(x,y, width, height)

当我们希望将球击打时,实际是需要将球的速度改为一个不为0的数。可以用从球中心到鼠标点的距离作为一个参考量

    def draw_and_wait_hit(self):# 旧代码略if pygame.mouse.get_pressed()[0]:  # 鼠标左键被按下self.speed[0] = (self.rect.center[0] - pos[0]) * 0.1self.speed[1] = (self.rect.center[1] - pos[1]) * 0.1

这样当鼠标左键按下时,球就被打出来了,由于平常的速度在2至4左右,这个计算出来的距离有点大,我们取其中的十分之一作为速度

走到这一步发现球是击出去了,但击到另外的球上,被撞击的球文丝不动。

原因是被撞的球此时速度已经为0了,此时再怎么取返,速度都为0,因此需要重新考虑。

当速度接近0时,使用撞击球的速度取反

这样,我们改一个crash

    def crash(self, groups):if pygame.sprite.spritecollide(self, groups, False):if abs(self.speed[0]) > 1:self.speed[0] = -self.speed[0]else:self.speed[0] = -groups[0].speed[0]if abs(self.speed[1]) > 1:self.speed[1] = -self.speed[1]else:self.speed[1] = -groups[0].speed[1]

当球的速度接近0,就采用撞击的球的相反速度

然后我们发现当A撞击B,B撞C时,新的情况出现了,B和C在那不断抖动,猜想可能是撞击完后没能实现各自的速度取返。

所以我们需要在全部碰撞完成后,调整各球的速度,使他们彼此为反

    def adjust(self, groups):if pygame.sprite.spritecollide(self, groups, False):if (self.speed[0] > 0 and groups[0].speed[0] > 0) or (self.speed[0] < 0 and groups[0].speed[0] < 0):self.speed[0] = -self.speed[0]if (self.speed[1] > 0 and groups[0].speed[1] > 0) or (self.speed[1] < 0 and groups[0].speed[1] < 0):self.speed[1] = -self.speed[1]

然后在后面针对每一个球做一次调整:

while True:# 略for i in range(len(balls)):for j in range(len(balls)):if i == j:continueballs[i].adjust([balls[j]])

至此A撞B,B撞C就不会贴在一起不断抖动了

做一个球洞比较简单,直接在while True中用circle画一个黑色的圆即可,当然,在此之前我们要思考洞的位置,可放在右下角,用到pygame为我们提供的Rect

circle_rect = Rect(width-100, height-100, 100, 100)

然后在While中画出圆:

pygame.draw.circle(screen, [0, 0, 0], circle_rect.center, 50, 0)

怎样表示球进洞呢,通过Rect有一个contains可以判断一个矩形是否包含另一个矩形,我们可以将小球中心点构造成一个小矩形出来

rect = pygame.Rect(self.rect.center[0], self.rect.center[1], 1, 1)

然后判断黑色的圆形是否包含rect:

if circle_rect.contains(rect):

一旦发现黑色的圆包含某个小球的球心,我们可以将小球显示置为False,只有在小球显示为真时才可以显示小球

至此小球进洞就完成了

补充画一个描准器:

        keys = pygame.key.get_pressed()for k in keys:if k:self.show_sighting = not self.show_sightingbreakif self.show_sighting:pos2 = [0, 0]if self.rect.center[0] > pos[0]:pos2[0] = self.rect.center[0] + abs((self.rect.center[0] - pos[0]))else:pos2[0] = self.rect.center[0] - abs((self.rect.center[0] - pos[0]))if self.rect.center[1] > pos[1]:pos2[1] = self.rect.center[1] + abs((self.rect.center[1] - pos[1]))else:pos2[1] = self.rect.center[1] - abs((self.rect.center[1] - pos[1]))

最后补上所有代码:

import pygame, sysclass MyBall(pygame.sprite.Sprite):def __init__(self, point, speed):self.image = pygame.image.load("beach_ball.png")self.rect = self.image.get_rect()self.rect.left = point[0]self.rect.top = point[1]self.speed = speedself.show_sighting = Trueself.show = Truedef move(self):if not self.show:returnself.rect = self.rect.move(self.speed)if self.rect.right > width:self.speed[0] = -abs(self.speed[0])if self.rect.left < 0:self.speed[0] = abs(self.speed[0])if self.rect.bottom > height:self.speed[1] = -abs(self.speed[1])if self.rect.top < 0:self.speed[1] = abs(self.speed[1])rect = pygame.Rect(self.rect.center[0], self.rect.center[1], 1, 1)if circle_rect.contains(rect):self.show = not self.showscreen.blit(self.image, self.rect)def dec_speed(self):self.speed[0] = self.speed[0] * 0.995self.speed[1] = self.speed[1] * 0.995def crash(self, groups):if not self.show:returnif pygame.sprite.spritecollide(self, groups, False):if abs(self.speed[0]) > 1:self.speed[0] = -self.speed[0]else:self.speed[0] = -groups[0].speed[0]if abs(self.speed[1]) > 1:self.speed[1] = -self.speed[1]else:self.speed[1] = -groups[0].speed[1]def adjust(self, groups):if pygame.sprite.spritecollide(self, groups, False):if (self.speed[0] > 0 and groups[0].speed[0] > 0) or (self.speed[0] < 0 and groups[0].speed[0] < 0):self.speed[0] = -self.speed[0]if (self.speed[1] > 0 and groups[0].speed[1] > 0) or (self.speed[1] < 0 and groups[0].speed[1] < 0):self.speed[1] = -self.speed[1]def draw_and_wait_hit(self):if abs(self.speed[0]) > 1 or abs(self.speed[1]) > 1:returnpos = pygame.mouse.get_pos()pygame.draw.line(screen, [255, 0, 0], self.rect.center, pos, 10)keys = pygame.key.get_pressed()for k in keys:if k:self.show_sighting = not self.show_sightingbreakif self.show_sighting:pos2 = [0, 0]if self.rect.center[0] > pos[0]:pos2[0] = self.rect.center[0] + abs((self.rect.center[0] - pos[0]))else:pos2[0] = self.rect.center[0] - abs((self.rect.center[0] - pos[0]))if self.rect.center[1] > pos[1]:pos2[1] = self.rect.center[1] + abs((self.rect.center[1] - pos[1]))else:pos2[1] = self.rect.center[1] - abs((self.rect.center[1] - pos[1]))pygame.draw.line(screen, [255, 0, 0], self.rect.center, pos2, 2)if pygame.mouse.get_pressed()[0]:self.speed[0] = (self.rect.center[0] - pos[0])*0.1self.speed[1] = (self.rect.center[1] - pos[1])*0.1pygame.init()
size = width, height = 640, 480
screen = pygame.display.set_mode(size)
balls = []
for i in range(3):ball = MyBall([180 + 180 * i, 180], [4, 4])balls.append(ball)circle_rect = pygame.Rect(width-100, height-100, 100, 100)while True:for event in pygame.event.get():if event.type == pygame.QUIT:sys.exit()screen.fill([255, 255, 255])for i in range(len(balls)):if i == 0:balls[i].draw_and_wait_hit()balls[i].move()balls[i].dec_speed()for i in range(len(balls)):for j in range(len(balls)):if i == j:continueballs[i].crash([balls[j]])for i in range(len(balls)):for j in range(len(balls)):if i == j:continueballs[i].adjust([balls[j]])pygame.draw.circle(screen, [0, 0, 0], circle_rect.center, circle_rect.width/2)pygame.display.flip()pygame.time.delay(20)

相关文章:

pygame7 弹球游戏2

上节课我们做到当球静止下来后在第0号球上画一个球杆 本节课我们将会让这个球杆将球打出来 1、鼠标事件 pygame.mouse.get_pressed():返回鼠标左键&#xff0c;中间&#xff0c;右键的情况 2、键盘事件&#xff1a; pygame.key.get_pressed(): 返回所有键盘的情况 3、pyg…...

计算机网络4:计算机网络体系结构

目录计算机网络体系结构1.网络模型2.每一层的代表含义2.1 OSI7层模型2.2 五层协议2.3 TCP/IP 四层协议3.数据在各层之间的传输过程4.为什么要进行分层计算机网络体系结构 1.网络模型 2.每一层的代表含义 2.1 OSI7层模型 &#xff08;1&#xff09;物理层&#xff1a;比特流–…...

1630_GNU的二进制分析工具nm简单使用探索

全部学习汇总&#xff1a; GreyZhang/toolbox: 常用的工具使用查询&#xff0c;非教程&#xff0c;仅作为自我参考&#xff01; (github.com) GNU有一套二进制的分析工具&#xff0c;之前是用过objdump的&#xff0c;但是也没有系统掌握。如果做底层软件的设计&#xff0c;这些…...

【Redis】Redis高可用之Redis Cluster集群模式详解(Redis专栏启动)

&#x1f4eb;作者简介&#xff1a;小明java问道之路&#xff0c;2022年度博客之星全国TOP3&#xff0c;专注于后端、中间件、计算机底层、架构设计演进与稳定性建工设优化。文章内容兼具广度深度、大厂技术方案&#xff0c;对待技术喜欢推理加验证&#xff0c;就职于知名金融公…...

1.8 正则表达式

正则表示式是用来匹配与查找字符串的&#xff0c;从网上爬取数据不可避免的会用到正则表达式。 Python 的表达式要先引入 re 模块&#xff0c;正则表达式以 r 引导。Re库主要功能函数函数说明re.search()在一个字符串中搜索匹配正则表达式的第一个位置&#xff0c;返回match对象…...

Postgresql 根据单列或几列分组去重row_number() over() partition by

Postgresql 根据单列或几列分组去重row_number() over() partition by 一般用于单列或者几列需要去重后进行计算值的 count(distinct(eid)) 可以 比如有个例子&#xff0c;需要根据名称&#xff0c;城市去筛选覆盖的道路长度&#xff0c;以月因为建立了唯一索引是ok的&#…...

基于蒙特卡洛法的规模化电动车有序充放电及负荷预测(PythonMatlab实现)

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️❤️&#x1f4a5;&#x1f4a5;&#x1f4a5; &#x1f389;作者研究&#xff1a;&#x1f3c5;&#x1f3c5;&#x1f3c5;主要研究方向是电力系统和智能算法、机器学…...

Selenium常用API详解,从入门到进阶(全套)

目录 1、打开页面 2、查找页面元素 3、输入文本 4、点击操作 5、提交操作 6、清除文本 7、获取文本、属性 8、获取页面的标题和URL 9、窗口 9.1、设置窗口大小 9.2、窗口切换 9.2.1、为什么需要窗口切换&#xff1f; 9.2.2、获取句柄的方式 9.2.3、切换句柄 10、…...

自从学会了Python,我实现了壁纸自由(6)

小朋友们好&#xff0c;大朋友们好&#xff01;我是猫妹&#xff01;哈哈哈&#xff0c;又到周末啦&#xff01;这周过得怎么样&#xff1f;马上就要开学了&#xff0c;寒假作业早已写好了吧&#xff1f;开学让人兴奋&#xff0c;上了很久网课都要吐啦&#xff01;开学也让人有…...

Ruby 发送邮件 - SMTP

SMTP&#xff08;Simple Mail Transfer Protocol&#xff09;即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则&#xff0c;由它来控制信件的中转方式。 Ruby提供了 Net::SMTP 来发送邮件&#xff0c;并提供了两个方法 new 和 start: new 方法有两个参数&am…...

Python爱心代码

前言 Python漂浮爱心&#xff0c;具体源码见&#xff1a;Python动态爱心代码_爱心代码-Python文档类资源-CSDN下载 爱心类 class Heart(): #每个爱心&#xff08;爱心类&#xff09; def __init__(self): self.r ra.randint(10,15) #爱心的半径 …...

【二分查找法及其应用】

文章目录一. 前提二. 基本思路三. 代码实现四. 封装在STL中的二分查找算法五. 浮点数二分一. 前提 待查找的序列是有序的&#xff1b;待查找的 a 采取顺序存储结构。 二. 基本思路 设在升序序列 a [ low…high ] 查找的 k &#xff0c; 首先找中间值 mid a [ ( lowhigh )/2 …...

Android 进阶——Framework核心 之Binder Java成员类详解(三)

文章大纲引言一、Binder Java家族核心成员关系图二、Binder Java家族核心成员源码概述1、android.os.IBinder1.1、boolean transact(int code, Parcel data, Parcel reply, int flags) send a call to an IBinder object1.2、String getInterfaceDescriptor()1.3、boolean ping…...

Maven

Maven 1.什么是Maven 官方网站 https://maven.apache.org/ Maven是一款服务于Java平台的自动化构建工具&#xff0c;它可以帮助我们更方便的对项目进行构建、管理项目jar包 &#xff0c;包括: bulid 项目&#xff0c;切换 jar 版本&#xff0c;添加 jar, 删除 jar 包等 1.…...

1947抓住那头牛(队列 广度优先搜索)

目录 题目描述 解析 解题思路 代码部分 代码部分 运行结果 看看len数组中各个位置的标记值 为什么这样做一定是最短路径&#xff1a; 题目描述 农夫知道一头牛的位置&#xff0c;想要抓住它。农夫和牛都位于数轴上&#xff0c;农夫起始位于点N(0<N<100000)&…...

基于linux5.15.5的IMX 参考手册 ---21

基于linux5.15.5的IMX 参考手册 — 21 10.5.2高清多媒体接口&#xff08;HDMI&#xff09;和显示端口&#xff08;DP&#xff09;概述 10.5.2.1测试名称 •mxc_cec_test.out 10.5.2.1.1位置 /unit_tests/HDMI/ 10.5.2.1.2功能 验证HDMI CEC功能并向HDMI接收器发送断电命令。 1…...

Android Dalvik虚拟机 堆初始化流程

前言 上篇文章介绍了dalvik虚拟机启动流程&#xff0c;在dalvik虚拟机启动时调用了dvmGcStartup来启动堆。 本文介绍我们在日常开发使用Java时的堆创建流程。 Dalvik堆介绍 Dalvik虚拟机中&#xff0c;堆是由heap[0] Active堆和heap[1] Zygote堆两部分组成的。其中&#xff…...

0讲(补)——开发前必备基本常识

前言 专栏内容持续补充更新,目前正在进行优惠活动 目录 前言 一、函数的声明和定义 二、预编译 三、串口打印中的printf函数的使用...

JS学习笔记

1.WebAPIs简介导读Web APIs 和JS 基础关联性JS 基础阶段以及 Web APIs 阶段JS基础学习 ECMAScript 基础语法为后面作铺垫&#xff0c;Web APIs 是JS 的应用&#xff0c;大量使用JS基础语法做交互效果①JS 基础阶段我们学习的是ECMAScript 标准规定的基本语法要求同学们掌握JS 基…...

linux005之用户、组管理

linux用户管理简介&#xff1a; 任何使用linux系统的用户&#xff0c;都必须使用一个合法的账号和密码&#xff0c;账号和密码一般都是超级管理员创建&#xff0c;当然普通用户也可以创建用户&#xff0c;前提是必须拥有创建用户权限。 root是linux系统中默认创建的超级用户 创…...

idea大量爆红问题解决

问题描述 在学习和工作中&#xff0c;idea是程序员不可缺少的一个工具&#xff0c;但是突然在有些时候就会出现大量爆红的问题&#xff0c;发现无法跳转&#xff0c;无论是关机重启或者是替换root都无法解决 就是如上所展示的问题&#xff0c;但是程序依然可以启动。 问题解决…...

iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘

美国西海岸的夏天&#xff0c;再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至&#xff0c;这不仅是开发者的盛宴&#xff0c;更是全球数亿苹果用户翘首以盼的科技春晚。今年&#xff0c;苹果依旧为我们带来了全家桶式的系统更新&#xff0c;包括 iOS 26、iPadOS 26…...

Xshell远程连接Kali(默认 | 私钥)Note版

前言:xshell远程连接&#xff0c;私钥连接和常规默认连接 任务一 开启ssh服务 service ssh status //查看ssh服务状态 service ssh start //开启ssh服务 update-rc.d ssh enable //开启自启动ssh服务 任务二 修改配置文件 vi /etc/ssh/ssh_config //第一…...

Zustand 状态管理库:极简而强大的解决方案

Zustand 是一个轻量级、快速和可扩展的状态管理库&#xff0c;特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...

汽车生产虚拟实训中的技能提升与生产优化​

在制造业蓬勃发展的大背景下&#xff0c;虚拟教学实训宛如一颗璀璨的新星&#xff0c;正发挥着不可或缺且日益凸显的关键作用&#xff0c;源源不断地为企业的稳健前行与创新发展注入磅礴强大的动力。就以汽车制造企业这一极具代表性的行业主体为例&#xff0c;汽车生产线上各类…...

将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?

Otsu 是一种自动阈值化方法&#xff0c;用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理&#xff0c;能够自动确定一个阈值&#xff0c;将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...

srs linux

下载编译运行 git clone https:///ossrs/srs.git ./configure --h265on make 编译完成后即可启动SRS # 启动 ./objs/srs -c conf/srs.conf # 查看日志 tail -n 30 -f ./objs/srs.log 开放端口 默认RTMP接收推流端口是1935&#xff0c;SRS管理页面端口是8080&#xff0c;可…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院查看报告小程序

一、开发环境准备 ​​工具安装​​&#xff1a; 下载安装DevEco Studio 4.0&#xff08;支持HarmonyOS 5&#xff09;配置HarmonyOS SDK 5.0确保Node.js版本≥14 ​​项目初始化​​&#xff1a; ohpm init harmony/hospital-report-app 二、核心功能模块实现 1. 报告列表…...

智能AI电话机器人系统的识别能力现状与发展水平

一、引言 随着人工智能技术的飞速发展&#xff0c;AI电话机器人系统已经从简单的自动应答工具演变为具备复杂交互能力的智能助手。这类系统结合了语音识别、自然语言处理、情感计算和机器学习等多项前沿技术&#xff0c;在客户服务、营销推广、信息查询等领域发挥着越来越重要…...

深入浅出深度学习基础:从感知机到全连接神经网络的核心原理与应用

文章目录 前言一、感知机 (Perceptron)1.1 基础介绍1.1.1 感知机是什么&#xff1f;1.1.2 感知机的工作原理 1.2 感知机的简单应用&#xff1a;基本逻辑门1.2.1 逻辑与 (Logic AND)1.2.2 逻辑或 (Logic OR)1.2.3 逻辑与非 (Logic NAND) 1.3 感知机的实现1.3.1 简单实现 (基于阈…...