- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在熟悉如何使用 AudioUnit 来播放声音,但对数据包和帧的概念感到困惑。我想知道:
AudioUnit上下文中数据包和帧的定义是什么
每个数据包使用多个样本以及每个帧使用多个数据包的交易是什么
我提问的原因:在迄今为止我看到的所有代码示例中,数据包本质上是一个示例,对于 16 位立体声流,通常 mBytesPerPacket=4。 mFramesPerPacket 通常为 1,使得帧、数据包和样本(都是立体样本)成为相同的概念。
我期望数据包和/或帧成为样本缓冲区,即一组 256 或 512 个连续样本,驱动程序可以指向并线性读取它们。将帧/数据包大小减少到一个样本似乎会给负责播放数据的任何驱动程序带来不必要的压力。我缺少什么?
最佳答案
首先,一些定义:
您不应该混淆数据包和帧,事实上 mFramesPerPacket
通常应设置为 1。这并不意味着您的 AudioUnit 的 render 方法将在每帧获得回调。如果您想控制发生这种情况的频率,则需要将 kAudioSessionProperty_PreferredHardwareIOBufferDuration 属性设置为首选缓冲区大小。设置此属性并不能保证您所要求的确切缓冲区大小,但系统会尝试为您提供接近此值的值。
关于cocoa - AudioUnit 的数据包和帧大小使用什么值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5561462/
我有一个 AudioUnit,对应的回调正常工作,但现在,我需要将它发送到 RemoteIO,因为我正在实现一些需要 RemoteIO AudioUnit 才能工作的框架。 那么...我需要与此 au
我正在熟悉如何使用 AudioUnit 来播放声音,但对数据包和帧的概念感到困惑。我想知道: AudioUnit上下文中数据包和帧的定义是什么 每个数据包使用多个样本以及每个帧使用多个数据包的交易是什
我有使用 AudioUnit 将正弦波渲染到输出的简单代码。我的问题是:我应该在框架中放入的值范围是多少?我的意思是,在 AudioUnitRender 函数中,我应该为缓冲区数组提供一些音频数据……
我编写了一个简单的 audiounit,它应该交换立体声源的左右声道。对于使用 BASS 库的命令行程序,此代码的移植版本在 C 中运行良好,但我无法让相同的代码在 Xcode 中为 audiouni
我已经实现了一个 AUGraph,其中包含一个 AudioUnit,用于处理来自麦克风和耳机的 IO。我遇到的问题是缺少音频输入 block 。 我相信样本在硬件到软件缓冲区交换期间丢失了。我尝试将
我正在尝试编写一个 iOS 应用程序,从麦克风捕获声音,将其通过高通滤波器,并对处理后的声音进行一些计算。基于 Stefan Popp 的 MicInput ( http://www.stefanpo
所以我的 AudioUnit 从 iOS 中的麦克风/线路输入中获取数据时遇到了一些问题。我能够按照我认为合适的方式设置所有内容,它正在调用我的 recordingCallback,但是我从缓冲区中获
我正在尝试编写一个 iOS 应用程序,它将将从麦克风接收到的声音传递给扬声器而不做任何更改。我读过苹果文档和指南。我从这个 guide 中选择了第一个图案.但什么也没发生——沉默。如您所见,我已尝试使
我的应用程序正在利用 AudioUnit 功能为节拍器应用程序产生短促的声音。一切都运行良好。 现在我想从设备上的 iTunes 库播放 MP3,并使用 MPMusicPlayerController
我的问题涉及音频单元。为了设计适用于 iPhone 的变声应用程序(使用 Objective-C xCode),我使用此网站上的 RemoteIO audioUnit 示例: http://atast
我已经用头撞墙有一段时间了。我的 Xcode 项目在重构时出现了一点困惑,并且拒绝构建。我已经消除了所有其他错误,除了最后一个链接时错误: Framework not found AudioUnit
我可以设置实时播放并在远程 IO 单元之间放置延迟单元以设置延迟效果。 AudioComponentDescription delayDesc; delayDesc.componentType =
我最近在Mac上使用AudioUnits设计了一个录音机。它的设计类似于视频安全系统,可以连续记录,并带有图形化的功率电平显示,以供回放浏览。 我注意到,每85分钟就会出现3分钟的失真。消除了一天之后
用于创建版本3 AudioUnit的示例代码演示了实现如何需要返回功能块以进行渲染处理。该块都将从前一个 通过pullInputBlock链中的AxudioUnit并将处理后的样本提供给输出缓冲区。如
当用户更改参数或预设时,我如何/何时实际更新仪器? AUInstrumentBase 中没有ParameterUpdated 或PresetSelected 类型的方法/回调 最佳答案 相关机制是 A
对于音频单元,您必须像这样将节点添加到图表中...... AUGraphAddNode(processingGraph, &mixerUnitDescription, &mixerNode) AUGr
我在想是否有可能获得对 AudioUnit 记录(可能结束播放)设备的独占访问,以确保在我工作时(最终甚至在后台)任何其他进程都不会访问它? 任何建议都会有帮助。 提前谢谢您! 最佳答案 您的应用在前
我正在构建一个应用程序,该应用程序涉及在应用均衡 (EQ) 效果的同时播放用户音乐库中的歌曲。我以前只使用过 AudioUnits 来生成声音,所以我遇到了一些麻烦。 我当前的计划是使用 AVAsse
我正在尝试实现播放通过套接字从远程服务器接收到的 pcm 音频。这是我之前的问题 link .这工作正常,因为我使用循环缓冲区始终输入传入缓冲区。 但是我有一个问题,如果我没有为我的输出提供缓冲区,就
我使用 AudioUnit 以 8 KHz 采样率和 8 位音频样本录制和播放音频。我使用以下来源的示例:https://github.com/fuxx/MicInput 播放部分基于回调模式。使用这
我是一名优秀的程序员,十分优秀!