用Python Pygame做的一些好玩的小游戏
有些游戏的代码比较长就不公布了
1.简简单单
1.疯狂的鸡哥

你要准备的图片:

命名为:ji.png
代码:
import pygame
import random as r
pygame.init()
pygame.display.set_caption('aaa')
pm = pygame.display.set_mode((800,600))class Ls(pygame.sprite.Sprite):def __init__(self,pos):#pos 鼠标点击的位置super().__init__()self.image = pygame.image.load('ji.png')self.dx = r.randint(20,50)self.dx2 = r.randint(20, 50)self.image = pygame.transform.scale(self.image,(self.dx,self.dx2))self.rect = self.image.get_rect()self.rect.top = pos[0]self.rect.left =pos[1]self.vx = r.randint(-3,11)self.vy = r.randint(-2,12)# update方法def update(self):self.rect.left += self.vxself.rect.top += self.vyif self.rect.left <= 0 or self.rect.left >= 750:self.vx = -self.vxself.image = pygame.transform.scale(self.image,(self.dx,self.dx2))if self.rect.top <= 0 or self.rect.top >= 550:self.vy = -self.vy
group = pygame.sprite.Group()
while True:pm.fill((120,205,255))zt = pygame.mouse.get_pressed()zy = pygame.font.Font('叶根友刀锋黑草.ttf',50).render('左键增加滚轮碰到哪个哪个删除 ',True,(0,0,0))pm.blit(zy,(0,0))if zt[0]:group.add(Ls([100,200]))if zt[1]:wz = pygame.mouse.get_pos()for i in group:if i.rect.collidepoint(wz): #给定点是否在给定矩形范围中,前面的是给定矩形,括号中的是点.i.kill()group.draw(pm)group.update()for event in pygame.event.get():if event.type == pygame.QUIT:exit()pygame.display.update()pygame.time.Clock().tick(20)
2.智慧的随机分数系统

while True:import pygamepygame.init()pygame.display.set_caption('aaa')screen = pygame.display.set_mode((800,600))jts = pygame.image.load('照片\jts.png')jtx = pygame.image.load('照片\jtx.png')qd = pygame.image.load('照片\qd.png')a = 100mm = 1while mm == 1:screen.fill((255,255,255))ju = pygame.font.Font('字体\叶根友刀锋黑草.ttf', 100)s = ju.render(str(a), True, (1, 2, 200))ju2 = pygame.font.Font('字体\叶根友刀锋黑草.ttf', 100)s2 = ju2.render('满分:', True, (1, 2, 200))for event in pygame.event.get():if event.type == pygame.QUIT:exit()screen.blit(s,(300,300))screen.blit(qd, (620, 10))screen.blit(s2,(100,100))screen.blit(jts,(500,200))screen.blit(jtx,(500,400))x, y = pygame.mouse.get_pos()for i in range(111):for ii in range(101):if x == 500+i and y == 200 + ii and pygame.mouse.get_pressed()[0] == True:a = a+1for i in range(97):for ii in range(117):if x == 500+i and y == 400 + ii and pygame.mouse.get_pressed()[0] == True:a = a-1for i in range(154):for ii in range(79):if x == 620+i and y == 10 + ii and pygame.mouse.get_pressed()[0] == True:mm = 1333pygame.display.update()pygame.time.Clock().tick(20)import pygameimport random as rpygame.init()pygame.display.set_caption('aaa')screen = pygame.display.set_mode((800,600))qd = pygame.image.load('照片\qd.png')b = str(r.randint(0,a)) + '分'mm = 1while mm == 1:screen.fill((255,255,255))ju = pygame.font.Font('字体\叶根友刀锋黑草.ttf', 50)s = ju.render(b, True, (1, 2, 200))ju2 = pygame.font.Font('字体\叶根友刀锋黑草.ttf', 50)s2 = ju2.render('我预测你这次考试会考:', True, (1, 2, 200))for event in pygame.event.get():if event.type == pygame.QUIT:exit()screen.blit(s,(100,200))screen.blit(qd, (620, 500))screen.blit(s2,(100,100))x, y = pygame.mouse.get_pos()for i in range(154):for ii in range(79):if x == 620+i and y == 500 + ii and pygame.mouse.get_pressed()[0] == True:print(1)mm = 1333pygame.display.update()pygame.time.Clock().tick(20)
要准备的图片:
jts.png #向上的箭头 jtx.png #向下的箭头 qd.png #确定
2.平平淡淡也挺好玩
1.极速赛车
准备一个汽车图片叫做:
qc.png
代码:
import pygame,sys
from random import*
while True:js = ''class Block(pygame.sprite.Sprite):def __init__(self):super().__init__()self.kd = randint(90,180)self.image = pygame.Surface((self.kd,20))self.image.fill((255,255,255))self.rect = self.image.get_rect()self.rect.top = 0self.rect.left = 0def update(self,v):self.rect.top += vif self.rect.top >= 600:self.kill()class Block2(Block):def __init__(self):super().__init__()self.rect.left = 400-self.kdclass Car(pygame.sprite.Sprite):def __init__(self):super().__init__()self.image = pygame.image.load('qc.png')self.image = pygame.transform.scale(self.image, (20, 50))self.rect = self.image.get_rect()self.rect.top = 400self.rect.left = 150def update(self):k = pygame.key.get_pressed()if k[pygame.K_RIGHT]:self.rect.left += 5elif k[pygame.K_LEFT]:self.rect.left -= 5if self.rect.left >= 400:self.rect.left = 400if self.rect.left <= 0:self.rect.left = 0def zi(dx,x,y):xz = pygame.font.Font('叶根友刀锋黑草.ttf', 50).render(str(dx), True, (0, 0, 0))screen.blit(xz,(x,y))pygame.init()screen = pygame.display.set_mode((400,600))pygame.display.set_caption("qc")group = pygame.sprite.Group()group2 = pygame.sprite.Group()group3 = pygame.sprite.Group()group3.add(Car())i = 0v = 3while True:screen.fill((0,0,255))for event in pygame.event.get():if event.type == pygame.QUIT:sys.exit()t = pygame.time.get_ticks()if js == '':miao = str(t / 1000)miao2 = int(miao[0])zi('速度:' + str(int(v)), 0, 0)if miao2 == 1 and miao2 != 0:v += 0.001i += 1jg = randint(20,50) #间隔if i % jg == 0:group.add(Block())group.draw(screen)group.update(v)jg2 = randint(20, 50) # 间隔2if i % jg2 == 0:group2.add(Block2())group2.draw(screen)group2.update(v)group3.draw(screen)group3.update()else:zi('Game Over',0,100)zi('按滚轮回去',50,200)#碰撞a = pygame.sprite.groupcollide(group,group3,False,False)b = pygame.sprite.groupcollide(group2, group3, False, False)if a or b:js = '结束'i = 0v = 3if pygame.mouse.get_pressed()[1] and js == '结束':breakpygame.display.update()pygame.time.Clock().tick(60)
2.滑雪

代码太长了:294行
提供一个创意思路
3.制作困难的游戏
提供思路
1.风叶穿行
被我爆改成了火山穿行
网站链接(B站的灵感):风叶穿行 (bilibili.com)

2.鱿鱼游戏系列

4.我还有很多有意思的pygame游戏
相关文章:
用Python Pygame做的一些好玩的小游戏
有些游戏的代码比较长就不公布了 1.简简单单 1.疯狂的鸡哥 你要准备的图片: 命名为:ji.png 代码: import pygame import random as r pygame.init() pygame.display.set_caption(aaa) pm pygame.display.set_mode((800,600))class Ls(py…...
【吊打面试官系列】Java高并发篇 - ThreadLocal 是什么?有什么用?
大家好,我是锋哥。今天分享关于 【ThreadLocal 是什么?有什么用?】面试题,希望对大家有帮助; ThreadLocal 是什么?有什么用? ThreadLocal 是一个本地线程副本变量工具类。主要用于将私有线程和该…...
Spring MVC的数据转换及数据格式化:java 转换器接口(将一种类型的对象转换为另一种类型及其子类对象)
文章目录 引言I 将String转为BaseEnum的子类对象1.1 注册转换器工厂1.2 实现转换器工厂1.3 实现转换器接口 `interface Converter<S, T> `1.4 根据枚举code和type获取枚举II 枚举2.1 枚举接口2.2 枚举子类2.3 请求实体引言 Spring MVC的数据转换及数据格式化 应用场景:…...
【开源】多语言大型语言模型的革新:百亿参数模型超越千亿参数性能
大型人工智能模型,尤其是那些拥有千亿参数的模型,因其出色的商业应用表现而受到市场的青睐。但是,直接通过API使用这些模型可能会带来数据泄露的风险,尤其是当模型提供商如OpenAI等可能涉及数据隐私问题时。私有部署虽然是一个解决…...
DDL—表—数据类型—日期时间类型相关语法
(1)表格如下: 类型大小范围格式描述DATE31000-01-01 至 9999-12-31YYYY-MM-DD日期值(年月日)TIME3-838:59:59 至 838:59:59HH:MM:SS时间值或持续时间(时分秒)YEAR11901 至 2155YYYY年份值DATET…...
Ant Design pro 6.0.0 搭建使用以及相关配置
一、背景 在选择一款比较合适的中台的情况下,挑选了有arco design、ant design pro、soybean、vue-pure-admin等中台系统,经过筛选就选择了ant design pro。之前使用过arco design 搭建通过组件库拼装过后台管理界面,官方文档也比较全&#…...
Vue生命周期钩子是如何实现的
Vue的生命周期钩子是在Vue组件创建、挂载、更新、销毁等过程中自动调用的特殊函数。这些钩子允许开发者在组件的不同阶段执行特定的逻辑。Vue 2 和 Vue 3 在生命周期钩子上有一些差异,主要是因为Vue 3引入了Composition API和更现代的JavaScript特性。 Vue 2 的生命…...
002 仿muduo库实现高性能服务器组件_整体框架
🌈个人主页:Fan_558 🔥 系列专栏:仿muduo 🌹关注我💪🏻带你学更多知识 文章目录 前言项目框架小结 前言 本文不会包含任何项目模块的代码,旨在向你介绍项目具体分为哪几个模块&am…...
车道线识别与预警系统LDWS(代码+教程)
车道线识别与预警系统(Lane Departure Warning System, LDWS)作为智能交通系统中的重要组成部分,旨在通过先进的图像处理和计算机视觉技术,实时监测车辆行驶过程中的车道位置,预防因驾驶员疏忽或疲劳导致的车道偏离事故…...
Python基础学习笔记(七)——元组
目录 一、一维元组的介绍、创建与修改二、组合的基本操作1. 遍历2. 取长度3. 取最值4. 打包5. 批处理5.1 map()函数5.2 lambda 表达式5.3 lambda 表达式 map()函数 一、一维元组的介绍、创建与修改 元组(tuple),一种不可变、有序、可重复的数…...
安卓开发:相机水印设置
1.更新水印 DecimalFormat DF new DecimalFormat("#"); DecimalFormat DF1 new DecimalFormat("#.#");LocationManager LM (LocationManager)getSystemService(Context.LOCATION_SERVICE); LM.requestLocationUpdates(LocationManager.GPS_PROVIDER, 2…...
Excel工作表单元格单击选中事件,VBA动态数值排序
Excel工作表单元格单击选中事件,VBA动态数值排序(WX公众号:Excel潘谆白说VBA) 文章目录 前言一、运行效果二、代码前言 面对每月的消费账单,面对月底待还的信用卡或花呗,面对不足三位数的余额,你是否怀疑过账单自己的消费。你是否因此开始记账,每个月记流水,想知道当月…...
数据结构~~链式二叉树
目录 一、基本概念 链式存储概念 二、链式二叉树的结构 链式二叉树结构 构建链式二叉树 二叉树的遍历 二叉树节点和高度等 二叉树销毁 三、链式二叉树的练习 相同的树 对称二叉树 另外一颗子树 二叉树前序遍历 二叉树遍历 四、完整代码 Tree.h Tree.c 五、总结 一…...
线程池,日志
所要用到的知识点: 多线程的创建 生产消费模型, 线程锁 条件变量 代码: 线程池日志...
vue的图片上传
关于vue3的图片上传,这里记录一下,有兴趣的朋友可以参考。。。。 <van-uploader:after-read"afterRead"v-model"headImg":max-count"1"class"picture"/> const fileList ref();const afterRead (fil…...
题解 P1150
题解 P1150 因为k个烟蒂1根烟1个烟蒂 所以k-1个烟蒂1根烟 注意减掉最后一根烟的烟蒂 (因这题并没有借烟蒂换烟再还回这一说) 此解法为小学4~6年级水平 #include <bits/stdc.h>using namespace std;int main(){int n,k;cin>>n>>k;cout<<n(n-1)/(k-…...
牛客NC324 下一个更大的数(三)【中等 双指针 Java/Go/PHP/C++】参考lintcode 52 · 下一个排列
题目 题目链接: https://www.nowcoder.com/practice/475da0d4e37a481bacf9a09b5a059199 思路 第一步:获取数字上每一个数,组成数组arr 第二步:利用“下一个排列” 问题解题方法来继续作答,步骤:利用lintc…...
Vue3解决“找不到模块“@/components/xxx.vue”或其相应的类型声明”
文章目录 前言背景问题描述解决方案总结 前言 在使用 Vue 3 开发项目时,遇到“找不到模块 ‘/components/xxx.vue’ 或其相应的类型声明”的错误是一个常见问题。这通常与 TypeScript 和模块解析相关的配置不当有关。本文将详细介绍如何解决此问题,确保…...
nginx的Connection refused
问题描述 nginx的错误日志中突然出现大量的的Connection refused问题,日志如下: 2020/03/19 09:52:53 [error] 20117#20117: *7403411764 connect() failed (111: Connection refused) while connecting to upstream, client: xxx.xxx.xxx.xxx, server:…...
Haskell 的高阶函数(Higher-order functions)
本节继续介绍Haskell的知识,本节内容介绍的是高阶函数(Higher-order functions)的概念和应用。高阶函数是指能够接受其他函数作为参数,或者返回函数作为结果的函数。 Functions as values(函数作为值)&…...
突破不可导策略的训练难题:零阶优化与强化学习的深度嵌合
强化学习(Reinforcement Learning, RL)是工业领域智能控制的重要方法。它的基本原理是将最优控制问题建模为马尔可夫决策过程,然后使用强化学习的Actor-Critic机制(中文译作“知行互动”机制),逐步迭代求解…...
(二)TensorRT-LLM | 模型导出(v0.20.0rc3)
0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述,后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作,其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...
1688商品列表API与其他数据源的对接思路
将1688商品列表API与其他数据源对接时,需结合业务场景设计数据流转链路,重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点: 一、核心对接场景与目标 商品数据同步 场景:将1688商品信息…...
Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级
在互联网的快速发展中,高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司,近期做出了一个重大技术决策:弃用长期使用的 Nginx,转而采用其内部开发…...
微信小程序云开发平台MySQL的连接方式
注:微信小程序云开发平台指的是腾讯云开发 先给结论:微信小程序云开发平台的MySQL,无法通过获取数据库连接信息的方式进行连接,连接只能通过云开发的SDK连接,具体要参考官方文档: 为什么? 因为…...
MySQL中【正则表达式】用法
MySQL 中正则表达式通过 REGEXP 或 RLIKE 操作符实现(两者等价),用于在 WHERE 子句中进行复杂的字符串模式匹配。以下是核心用法和示例: 一、基础语法 SELECT column_name FROM table_name WHERE column_name REGEXP pattern; …...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
Angular微前端架构:Module Federation + ngx-build-plus (Webpack)
以下是一个完整的 Angular 微前端示例,其中使用的是 Module Federation 和 npx-build-plus 实现了主应用(Shell)与子应用(Remote)的集成。 🛠️ 项目结构 angular-mf/ ├── shell-app/ # 主应用&…...
以光量子为例,详解量子获取方式
光量子技术获取量子比特可在室温下进行。该方式有望通过与名为硅光子学(silicon photonics)的光波导(optical waveguide)芯片制造技术和光纤等光通信技术相结合来实现量子计算机。量子力学中,光既是波又是粒子。光子本…...
网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...

