BlackHole: 音频回环驱动
BlackHole是一款现代macOS虚拟音频回环驱动程序,允许应用程序以零额外延迟将音频传递给其他应用程序。
下载安装程序
加入Discord服务器
资助
赞助: https://github.com/sponsors/ExistentialAudio
目录
特性
- 构建2、16、64、128和256音频通道版本
- 可自定义通道数、延迟、隐藏设备
- 可自定义镜像设备,允许隐藏输入或输出
- 支持8kHz、16kHz、44.1kHz、48kHz、88.2kHz、96kHz、176.4kHz、192kHz、352.8kHz、384kHz、705.6kHz和768kHz采样率
- 零额外驱动延迟
- 兼容macOS 10.10 Yosemite及更新版本
- 为Intel和Apple Silicon构建
- 无需内核扩展或修改系统安全性
安装说明
选项1:下载安装程序
- 下载最新安装程序
- 关闭所有正在运行的音频应用程序
- 打开并安装软件包
选项2:通过Homebrew安装
- 2通道:
brew install blackhole-2ch
- 16通道:
brew install blackhole-16ch
- 64通道:
brew install blackhole-64ch
卸载说明
选项1:使用卸载程序
选项2:手动卸载
-
使用终端命令删除BlackHole驱动程序:
rm -R /Library/Audio/Plug-Ins/HAL/BlackHoleXch.driver
确保将
X
替换为2
、16
或64
。注意,目录是根目录
/Library
,而不是/Users/user/Library
。 -
使用终端命令重启CoreAudio:
sudo killall -9 coreaudiod
更多具体细节请访问Wiki。
用户指南
Logic Pro X
GarageBand
Reaper
- Reaper到Zoom 作者:Noah Liebman
录制系统音频
- 设置多输出设备
- 在
音频MIDI设置
→音频设备
中右键点击新创建的多输出设备,选择"将此设备用于声音输出" - 打开数字音频工作站(DAW),如GarageBand,将输入设备设置为"BlackHole"
- 将轨道设置为从通道1-2输入
- 从其他应用程序播放音频,并在DAW中监听或录制
在应用程序之间路由音频
- 在发送应用程序中将输出驱动程序设置为"BlackHole"
- 将音频输出到任何通道
- 打开接收应用程序,将输入设备设置为"BlackHole"
- 从相应的输出通道输入音频
开发者指南
所有非GPLv3项目都需要许可证
请支持我们的辛勤工作和持续开发。要请求许可证,请联系Existential Audio。
构建和安装
构建完成后,安装BlackHole:
- 将构建好的
BlackHoleXch.driver
包复制或移动到/Library/Audio/Plug-Ins/HAL
- 使用
sudo killall -9 coreaudiod
重启CoreAudio
自定义BlackHole
可以使用以下预编译常量轻松自定义BlackHole的构建。
kDriver_Name
kPlugIn_BundleID
kPlugIn_Icon
kDevice_Name
kDevice_IsHidden
kDevice_HasInput
kDevice_HasOutput
kDevice2_Name
kDevice2_IsHidden
kDevice2_HasInput
kDevice2_HasOutput
kLatency_Frame_Size
kNumber_Of_Channels
kSampleRates
可以在构建时使用xcodebuild
的GCC_PREPROCESSOR_DEFINITIONS
指定这些常量。
示例:
xcodebuild \
-project BlackHole.xcodeproj \
GCC_PREPROCESSOR_DEFINITIONS='$GCC_PREPROCESSOR_DEFINITIONS kSomeConstant=value'
使用字符串时请确保转义任何引号。
重命名BlackHole
要自定义BlackHole,需要更改以下常量:
kDriver_Name
kPlugIn_BundleID
(注意,这必须与目标bundleID匹配)kPlugIn_Icon
可以使用xcodebuild
将这些指定为预编译常量。
driverName="BlackHole"
bundleID="audio.existential.BlackHole"
icon="BlackHole.icns"
xcodebuild \
-project BlackHole.xcodeproj \
-configuration Release \
PRODUCT_BUNDLE_IDENTIFIER=$bundleID \
GCC_PREPROCESSOR_DEFINITIONS='$GCC_PREPROCESSOR_DEFINITIONS
kDriver_Name=\"'$driverName'\"
kPlugIn_BundleID=\"'$bundleID'\"
kPlugIn_Icon=\"'$icon'\"'
自定义通道、延迟和采样率
kNumber_Of_Channels
用于设置通道数。指定高通道数时要小心。虽然BlackHole在高通道数下设计得非常高效,但你的计算机可能无法跟上。采样率也起作用。不要在高通道数下使用高采样率。一些应用程序不知道如何处理高通道数。请谨慎操作。
kLatency_Frame_Size
是驱动程序处理传入和传出音频所需的时间(以帧为单位)。它可以用来延迟BlackHole内部的音频,最多可达65536帧。如果在高通道数下使用BlackHole,这可能会有帮助。
kSampleRates
设置音频设备的采样率。如果使用多个采样率,请用逗号(,
)分隔。例如:kSampleRates='44100,48000'
。
镜像设备
默认情况下,BlackHole有一个隐藏的镜像音频设备。可以使用以下常量自定义设备。
// 原始设备
kDevice_IsHidden
kDevice_HasInput
kDevice_HasOutput
// 镜像设备
kDevice2_IsHidden
kDevice2_HasInput
kDevice2_HasOutput
当所有设置为true时,将出现第二个完全相同的BlackHole。输入和输出是镜像的,因此两个设备的输出都会进入两个设备的输入。
如果需要单独的输入和输出设备,这很有用。
示例
// 原始设备
kDevice_IsHidden=false
kDevice_HasInput=true
kDevice_HasOutput=false
// 镜像设备
kDevice2_IsHidden=false
kDevice2_HasInput=false
kDevice2_HasOutput=true
在这种情况下,我们有两个BlackHole设备。一个只有输入,另一个只有输出。
在项目中使用这种方法的一种方式是隐藏镜像设备,并在后台使用它。这样用户将看到一个仅输入的设备,同时在后台通过输出路由音频。
可以使用kAudioHardwarePropertyTranslateUIDToDevice
访问隐藏的音频设备。
持续集成/持续部署
BlackHole可以集成到您的CI/CD中。请查看create_installer.shshell脚本,了解安装程序是如何构建、签名和公证的。
功能请求
如果您对以下任何功能感兴趣,请在链接的问题中留下评论。要请求未列出的功能,请创建一个新的问题。
- 与其他音频设备同步时钟 正在开发中,请参见v0.3.0
- 将Blackhole输出到其他音频设备
- 添加对AU插件的支持
- 通道间路由
- 直接录制到文件
- 配置选项菜单
- 支持额外的位深度
常见问题
为什么BlackHole没有出现在应用程序文件夹中?
BlackHole是一个虚拟音频回环驱动程序。它只会出现在音频MIDI设置
、声音偏好设置
或其他音频应用程序中。
如何同时听到音频并使用BlackHole?
请参阅设置多输出设备。
BlackHole使用什么位深度,我可以更改吗?
BlackHole使用32位浮点位深度,因为macOS Core Audio在系统级别原生使用32位。这提供了最广泛的兼容性和最大的音频动态范围。
这种格式对于最高24位整数是无损的。所有应用程序都应该能够播放和录制音频,不需要在BlackHole驱动程序级别调整位深度。
如何更改多输出设备的音量?
遗憾的是,macOS不支持更改多输出设备的音量,但您可以在音频MIDI设置中设置单个设备的音量。
为什么没有声音通过BlackHole播放?
-
检查
系统偏好设置
→安全性与隐私
→隐私
→麦克风
,确保您的数字音频工作站(DAW)应用程序有麦克风访问权限。 -
检查
音频MIDI设置
中BlackHole输入和输出的音量是否已调到最大。 -
如果您使用的是多输出设备,由于macOS的问题,必须启用内置输出并将其列为多输出中的顶部设备。详情请参见此处。
为什么使用多输出或聚合设备时,音频在X分钟后出现故障?
- 您需要为除时钟源(也称为主设备或主要设备)以外的所有设备启用漂移校正。
为什么安装程序失败?
- macOS的某些版本存在一个已知问题,当安装包位于某些文件夹中时可能会安装失败。如果您将.pkg文件下载到下载文件夹,请尝试将其移动到桌面并再次打开.pkg(或反之亦然)。
哪些应用程序不兼容多输出?
遗憾的是,多输出可能会有bug,有些应用程序根本无法使用。以下是已知的不兼容应用列表。如果发现其他不兼容的应用程序,请通过开启问题来报告。
- Apple Podcasts
- Apple Messages
- HDHomeRun
AirPods与聚合/多输出设备不兼容。
AirPods的麦克风以较低的采样率运行,这意味着它不应用作聚合或多输出设备中的主要/时钟设备。解决方案是使用内置扬声器(只需将其静音)或BlackHole 2ch作为主要/时钟设备。BlackHole 16ch不能作为主要设备,因为主要设备需要有2个通道。
更多详情请阅读此讨论。
我可以将BlackHole集成到我的应用程序中吗?
BlackHole采用GPL-3.0许可。只要您的应用程序也采用GPL-3.0许可,您就可以使用BlackHole。对于所有其他应用程序,请直接联系Existential Audio。
链接和资源
MultiSoundChanger
一个小工具,用于更改声音音量,甚至适用于聚合设备,因为原生声音音量控制器无法更改聚合设备的音量
BackgroundMusic
Background Music,一个macOS音频实用程序:自动暂停音乐、设置单个应用程序的音量并录制系统音频。