用 Python 模拟下雨效果
用 Python 模拟下雨效果
雨天别有一番浪漫情怀:淅淅沥沥的雨滴、湿润的空气、朦胧的光影……在屏幕上也能感受下雨的美妙。本文将带你用一份简单的 Python 脚本,手把手实现「下雨效果」动画。文章深入浅出,零基础也能快速上手,完整代码仅需一个脚本文件即可运行。
目录
- 前言
- 环境准备
- 雨滴模拟原理
- 实现思路
- 完整脚本讲解
- 完整脚本代码
- 运行效果
- 拓展思考
- 结语
前言
在图形编程中,常见的视觉特效之一就是雨滴下落动画。无论是游戏背景、界面装饰,还是演示特效,模拟下雨都能增添生动氛围。本示例使用 Python 结合 Pygame 库,在窗口中绘制无数条雨线,并让它们以不同速度、位置、长度滑落,形成自然的雨幕效果。整个过程非常直观,适合刚接触 Python GUI 或图形编程的新手。
环境准备
- Python 版本:建议 3.6 及以上
- 依赖库:Pygame
在命令行中执行:
pip install pygame
若出现安装问题,可尝试升级 pip:
pip install --upgrade pip
雨滴模拟原理
要模拟下雨效果,核心思想是:
-
雨滴属性
- 位置
(x, y)
:雨滴当前坐标。 - 长度
length
:模拟不同距离或速度导致的雨滴长短差异。 - 速度
speed
:决定雨滴下落的快慢,可与length
相关。
- 位置
-
下落逻辑
- 每帧 (frame) 更新时,让
y += speed
。 - 若
y
超出窗口底部,高度加上length
后重置到顶部(y = -length
),并随机生成新的x
、length
和speed
。
- 每帧 (frame) 更新时,让
-
绘制方法
- 在 Pygame 窗口中,用
draw.line()
绘制一条短线来代表雨滴。 - 背景每帧需重绘为深色,以清除上一帧的残影。
- 在 Pygame 窗口中,用
实现思路
-
初始化
- 导入模块、初始化 Pygame,设置窗口宽高与帧率 (FPS)。
-
创建雨滴列表
- 根据需求生成多个
Raindrop
实例,存放于列表中。
- 根据需求生成多个
-
主循环
- 处理退出事件。
- 填充背景色。
- 遍历雨滴列表,更新位置并绘制。
- 刷新显示并控制帧率。
-
优雅退出
- 当检测到窗口关闭事件,退出循环并调用
pygame.quit()
。
- 当检测到窗口关闭事件,退出循环并调用
完整脚本讲解
下面逐段讲解脚本中关键部分。
import pygame, random, sys
pygame
:图形窗口与绘图操作。random
:生成随机位置与属性。sys
:退出程序使用。
class Raindrop:def __init__(self, screen_width, screen_height):self.screen_width = screen_widthself.screen_height = screen_heightself.reset()
Raindrop
类用于封装单个雨滴。传入屏幕尺寸以便重置时随机生成坐标。
def reset(self):self.x = random.randint(0, self.screen_width)self.y = random.randint(-self.screen_height, 0)self.length = random.randint(5, 15)self.speed = random.uniform(4, 10) * (self.length / 10)
reset()
随机分配x
、y
、length
、speed
。y
在[-screen_height, 0]
范围随机初始,保证雨幕一开始就满屏。- 速度与长度挂钩,长雨滴下落更快,增强透视感。
def fall(self):self.y += self.speedif self.y > self.screen_height:self.reset()
fall()
更新y
坐标,若超出底部则重置回顶部。
def draw(self, surface):end_y = self.y + self.lengthpygame.draw.line(surface, (180, 180, 255), (self.x, self.y), (self.x, end_y), 1)
- 用浅蓝色
(180,180,255)
绘制细线代表雨滴。
接着是主程序部分,负责窗口创建、循环与事件处理。
完整脚本代码
请将以下代码保存为
rain.py
,然后在命令行执行python rain.py
即可查看下雨效果。
import pygame, random, sysclass Raindrop:def __init__(self, screen_width, screen_height):self.screen_width = screen_widthself.screen_height = screen_heightself.reset()def reset(self):self.x = random.randint(0, self.screen_width)self.y = random.randint(-self.screen_height, 0)self.length = random.randint(5, 15)self.speed = random.uniform(4, 10) * (self.length / 10)def fall(self):self.y += self.speedif self.y > self.screen_height:self.reset()def draw(self, surface):end_y = self.y + self.lengthpygame.draw.line(surface, (180, 180, 255), (self.x, self.y), (self.x, end_y), 1)def main():pygame.init()screen_width, screen_height = 800, 600screen = pygame.display.set_mode((screen_width, screen_height))pygame.display.set_caption("Python 雨滴模拟")clock = pygame.time.Clock()# 初始化雨滴raindrops = [Raindrop(screen_width, screen_height) for _ in range(300)]# 主循环running = Truewhile running:for event in pygame.event.get():if event.type == pygame.QUIT:running = False# 填充背景screen.fill((10, 10, 30))# 更新并绘制每个雨滴for drop in raindrops:drop.fall()drop.draw(screen)# 刷新显示pygame.display.flip()clock.tick(60)pygame.quit()sys.exit()if __name__ == "__main__":main()
运行效果
运行后,你将看到一个 800×600 的深色窗口,无数细细的浅蓝色雨滴以不同速度从顶部滑落,形成层次分明的雨幕。若想更贴近真实,可以:
- 调整颜色:将
(180,180,255)
改为其他色值。 - 改变雨滴数量:修改
raindrops
列表长度(300 可增可减)。 - 添加风向:在
fall()
中改变x
坐标,模拟风吹雨打效果。
拓展思考
- 视差效果
将雨滴分为「前景」「中景」「远景」三组,分别使用不同速度、颜色与透明度,营造深度感。 - 撞击水面
当雨滴落到预设的“地面”高度,可在底部绘制一圈淡淡的水花动画。 - 粒子系统
为水花使用粒子系统,让每个水花粒子具有衰减、弹跳特性,更真实。
结语
本文以最简单的 Pygame 用例,向你展示如何在 Python 中模拟下雨特效。核心思路就是不断重置和重绘雨滴坐标,通过随机属性让画面更具丰富性。动手运行一下,相信你会对图形编程更加感兴趣。后续可以在此基础上加入更多效果,打造属于自己的雨天场景。祝学习愉快!
相关文章:

用 Python 模拟下雨效果
用 Python 模拟下雨效果 雨天别有一番浪漫情怀:淅淅沥沥的雨滴、湿润的空气、朦胧的光影……在屏幕上也能感受下雨的美妙。本文将带你用一份简单的 Python 脚本,手把手实现「下雨效果」动画。文章深入浅出,零基础也能快速上手,完…...

C#对象集合去重的一种方式
前言 现在AI越来越强大了,有很多问题其实不需要在去各个网站上查了,直接问AI就好了,但是呢,AI给的代码可能能用,也可能需要调整,但是自己肯定是要会的,所以还是总结一下吧。 问题 如果有一个…...
【LangChain】
以下是关于 LangChain框架 各核心组件的详细解析,结合其功能定位、技术实现和实际应用场景: 一、LangChain Libraries(核心库) 功能定位 跨语言支持:提供Python/JS双版本API,统一不同语言的LLM开发生态 …...
Java 面试实录:从Spring到微服务的技术探讨
在一个明亮的会议室里,严肃的面试官与搞笑的程序员谢飞机正进行一场关于Java技术栈的面试。场景设定在一家知名互联网大厂,他们的对话充满了技术性与娱乐性。 第一轮:Spring框架与数据库 面试官:“谢飞机,能解释一下…...

在ROS2(humble)+Gazebo+rqt下,实时显示仿真无人机的相机图像
文章目录 前言一、版本检查检查ROS2版本 二、步骤1.下载对应版本的PX4(1)检查PX4版本(2)修改文件名(3)下载正确的PX4版本 2.下载对应版本的Gazebo(1)检查Gazebo版本(2)卸载不正确的Gazebo版本(3)下载正确的Gazebo版本 3.安装bridge包4.启动 总结 前言 在ROS2的环境下ÿ…...

github双重认证怎么做
引言 好久没登陆github了, 今天登陆github后,提醒进行2FA认证。 查看了github通知,自 2023 年 3 月起,GitHub 要求所有在 GitHub.com 上贡献代码的用户启用一种或多种形式的双重身份验证 (2FA)。 假如你也遇到这个问题…...

数据的类型——认识你的数据
第02篇:数据的类型——认识你的数据 写在前面:嗨,大家好!我是蓝皮怪。在上一篇文章中,我们聊了统计学的基本概念,今天我们来深入了解一个非常重要的话题——数据的类型。你可能会想:"数据就…...
DeepSeek与AI提示语设计的全面指南
文章目录 什么是提示语设计?为什么提示语设计如此重要?DeepSeek提示语设计的基本原则1. 明确性是王道2. 结构化你的需求3. 提供上下文4. 指定输出格式5. 使用示例6. 设定角色 进阶技巧:让你的提示语更上一层楼1. 链式思考2. 反向提问3. 限定条…...
Kafka KRaft + SSL + SASL/PLAIN 部署文档
本文档介绍如何在 Windows 环境下部署 Kafka 4.x,使用 KRaft 模式、SSL 加密和 SASL/PLAIN 认证。stevensu1/kafka_2.13-4.0.0 1. 环境准备 JDK 17 或更高版本Kafka 4.x 版本(本文档基于 kafka_2.13-4.0.0) 2. 目录结构 D:\kafka_2.13-4.…...
Codeforces Round 1027 (Div. 3)
A. Square Year 题目大意:拆分完全平方数。 【解题】:如果是完全平方数输出0 平方根就行,不是就输出-1。 code: #include <iostream> #include <string> #include <cmath> using namespace std; typedef long long LL…...
动态内容加载时,爬虫应如何处理?
处理动态内容加载是爬虫开发中的一个常见挑战。许多现代网站使用 JavaScript 动态加载内容,这意味着页面的某些部分可能在初始加载时并不存在,而是通过后续的 AJAX 请求或 JavaScript 执行动态生成的。为了处理这种情况,爬虫需要能够模拟浏览…...

第五十二节:增强现实基础-简单 AR 应用实现
引言 增强现实(Augmented Reality, AR)是一种将虚拟信息叠加到真实世界的技术,广泛应用于游戏、教育、工业维护等领域。与传统虚拟现实(VR)不同,AR强调虚实结合,用户无需完全沉浸到虚拟环境中。本文将通过Python和OpenCV库,从零开始实现一个基础的AR应用:在检测到特定…...
前端高频面试题1:HTML/CSS/浏览器/计算机网络
目录 1.为什么会出现margin塌陷? 2.如何解决margin塌陷? 3.HTML5有哪些新特性? 4.常见的语义化标签有哪些?语义化标签的好处? 5.使用css和js做动画有何优劣 6.如何实现文本超出展示省略号 7.deep在css中存在吗&…...

LLaMaFactory 微调QwenCoder模型
步骤一:准备LLamaFactory环境 首先,让我们尝试使用github的方式克隆仓库: git config --global http.sslVerify false && git clone --depth 1 https://github.com/hiyouga/LLaMA-Factory.git # 创建新环境,指定 Python 版本(以 3.…...
Git全流程操作指南
Git全流程操作指南 一、Git 环境配置 1. 安装 Git Windows:下载 Git for Windows macOS:brew install git Linux: sudo apt-get update && sudo apt-get install git # Debian/Ubuntu sudo yum install git …...

【最新版】Arduino IDE的安装入门Demo
1、背景说明 1、本教程编写日期为2025-5-24 2、Arduino IDE的版本为:Arduino IDE 2.3.6 3、使用的Arduino为Arduino Uno 1、ArduinoIDE的安装 1、下载。网址如下:官网 2、然后一路安装即可。 期间会默认安装相关驱动,默认安装即可。 3、安…...

不起火,不爆炸,高速摄像机、数字图像相关DIC技术在动力电池新国标安全性能测试中的应用
2026年7月1日,我国将正式实施GB38031-2025《电动汽车用动力蓄电池安全要求》——这项被称为“史上最严电池安全令”的新国标,首次将“热失控不蔓延、不起火、不爆炸”从企业技术储备上升为强制性要求,标志着电池安全进入“零容忍”时代&#…...

thinkadmin中使用layui日期选择器,数据库存储时间戳
form.html <div class="layui-form-item label-required-prev" id="jiezhi_time-div">...

WSL中ubuntu通过Windows带代理访问github
WSL中ubuntu通过Windows带代理访问github 前言: WSL是Windows下的ubuntu访问工具,目前无法访问外网,因此需要配置一下。 步骤一 代理中进行如下设置: 步骤二 ubuntu22.04中修改配置 使用如下命令获取IP地址: ip route | grep default | aw…...

RISC-V特权模式及切换
1 RISC-V特权模式基本概念 1.1 RISC-V特权模式介绍 RISC-V 指令集架构(ISA)采用多特权级别设计作为其核心安全机制,通过层次化的权限管理实现系统资源的隔离与保护。该架构明确定义了四个层次化的特权模式,按照权限等级由高至低…...
Python爬虫实战:研究Tornado框架相关技术
1. 引言 1.1 研究背景与意义 网络爬虫作为一种自动获取互联网信息的程序,在信息检索、数据挖掘、舆情分析等领域有着广泛的应用。随着互联网数据量的爆炸式增长,对爬虫的性能和效率提出了更高的要求。传统的同步爬虫在处理大量 URL 时效率低下,而异步爬虫可以显著提高并发…...

【深度学习】11. Transformer解析: Self-Attention、ELMo、Bert、GPT
Transformer 神经网络 Self-Attention 的提出动机 传统的循环神经网络(RNN)处理序列信息依赖时间步的先后顺序,无法并行,而且在捕捉长距离依赖关系时存在明显困难。为了解决这些问题,Transformer 引入了 Self-Attent…...
Ubuntu实现和主机的复制粘贴 VMware-Tools(open-vm-tools)
Ubuntu实现和主机的复制粘贴 VMware-Tools(open-vm-tools) 1.安装open-vm-tools # 更新软件源并安装工具包 sudo apt update sudo apt install open-vm-tools open-vm-tools-desktop -y2.启用剪贴板共享 sudo nano /etc/vmware-tools/tools.conf添加或…...

4060显卡什么水平 4060显卡参数介绍
NVIDIA的GeForce RTX 40系列显卡基于最新的Ada Lovelace架构,提供了前所未有的图形处理能力和效率。其中,RTX 4060定位中高端市场,针对那些寻求卓越性能同时又注重成本效益的用户群体。那么,4060显卡什么水平呢?本文将…...
Kafka Producer 如何实现Exactly Once消息传递语义
Exactly-Once (精确一次) 是 Kafka 中最高级别的消息传递语义,确保消息既不会丢失也不会重复。以下是 Kafka Producer 实现 Exactly-Once 语义的关键机制: 1. 实现方法 1.1 启用幂等性 (Idempotence) props.put("enable.idempotence", &quo…...
通过ansible playbook创建azure 资源
安装 Ansible 在 macOS 上 Ansible 可以通过多种方式在 macOS 上安装,推荐使用 pip 或 Homebrew。 使用 Homebrew 安装 Ansible 运行以下命令: brew install ansible使用 pip 安装 Ansible 确保 Python 已安装(macOS 通常自带 Python),然后运行: pip install ansible…...
C++双线程交替打印奇偶数(活泼版)
C双线程交替打印奇偶数(活泼版) 文章目录 C双线程交替打印奇偶数(活泼版)1.🎮 游戏规则说明书2.🔧 游戏道具准备区2.1🧩 道具清单 3.👯♂️ 创建两个线程小伙伴3.1🧑…...

技术为器,服务为本:AI时代的客服价值重构
在智能化浪潮中,大语言模型的出现为客户服务行业注入了全新动能。然而技术创新的价值不在于技术本身,而在于其赋能服务的深度与广度。AI对于我们来说,如同发动机之于汽车,重要的不是引擎参数,而是整车带给用户的驾驶体…...
hadoop异构存储
Hadoop异构存储是一种基于HDFS的存储优化技术,通过将不同热度的数据分配到不同类型的存储介质上实现性能与成本的平衡。以下是其核心原理和实现方式: 一、核心概念 异构存储基本原理:Hadoop集群允许使用SSD、HDD、ARCHIVE等多种存储介质…...

EasyVoice:开源的文本转语音工具,让文字“开口说话“
名人说:博观而约取,厚积而薄发。——苏轼《稼说送张琥》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 一、EasyVoice是什么?1. 核心特性一览2. 技术架构概览 二、安装部署指南…...