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

pygame 音乐粒子特效

代码

import pygame
import numpy as np
import pymunk
from pymunk import Vec2d
import random
import librosa
import pydub# 初始化pygame
pygame.init()# 创建屏幕
screen = pygame.display.set_mode((1920*2-10, 1080*2-10))
clock = pygame.time.Clock()# 加载音乐文件
audio_file = '周杰伦-周大侠.flac'
audio = pydub.AudioSegment.from_file(audio_file)
audio = audio.set_channels(1)  # 确保音乐是单声道的
audio.export('temp.wav', format='wav')  # 转换为wav格式,因为pygame不支持mp3# 播放音乐
pygame.mixer.init()
pygame.mixer.music.load('temp.wav')
pygame.mixer.music.play(-1)  # -1表示无限循环播放# 转换为波形数组
y, sr = librosa.load('temp.wav')# 提取节奏
tempo, beat_frames = librosa.beat.beat_track(y=y, sr=sr)
beat_times = librosa.frames_to_time(beat_frames, sr=sr)# 创建pymunk空间
space = pymunk.Space()
space.gravity = (0, 0)  # 设置重力# 添加边界
border_thickness = 10
border_offset = border_thickness / 2# 创建边界的四个顶点
bodies = [pymunk.Body(body_type=pymunk.Body.STATIC) for _ in range(4)]
segments = [pymunk.Segment(bodies[0], (border_offset, border_offset), (screen.get_width() - border_offset, border_offset), border_thickness),pymunk.Segment(bodies[1], (screen.get_width() - border_offset, border_offset), (screen.get_width() - border_offset, screen.get_height() - border_offset), border_thickness),pymunk.Segment(bodies[2], (screen.get_width() - border_offset, screen.get_height() - border_offset), (border_offset, screen.get_height() - border_offset), border_thickness),pymunk.Segment(bodies[3], (border_offset, screen.get_height() - border_offset), (border_offset, border_offset), border_thickness)
]# 为边界形状添加到空间中
for body, segment in zip(bodies, segments):space.add(body, segment)  # 同时添加刚体和形状到空间中segment.elasticity = 1.0segment.friction = 0.0# 粒子类
class Particle:def __init__(self, space, position):self.body = pymunk.Body(1, float('inf'))self.body.position = positionself.shape = pymunk.Circle(self.body, 10)self.shape.elasticity = 1.0self.shape.friction = 0.0space.add(self.body, self.shape)self.color = (random.randint(0, 255), random.randint(0, 255), random.randint(0, 255))def draw(self, screen):pos = int(self.body.position.x), int(self.body.position.y)pygame.draw.circle(screen, self.color, pos, int(self.shape.radius))# 创建粒子
particles = [Particle(space, (random.randint(100, 700), random.randint(100, 500))) for _ in range(1000)]# 主循环
running = True
frame = 0
while running:for event in pygame.event.get():if event.type == pygame.QUIT:running = Falsescreen.fill((0, 0, 0))# 更新pymunk空间space.step(1/60.0)# 根据音乐节奏更新粒子速度if frame < len(beat_times) and pygame.time.get_ticks() / 1000 > beat_times[frame]:for particle in particles:impulse = Vec2d(random.uniform(-50, 50), random.uniform(-50, 50))particle.body.apply_impulse_at_local_point(impulse)frame += 1# 绘制粒子for particle in particles:particle.draw(screen)pygame.display.flip()clock.tick(60)pygame.quit()

解释

这段代码是一个使用Pygame和Pymunk库创建的音乐可视化效果。它加载一个音乐文件,提取音乐的节奏,并根据节奏在屏幕上创建和更新粒子的位置。以下是代码的详细解释:

  1. 导入所需的库:pygame用于图形和声音,numpy用于数学运算,pymunk用于物理模拟,random用于生成随机数,librosapydub用于处理音乐文件。
  2. 初始化Pygame并创建一个屏幕。
  3. 加载音乐文件,将其转换为单声道,并导出为WAV格式,因为Pygame不支持MP3格式。
  4. 使用pygame.mixer播放音乐。
  5. 使用librosa将音乐文件转换为波形数组,并提取音乐的节奏。
  6. 创建一个Pymunk空间,设置重力为0,并添加边界。
  7. 定义一个Particle类,用于创建和绘制粒子。
  8. 创建一个粒子列表,每个粒子都有一个随机位置。
  9. 主循环:处理事件,更新Pymunk空间,根据音乐节奏更新粒子速度,绘制粒子,并更新屏幕。
  10. 退出Pygame。
    这个代码的主要特点是使用音乐的节奏来控制粒子的运动,创造出一种动态的音乐可视化效果。
    在这里插入图片描述
http://www.lryc.cn/news/395123.html

相关文章:

  • Leetcode 295.数据流的中位数
  • A59 STM32_HAL库函数 之 TIM扩展驱动 -- A -- 所有函数的介绍及使用
  • 【Unity】UGUI的基本介绍
  • MySQL 9.0新特性:向量存储
  • ruoyi实用性改造--(四)选择数据源及非标准使用数据库
  • HMI 的 UI 风格创造奇迹
  • 如何安全隐藏IP地址,防止网络攻击?
  • Windows10/11家庭版开启Hyper-V虚拟机功能详解
  • 202487读书笔记|《我有个拥抱,你要不要》——生活从来如此,你的态度赋予它意义
  • 使用tcpdump抓取本本机的所有icmp包
  • Nginx:负载均衡小专题
  • 新增多种图表类型,新增插件管理模块,DataEase开源数据可视化分析工具v2.8.0发布
  • android perfetto使用技巧梳理
  • bond网络配置文件中zone
  • spring事务详解
  • LIMS系统的核心功能有哪些
  • jenkins在使用pipeline时,为何没有方块形视图
  • Desktop docker 部署 WordPress
  • 简单的找到自己需要的flutter ui 模板
  • SpringBoot实现多数据源切换
  • VUE + 小程序 关于前端循环上传附件页面卡死的问题
  • 【基础算法总结】分治—归并
  • 基于Java+SpringMvc+Vue技术的实验室管理系统设计与实现(6000字以上论文参考)
  • 19_谷歌GoogLeNet(InceptionV1)深度学习图像分类算法
  • clickhouse高可用可拓展部署
  • QT中QDomDocument读写XML文件
  • sql盲注
  • 星网安全产品线成立 引领卫星互联网解决方案创新
  • Adam自适应动量优化算法
  • Mac OS系统中Beyond Compare 4破解方式