python实现音频淡入淡出功能

要用到pygame库

复制代码
pip install pygame

示例代码:

python 复制代码
import time
import pygame

class MusicFader:
    def __init__(self,fadeDuration,musicDuration):
        self.fadeDuration=fadeDuration
        self.musicDuration=musicDuration
        self.steps=30

    def fadeIn(self,musicPath=None):#淡入
        if musicPath:
            pygame.mixer.music.load(musicPath)#载入音频
        pygame.mixer.music.set_volume(0.0)#设置初始音量
        pygame.mixer.music.play()#播放音乐

        stepTime=self.fadeDuration/self.steps
        for i in range(self.steps+1):
            volume=i/self.steps
            pygame.mixer.music.set_volume(volume)
            time.sleep(stepTime)
            ##逐步提高音量

    def fadeOut(self):#淡出
        currentVolume=pygame.mixer.music.get_volume()#获取现在音量
        if currentVolume<=0:#如果现在音量为0,停止播放
            pygame.mixer.music.stop()
            return
        
        stepTime=self.fadeDuration/self.steps
        for i in range(self.steps+1):
            volume=currentVolume*(1- i/self.steps)
            pygame.mixer.music.set_volume(max(0,volume))
            time.sleep(stepTime)
            ##逐步降低音量
        pygame.mixer.music.stop()

if __name__ == '__main__':
    pygame.mixer.init()#初始化mixer
    fader=MusicFader(fadeDuration=5.0,musicDuration=83)#5秒淡入淡出,83秒音频时长
    fader.fadeIn('1.mp3')#淡入
    time.sleep(fader.musicDuration-fader.fadeDuration*2)#音乐主体部分(减去了淡入淡出时间)
    fader.fadeOut()#淡出

如果不确定音频文件时长,可以用librosa库

python 复制代码
pip install librosa

改进代码:

python 复制代码
import time
import pygame
import librosa

class MusicFader:
    def __init__(self,fadeDuration,musicDuration):
        self.fadeDuration=fadeDuration
        self.musicDuration=musicDuration
        self.steps=30

    def fadeIn(self,musicPath=None):#淡入
        if musicPath:
            pygame.mixer.music.load(musicPath)#载入音频
        pygame.mixer.music.set_volume(0.0)#设置初始音量
        pygame.mixer.music.play()#播放音乐

        stepTime=self.fadeDuration/self.steps
        for i in range(self.steps+1):
            volume=i/self.steps
            pygame.mixer.music.set_volume(volume)
            time.sleep(stepTime)
            ##逐步提高音量

    def fadeOut(self):#淡出
        currentVolume=pygame.mixer.music.get_volume()#获取现在音量
        if currentVolume<=0:#如果现在音量为0,停止播放
            pygame.mixer.music.stop()
            return
        
        stepTime=self.fadeDuration/self.steps
        for i in range(self.steps+1):
            volume=currentVolume*(1- i/self.steps)
            pygame.mixer.music.set_volume(max(0,volume))
            time.sleep(stepTime)
            ##逐步降低音量
        pygame.mixer.music.stop()

if __name__ == '__main__':
    def getAudioDuration(filePath):
        duration=librosa.get_duration(path=filePath)#读取元数据
        return round(duration,2)#保留两位小数
        
    fadeDuration=5.0#淡入淡出时长
    audio='1.flac'
    musicDuration=getAudioDuration(audio)#音频时长
    
    pygame.mixer.init()#初始化mixer
    fader=MusicFader(fadeDuration=fadeDuration,musicDuration=musicDuration)
    fader.fadeIn(audio)#淡入
    time.sleep(fader.musicDuration-fader.fadeDuration*2+1.8)#音乐主体部分(减去了淡入淡出时间)
    fader.fadeOut()#淡出

这个代码还有些缺陷,比如淡出的时候会过早一点点结束音频导致结尾一部分音频播放不出来

相关推荐
zone773910 小时前
001:简单 RAG 入门
后端·python·面试
F_Quant10 小时前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来11 小时前
在node项目中执行python脚本
前端·python·node.js
IVEN_11 小时前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend12 小时前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽12 小时前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_1 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮1 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling1 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python