我正在寻找一个音频处理库,我可以用它在我的程序中进行一些即时音频编辑,例如转动一个旋钮,它会增加正在播放的音频文件的音调,而不会将更改保存到歌曲文件本身。我计划为windows和mac制作这个程序,所以我需要一个跨平台库。我没有太多闲钱,所以也不能花太多钱。如果有任何改变,我的程序将可以在市场上买到。在此先感谢您的帮助。 最佳答案 SoX位于http://sox.sourceforge.net/http://www.speech.kth.se/wavesurfer/处的Wavesurfer
关闭。这个问题是off-topic.它目前不接受答案。想改进这个问题吗?Updatethequestion所以它是on-topic用于堆栈溢出。关闭10年前。Improvethisquestion我有(控制台)程序flac.exe,我希望能够将一个目录中的所有flac文件解码为wav,而不必一次做每一个。我试过:flac-d*.flac但它在尝试创建wav文件时出错。
正如我在anotherquestion中提到的那样,我在使用Qt5.1的多媒体模块时遇到了问题。QMediaPlayer类不能播放一些MP3文件。我还没有彻底测试其他格式。我不确定这是否是与编解码器相关的问题。但我感兴趣的是直接在我的程序中使用编解码器,而不是依赖后端支持来播放媒体文件。我将在Qt5.1中为桌面Windows平台开发应用程序。我不知道在程序中使用编解码器。任何指针将不胜感激。 最佳答案 可以去【FFMPEG】:http://www.ffmpeg.org/集成开源编解码器来播放您的媒体文件。
我正在使用WASAPI编写专业音频应用程序。我机器上的所有设备都有16位或24位PCM的引擎格式。考虑到这一点,我想知道假设所有音频端点都将PCM作为其native格式是否安全。是吗?如果没有,什么样的设备没有? 最佳答案 假设所有设备都是16位或24位PCM绝对是不安全的。我知道选择正确的格式是一个很大的技巧。但它也可能类似于32位IeeeFloat。但是,作为用户,您只能设置16或24位->大多数情况下是16或24位。反正。您也可以使用独占模式。在独占模式下,你可以自己指定一种格式。但请记住:您必须被允许使用独占模式并且使用独占
Windows在这方面有太多的API太荒谬了。据说MediaFoundation是执行此操作的方法,但我在MSDN文档中看到很多“已弃用”,并且他们提供的示例仅用于从URL播放音乐。我在内存中有一个压缩的音频文件(mp3、m4a等)。现在我正在使用他们的CPlayer示例。(https://msdn.microsoft.com/en-us/library/windows/desktop/bb970516(v=vs.85).aspx)。有没有办法让MediaFoundation从内存中加载源?或者我是否必须在单独的线程中解压缩它并将其提供给XAudio2? 最
我希望这是有道理的,我不确定我应该怎么说这个...您好,我正在尝试编写一个能够监控某些进程的音频输出的程序。我很难找到一种方法来真正做到这一点。我只能找到获取当前音量级别的方法,而不是实际输出级别。我一直在通过Stackoverflow进行搜索,但我发现的所有内容都只能获取程序的音量控制级别(如Windows音量混合器中的slider,但我基本上是想获取blender)我基本上想每隔x毫秒检查一次程序的输出级别,如果它高于某个阈值,则运行一个方法来做某事。我怎样才能做到这一点?谢谢!快速编辑清楚:Win7+withC++ 最佳答案
GDI+提供了一个Image类,你可以使用这个类来读取一种格式的图像文件,然后将这个文件保存为另一种格式。但是如果我只想解码一个jpeg文件(已经加载到内存中),我该怎么做呢? 最佳答案 您可以使用SHCreateMemStream和Gdiplus::Image::FromStream#include#include#include#include...CComPtrstream;stream.Attach(SHCreateMemStream(buf,bufsize));Gdiplus::Image*image=Gdiplus::I
我正在尝试用C++修改一些音频文件的元数据,我遇到了[我认为]使用WindowsMediaFoundation的可能方法。所以我尝试整理一个简单的解决方案:#include#include#include#include#pragmacomment(lib,"Mf.lib")#pragmacomment(lib,"Mfplat.lib")intmain(){HRESULThr;CComPtrsource_resolver(nullptr);if(FAILED(hr=MFCreateSourceResolver(&source_resolver))){//Handleerrors...}
我有一blockAJA板,上面连接了一条SDI输入电缆。输入信号嵌入了视频和音频。视频可通过“Vid”引脚访问,音频可通过“Aud1-2”引脚访问。运行良好的DirectShow过滤图:“无直接显示音频设备”:我无法让FFMPEG正确映射音频部分。这是我尝试录制音频但没有成功的方法:ffmpeg-y-rtbufsize2048M-fdshow-iaudio="AJAS-CaptureKonaLHi-0"-acodecpcm_s24le-ar48000output.wavffmpeg-y-rtbufsize2048M-fdshow-audio_pin_name"Aud1-2"-iaudi
是否可以从计算机捕获所有声音并在到达扬声器之前通过均衡器?如何在其上编程带通滤波器?编辑:我正在尝试在Windows上实现这一点(使用Python?呵呵),但如果有一种通用的跨平台方法那就太好了。 最佳答案 在具有实时抢占内核的GNU/Linux平台上,您拥有JACK音频连接套件。简而言之,JACK允许您连接支持JACK的音频程序,这样您就可以从计算机中捕获所有声音。然后您可以将捕获的声音传递到另一个托管您的均衡器插件的JACK音频程序。至少在Linux中,均衡器插件要么是LADSPA插件,要么是LADSPA的后继插件标准LV2。如