1# OpenSL ES 2 3> **说明:** 4> OpenHarmony上的OpenSL ES接口,是早期SDK8版本开始提供,用于支持应用Native层音频开发的接口。但随着版本演进,接口定义的可扩展性不足,不再能满足音频系统的能力拓展,因此当前已不再推荐应用开发者继续使用此接口进行音频功能开发, 5> 请开发者[从OpenSL ES切换到OHAudio](../../media/audio/replace-opensles-by-ohaudio.md)。 6 7## 简介 8 9OpenSL ES(Open Sound Library for Embedded System)即嵌入式音频加速标准。为开发者提供了标准化、高性能以及低响应时间的音频功能开发的对象和接口。相对于开源免费的OpenSL ES,OpenHarmony基于[OpenSL ES](https://www.khronos.org/opensles/) 1.0.1 API规范实现了部分Native API,相关接口开放情况如表[支持的API](#支持的api)所示。 10 11## 引入OpenSL ES能力 12 13如果开发者需要使用OpenSL ES相关功能,首先请添加头文件: 14 15``` 16#include <SLES/OpenSLES.h> 17#include <SLES/OpenSLES_OpenHarmony.h> 18#include <SLES/OpenSLES_Platform.h> 19``` 20 21其次在CMakeLists.txt中添加以下链接动态库 22 23``` 24libOpenSLES.so 25``` 26 27## 支持的API 28 29|对象 |对外接口 |接口调用详情 |是否支持 |说明 | 30| ------------------ | -------------------- | -------------------------------------------------------------------------------------|----------| -------------------- | 31|SLEngineItf |CreateAudioPlayer |CreateAudioPlayer(SLEngineItf self, SLObjectItf *pPlayer, SLDataSource *pAudioSrc, SLDataSink *pAudioSnk, SLuint32 numInterfaces, const SLInterfaceID *pInterfaceIds, const SLboolean *pInterfaceRequired) |是 |创建音频播放机。 | 32|SLEngineItf |CreateAudioRecorder |reateAudioRecorder(SLEngineItf self, SLObjectItf *pRecorder, SLDataSource *pAudioSrc, SLDataSink *pAudioSnk, SLuint32 numInterfaces, const SLInterfaceID *pInterfaceIds, const SLboolean *pInterfaceRequired)|是 |创建音频录制器。 | 33|SLEngineItf |CreateAudioOutputMix |CreateOutputMix(SLEngineItf self, SLObjectItf *pMix, SLuint32 numInterfaces, const SLInterfaceID *pInterfaceIds, const SLboolean *pInterfaceRequired)|是 |创建混音器。 | 34|SLObjectItf |Realize |Realize(SLObjectItf self, SLboolean async) |是 |创建音频播放机。 | 35|SLObjectItf |getState |GetState(SLObjectItf self, SLuint32 *pState) |是 |获取状态。 | 36|SLObjectItf |getInterface |GetInterface(SLObjectItf self, const SLInterfaceID iid, void *pInterface) |是 |获取接口。 | 37|SLObjectItf |Destroy |Destroy(SLObjectItf self) |是 |销毁对象。 | 38|SLOHBufferQueueItf |Enqueue |Enqueue(SLOHBufferQueueItf self, const void *pBuffer, SLuint32 size) |是 |将buffer加入实际队列中。| 39|SLOHBufferQueueItf |clear |Clear(SLOHBufferQueueItf self) |是 |释放buffer队列 | 40|SLOHBufferQueueItf |getState |GetState(SLOHBufferQueueItf self, SLOHBufferQueueState *pState) |是 |获取BufferQueue状态。 | 41|SLOHBufferQueueItf |getBuffer |GetBuffer(SLOHBufferQueueItf self, SLuint8 **buffer, SLuint32 *size) |是 |获取buffer。 | 42|SLOHBufferQueueItf |RegisterCallback |RegisterCallback(SLOHBufferQueueItf self, SlOHBufferQueueCallback callback, void *pContext) |是 |注册回调函数。 | 43|SLPlayItf |SetPlayState |SetPlayState(SLPlayItf self, SLuint32 state) |是 |设置播放状态。 | 44|SLPlayItf |GetPlayState |GetPlayState(SLPlayItf self, SLuint32 *pState) |是 |获取播放状态。 | 45|SLRecordItf |SetRecordState |SetRecordState(SLRecordItf self, SLuint32 state) |是 |设置录制状态。 | 46|SLRecordItf |GetRecordState |GetRecordState(SLRecordItf self, SLuint32 *pState) |是 |获取录制状态。 | 47|SLVolumeItf |SetVolumeLevel |SetVolumeLevel(SLVolumeItf self, SLmillibel level) |是 |设置音量。 | 48|SLVolumeItf |GetVolumeLevel |GetVolumeLevel(SLVolumeItf self, SLmillibel *pLevel) |是 |获取音量。 | 49|SLVolumeItf |GetMaxVolumeLevel |GetMaxVolumeLevel(SLVolumeItf self, SLmillibel *pMaxLevel) |是 |获取最大音量。 |