Pygame详解:music 模块

苏画
2021-04-10 / 0 评论 / 132 阅读 / 正在检测是否收录...
温馨提示:
本文最后更新于2021年12月23日,已超过826天没有更新,若内容或图片失效,请留言反馈。

pygame.mixer.music
Pygame 中控制音频流的模块。

函数

pygame.mixer.music.load()  ——  载入一个音乐文件用于播放
pygame.mixer.music.play()  ——  开始播放音乐流
pygame.mixer.music.rewind()  ——  重新开始播放音乐
pygame.mixer.music.stop()  ——  结束音乐播放
pygame.mixer.music.pause()  ——  暂停音乐播放
pygame.mixer.music.unpause()  ——  恢复音乐播放
pygame.mixer.music.fadeout()  ——  淡出的效果结束音乐播放
pygame.mixer.music.set_volume()  ——  设置音量
pygame.mixer.music.get_volume()  ——  获取音量
pygame.mixer.music.get_busy()  ——  检查是否正在播放音乐
pygame.mixer.music.set_pos()  ——  设置播放的位置
pygame.mixer.music.get_pos()  ——  获取播放的位置
pygame.mixer.music.queue()  ——  将一个音乐文件放入队列中,并排在当前播放的音乐之后
pygame.mixer.music.set_endevent()  ——  当播放结束时发出一个事件
pygame.mixer.music.get_endevent()  ——  获取播放结束时发送的事件

Pygame 中播放音乐的模块和 pygame.mixer 模块是密切联系的。使用音乐模块去控制在调音器上的音乐播放。

音乐(music)播放和声音(sound)播放的不同之处在于音乐是流式的,并且绝对不会在一开始就把一个音乐文件全部载入。调音系统在工作刚开始时仅支持单音乐流。

注意:对于 MP3 格式的支持是受限制的。在一些系统上,一种不受支持的格式将会是系统崩溃,例如 Debian Linux。为了游戏的稳定性,建议使用 OGG 进行替代。

函数详解

pygame.mixer.music.load()

载入一个音乐文件用于播放。

load(filename) -> None

load(object) -> None

该函数将会载入一个音乐文件名或者文件对象,并且准备播放。如果已经有音乐流正在播放,该音乐流将被停止。另外,函数不会开始播放音乐。

pygame.mixer.music.play()

开始播放音乐流。

play(loops=0, start=0.0) -> None

该函数用于播放已载入的音乐流。如果音乐已经开始播放,则将会重新开始播放。

loops 参数控制重复播放的次数,例如 play(5) 意味着被载入的音乐将会立即开始播放 1 次并且再重复 5 次,共 6 次。如果 loops = -1,则表示无限重复播放。

start 参数控制音乐从哪里开始播放。开始的位置取决于音乐的格式。MP3 和 OGG 使用时间表示播放位置(以秒为单位)。MOD使用模式顺序编号表示播放位置。如果音乐文件无法设置开始位置,则传递了start参数后会产生一个NotImplementedError 错误。

pygame.mixer.music.rewind()

重新开始播放音乐。

rewind() -> None

从文件开头开始重新播放音乐。

pygame.mixer.music.stop()

结束音乐播放。

stop() -> None

如果音乐正在播放则立即结束播放。

pygame.mixer.music.pause()

暂停音乐流的播放。

pause() -> None

通过调用 pygame.mixer.music.unpause() 函数继续播放音乐。

pygame.mixer.music.unpause()

恢复音乐播放。

unpause() -> None

在播放暂停后使用该函数可以继续音乐流的播放。

pygame.mixer.music.fadeout()

淡出的效果结束音乐播放。

fadeout(time) -> None

该函数将会在音乐淡出(也就是不在有声音放出)一段指定长度的时间(以毫秒为单位)后结束播放。

注意:该函数在调用后会一直处于阻塞状态,直到音乐已经淡出。

pygame.mixer.music.set_volume()

设置音量。

set_volume(value) -> None

设置音乐的播放音量。

value 参数值范围为 0.0~1.0。当新的音乐文件被载入,音量会被重置。

pygame.mixer.music.get_volume()

获取音量。

get_volume() -> value

返回正在播放的音乐的音量(此音量应该是调音器音量,注意与其他音量参数区分)。返回值范围为 0.0~1.0。

pygame.mixer.music.get_busy()

检查是否正在播放音乐。

get_busy() -> bool

如果有音乐流正在播放,此方法返回 True。否则返回 False。

pygame.mixer.music.set_pos()

设置播放的位置。

set_pos(pos) -> None

设置播放的起始位置。pos 参数是一个浮点数(或者一个可以转换为浮点数的数值),其值取决于音乐文件的格式:

对于 MOD 文件,它是模块中的整型模式号;
对于 OGG 文件,它是一个以音频开头为零点的绝对时间值(以秒为单位);
对于 MP3 文件,它是以当前播放位置为零点的绝对时间值(以秒为单位)。

为了对一个 MP3 文件的进行绝对定位,建议首先调用 rewind() 函数(其他文件格式不受支持)。SDL_mixer 更新的版本提供了更好的定位支持。如果一种特殊的格式不支持定位,将会产生一个 SDLError 错误。

该函数会调用 SDL_mixer 内的 Mix_SetMusicPosition() 函数。

pygame.mixer.music.get_pos()

获取播放的位置。

get_pos() -> time

此函数会获得音乐的播放时长(以毫秒为单数的数值)。返回值仅代表已经音乐已经播放了多久,并不考虑任何起始位置偏移量。

pygame.mixer.music.queue()

将一个音乐文件放入队列中,并排在当前播放的音乐之后。

queue(filename) -> None

此函数将会载入一个音乐文件并将其放入队列中。当前的音乐一旦播放完毕,正在排队的音乐文件就会开始播放。如果当前音乐被人为停止或者切换到其他音乐,则正在排队的音乐会被丢弃。

下面的示例意思是先播放 6 次 Bach 然后再播放 1 次 Mozart:

pygame.mixer.music.load('bach.ogg')
pygame.mixer.music.play(5)        # Plays six times, not five!
pygame.mixer.music.queue('mozart.ogg')

pygame.mixer.music.set_endevent()

当播放结束时发出一个事件。

set_endevent() -> None

set_endevent(type) -> None

调用此函数会使 Pygame 在音乐结束播放后发出信号(通过事件队列)。

type 参数决定了什么样的事件将被放入事件队列中。

任何时候音乐结束,都会放入指定事件到队列中(不仅仅是第一次)。调用该函数并不带任何参数,表示停止投放事件到队列中。

pygame.mixer.music.get_endevent()

获取播放结束时发送的事件。

get_endevent() -> type

返回音乐结束时被放入队列的事件类型。

如果没有指定 endevent 事件,此方法会返回 pygame.NOEVENT 。

0

评论 (0)

取消