99精品伊人亚洲|最近国产中文炮友|九草在线视频支援|AV网站大全最新|美女黄片免费观看|国产精品资源视频|精彩无码视频一区|91大神在线后入|伊人终合在线播放|久草综合久久中文

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

OpenHarmony 3.2 Beta Audio——音頻渲染

OpenAtom OpenHarmony ? 來源:未知 ? 2023-03-11 16:40 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

點擊藍字 ╳ 關(guān)注我們


開源項目 OpenHarmony
是每個人的 OpenHarmony

巴延興

深圳開鴻數(shù)字產(chǎn)業(yè)發(fā)展有限公司

資深OS框架開發(fā)工程師

一、簡介

Audio是多媒體子系統(tǒng)中的一個重要模塊,其涉及的內(nèi)容比較多,有音頻的渲染、音頻的采集、音頻的策略管理等。本文主要針對音頻渲染功能進行詳細地分析,并通過源碼中提供的例子,對音頻渲染進行流程的梳理。

二、目錄

foundation/multimedia/audio_framework
audio_framework
├── frameworks
│ ├── js #js 接口
│ │ └── napi
│ │ └── audio_renderer #audio_renderer NAPI接口
│ │ ├── include
│ │ │ ├── audio_renderer_callback_napi.h
│ │ │ ├── renderer_data_request_callback_napi.h
│ │ │ ├── renderer_period_position_callback_napi.h
│ │ │ └── renderer_position_callback_napi.h
│ │ └── src
│ │ ├── audio_renderer_callback_napi.cpp
│ │ ├── audio_renderer_napi.cpp
│ │ ├── renderer_data_request_callback_napi.cpp
│ │ ├── renderer_period_position_callback_napi.cpp
│ │ └── renderer_position_callback_napi.cpp
│ └── native #native 接口
│ └── audiorenderer
│ ├── BUILD.gn
│ ├── include
│ │ ├── audio_renderer_private.h
│ │ └── audio_renderer_proxy_obj.h
│ ├── src
│ │ ├── audio_renderer.cpp
│ │ └── audio_renderer_proxy_obj.cpp
│ └── test
│ └── example
│ └── audio_renderer_test.cpp
├── interfaces
│ ├── inner_api #native實現(xiàn)的接口
│ │ └── native
│ │ └── audiorenderer #audio渲染本地實現(xiàn)的接口定義
│ │ └── include
│ │ └── audio_renderer.h
│ └── kits #js調(diào)用的接口
│ └── js
│ └── audio_renderer #audio渲染NAPI接口的定義
│ └── include
│ └── audio_renderer_napi.h
└── services #服務(wù)端
└── audio_service
├── BUILD.gn
├── client #IPC調(diào)用中的proxy
│ ├── include
│ │ ├── audio_manager_proxy.h
│ │ ├── audio_service_client.h
│ └── src
│ ├── audio_manager_proxy.cpp
│ ├── audio_service_client.cpp
└── server #IPC調(diào)用中的server
├── include
│ └── audio_server.h
└── src
├── audio_manager_stub.cpp
└──audio_server.cpp

三、音頻渲染總體流程


四、Native接口使用

在OpenAtom OpenHarmony(以下簡稱“OpenHarmony”)系統(tǒng)中,音頻模塊提供了功能測試代碼,本文選取了其中的音頻渲染例子作為切入點來進行介紹,例子采用的是對wav格式的音頻文件進行渲染。wav格式的音頻文件是wav頭文件和音頻的原始數(shù)據(jù),不需要進行數(shù)據(jù)解碼,所以音頻渲染直接對原始數(shù)據(jù)進行操作,文件路徑為:foundation/multimedia/audio_framework/frameworks/native/audiorenderer/test/example/audio_renderer_test.cpp
bool TestPlayback(int argc, char *argv[]) const
{
FILE* wavFile = fopen(path, "rb");
//讀取wav文件頭信息
size_t bytesRead = fread(&wavHeader, 1, headerSize, wavFile);


//設(shè)置AudioRenderer參數(shù)
AudioRendererOptions rendererOptions = {};
rendererOptions.streamInfo.encoding = AudioEncodingType::ENCODING_PCM;
rendererOptions.streamInfo.samplingRate = static_cast(wavHeader.SamplesPerSec);
rendererOptions.streamInfo.format = GetSampleFormat(wavHeader.bitsPerSample);
rendererOptions.streamInfo.channels = static_cast(wavHeader.NumOfChan);
rendererOptions.rendererInfo.contentType = contentType;
rendererOptions.rendererInfo.streamUsage = streamUsage;
rendererOptions.rendererInfo.rendererFlags = 0;


//創(chuàng)建AudioRender實例
unique_ptr audioRenderer = AudioRenderer::Create(rendererOptions);


shared_ptr cb1 = make_shared();
//設(shè)置音頻渲染回調(diào)
ret = audioRenderer->SetRendererCallback(cb1);


//InitRender方法主要調(diào)用了audioRenderer實例的Start方法,啟動音頻渲染
if (!InitRender(audioRenderer)) {
AUDIO_ERR_LOG("AudioRendererTest: Init render failed");
fclose(wavFile);
return false;
}


//StartRender方法主要是讀取wavFile文件的數(shù)據(jù),然后通過調(diào)用audioRenderer實例的Write方法進行播放
if (!StartRender(audioRenderer, wavFile)) {
AUDIO_ERR_LOG("AudioRendererTest: Start render failed");
fclose(wavFile);
return false;
}


//停止渲染
if (!audioRenderer->Stop()) {
AUDIO_ERR_LOG("AudioRendererTest: Stop failed");
}


//釋放渲染
if (!audioRenderer->Release()) {
AUDIO_ERR_LOG("AudioRendererTest: Release failed");
}


//關(guān)閉wavFile
fclose(wavFile);
return true;
}
首先讀取wav文件,通過讀取到wav文件的頭信息對AudioRendererOptions相關(guān)的參數(shù)進行設(shè)置,包括編碼格式、采樣率、采樣格式、通道數(shù)等。根據(jù)AudioRendererOptions設(shè)置的參數(shù)來創(chuàng)建AudioRenderer實例(實際上是AudioRendererPrivate),后續(xù)的音頻渲染主要是通過AudioRenderer實例進行。創(chuàng)建完成后,調(diào)用AudioRenderer的Start方法,啟動音頻渲染。啟動后,通過AudioRenderer實例的Write方法,將數(shù)據(jù)寫入,音頻數(shù)據(jù)會被播放。

五、調(diào)用流程


1.創(chuàng)建AudioRenderer
std::unique_ptr AudioRenderer::Create(const std::string cachePath,
const AudioRendererOptions &rendererOptions, const AppInfo &appInfo)
{
ContentType contentType = rendererOptions.rendererInfo.contentType;

StreamUsage streamUsage = rendererOptions.rendererInfo.streamUsage;

AudioStreamType audioStreamType = AudioStream::GetStreamType(contentType, streamUsage);
auto audioRenderer = std::make_unique(audioStreamType, appInfo);
if (!cachePath.empty()) {
AUDIO_DEBUG_LOG("Set application cache path");
audioRenderer->SetApplicationCachePath(cachePath);
}


audioRenderer->rendererInfo_.contentType = contentType;
audioRenderer->rendererInfo_.streamUsage = streamUsage;
audioRenderer->rendererInfo_.rendererFlags = rendererOptions.rendererInfo.rendererFlags;


AudioRendererParams params;
params.sampleFormat = rendererOptions.streamInfo.format;
params.sampleRate = rendererOptions.streamInfo.samplingRate;
params.channelCount = rendererOptions.streamInfo.channels;
params.encodingType = rendererOptions.streamInfo.encoding;


if (audioRenderer->SetParams(params) != SUCCESS) {
AUDIO_ERR_LOG("SetParams failed in renderer");
audioRenderer = nullptr;
return nullptr;
}


return audioRenderer;
}
首先通過AudioStream的GetStreamType方法獲取音頻流的類型,根據(jù)音頻流類型創(chuàng)建AudioRendererPrivate對象,AudioRendererPrivate是AudioRenderer的子類。緊接著對audioRenderer進行參數(shù)設(shè)置,其中包括采樣格式、采樣率、通道數(shù)、編碼格式。設(shè)置完成后返回創(chuàng)建的AudioRendererPrivate實例。

2.設(shè)置回調(diào)
int32_t AudioRendererPrivate::SetRendererCallback(const std::shared_ptr &callback)
{
RendererState state = GetStatus();
if (state == RENDERER_NEW || state == RENDERER_RELEASED) {
return ERR_ILLEGAL_STATE;
}
if (callback == nullptr) {
return ERR_INVALID_PARAM;
}


// Save reference for interrupt callback
if (audioInterruptCallback_ == nullptr) {
return ERROR;
}
std::shared_ptr cbInterrupt =
std::static_pointer_cast(audioInterruptCallback_);
cbInterrupt->SaveCallback(callback);


// Save and Set reference for stream callback. Order is important here.
if (audioStreamCallback_ == nullptr) {
audioStreamCallback_ = std::make_shared();
if (audioStreamCallback_ == nullptr) {
return ERROR;
}
}
std::shared_ptr cbStream =
std::static_pointer_cast(audioStreamCallback_);
cbStream->SaveCallback(callback);
(void)audioStream_->SetStreamCallback(audioStreamCallback_);


return SUCCESS;
}
參數(shù)傳入的回調(diào)主要涉及到兩個方面:一方面是AudioInterruptCallbackImpl中設(shè)置了我們傳入的渲染回調(diào),另一方面是AudioStreamCallbackRenderer中也設(shè)置了渲染回調(diào)。

3.啟動渲染
bool AudioRendererPrivate::Start(StateChangeCmdType cmdType) const
{
AUDIO_INFO_LOG("AudioRenderer::Start");
RendererState state = GetStatus();


AudioInterrupt audioInterrupt;
switch (mode_) {
case InterruptMode:
audioInterrupt = sharedInterrupt_;
break;
case InterruptMode:
audioInterrupt = audioInterrupt_;
break;
default:
break;
}
AUDIO_INFO_LOG("AudioRenderer: %{public}d, streamType: %{public}d, sessionID: %{public}d",
mode_, audioInterrupt.streamType, audioInterrupt.sessionID);


if (audioInterrupt.streamType == STREAM_DEFAULT || audioInterrupt.sessionID == INVALID_SESSION_ID) {
return false;
}


int32_t ret = AudioPolicyManager::GetInstance().ActivateAudioInterrupt(audioInterrupt);
if (ret != 0) {
AUDIO_ERR_LOG("AudioRendererPrivate::ActivateAudioInterrupt Failed");
return false;
}


return audioStream_->StartAudioStream(cmdType);
}
AudioPolicyManager::GetInstance().ActivateAudioInterrupt這個操作主要是根據(jù)AudioInterrupt來進行音頻中斷的激活,這里涉及了音頻策略相關(guān)的內(nèi)容,后續(xù)會專門出關(guān)于音頻策略的文章進行分析。這個方法的核心是通過調(diào)用AudioStream的StartAudioStream方法來啟動音頻流。
bool AudioStream::StartAudioStream(StateChangeCmdType cmdType)
{
int32_t ret = StartStream(cmdType);


resetTime_ = true;
int32_t retCode = clock_gettime(CLOCK_MONOTONIC, &baseTimestamp_);


if (renderMode_ == RENDER_MODE_CALLBACK) {
isReadyToWrite_ = true;
writeThread_ = std::make_unique<std::thread>(&AudioStream::WriteCbTheadLoop, this);
} else if (captureMode_ == CAPTURE_MODE_CALLBACK) {
isReadyToRead_ = true;
readThread_ = std::make_unique<std::thread>(&AudioStream::ReadCbThreadLoop, this);
}


isFirstRead_ = true;
isFirstWrite_ = true;
state_ = RUNNING;
AUDIO_INFO_LOG("StartAudioStream SUCCESS");


if (audioStreamTracker_) {
AUDIO_DEBUG_LOG("AudioStream:Calling Update tracker for Running");
audioStreamTracker_->UpdateTracker(sessionId_, state_, rendererInfo_, capturerInfo_);
}
return true;
}
AudioStream的StartAudioStream主要的工作是調(diào)用StartStream方法,StartStream方法是AudioServiceClient類中的方法。AudioServiceClient類是AudioStream的父類。接下來看一下AudioServiceClient的StartStream方法。
int32_t AudioServiceClient::StartStream(StateChangeCmdType cmdType)
{
int error;
lock_guard lockdata(dataMutex);
pa_operation *operation = nullptr;


pa_threaded_mainloop_lock(mainLoop);


pa_stream_state_t state = pa_stream_get_state(paStream);


streamCmdStatus = 0;
stateChangeCmdType_ = cmdType;
operation = pa_stream_cork(paStream, 0, PAStreamStartSuccessCb, (void *)this);


while (pa_operation_get_state(operation) == PA_OPERATION_RUNNING) {
pa_threaded_mainloop_wait(mainLoop);
}
pa_operation_unref(operation);
pa_threaded_mainloop_unlock(mainLoop);


if (!streamCmdStatus) {
AUDIO_ERR_LOG("Stream Start Failed");
ResetPAAudioClient();
return AUDIO_CLIENT_START_STREAM_ERR;
} else {
AUDIO_INFO_LOG("Stream Started Successfully");
return AUDIO_CLIENT_SUCCESS;
}
}
StartStream方法中主要是調(diào)用了pulseaudio庫的pa_stream_cork方法進行流啟動,后續(xù)就調(diào)用到了pulseaudio庫中了。pulseaudio庫我們暫且不分析。

4.寫入數(shù)據(jù)
int32_t AudioRendererPrivate::Write(uint8_t *buffer, size_t bufferSize)
{
return audioStream_->Write(buffer, bufferSize);
}
通過調(diào)用AudioStream的Write方式實現(xiàn)功能,接下來看一下AudioStream的Write方法。
size_t AudioStream::Write(uint8_t *buffer, size_t buffer_size)
{
int32_t writeError;
StreamBuffer stream;
stream.buffer = buffer;
stream.bufferLen = buffer_size;
isWriteInProgress_ = true;


if (isFirstWrite_) {
if (RenderPrebuf(stream.bufferLen)) {
return ERR_WRITE_FAILED;
}
isFirstWrite_ = false;
}


size_t bytesWritten = WriteStream(stream, writeError);
isWriteInProgress_ = false;
if (writeError != 0) {
AUDIO_ERR_LOG("WriteStream fail,writeError:%{public}d", writeError);
return ERR_WRITE_FAILED;
}
return bytesWritten;
}
Write方法中分成兩個階段,首次寫數(shù)據(jù),先調(diào)用RenderPrebuf方法,將preBuf_的數(shù)據(jù)寫入后再調(diào)用WriteStream進行音頻數(shù)據(jù)的寫入。
size_t AudioServiceClient::WriteStream(const StreamBuffer &stream, int32_t &pError)
{

size_t cachedLen = WriteToAudioCache(stream);
if (!acache.isFull) {
pError = error;
return cachedLen;
}


pa_threaded_mainloop_lock(mainLoop);




const uint8_t *buffer = acache.buffer.get();
size_t length = acache.totalCacheSize;


error = PaWriteStream(buffer, length);
acache.readIndex += acache.totalCacheSize;
acache.isFull = false;


if (!error && (length >= 0) && !acache.isFull) {
uint8_t *cacheBuffer = acache.buffer.get();
uint32_t offset = acache.readIndex;
uint32_t size = (acache.writeIndex - acache.readIndex);
if (size > 0) {
if (memcpy_s(cacheBuffer, acache.totalCacheSize, cacheBuffer + offset, size)) {
AUDIO_ERR_LOG("Update cache failed");
pa_threaded_mainloop_unlock(mainLoop);
pError = AUDIO_CLIENT_WRITE_STREAM_ERR;
return cachedLen;
}
AUDIO_INFO_LOG("rearranging the audio cache");
}
acache.readIndex = 0;
acache.writeIndex = 0;


if (cachedLen < stream.bufferLen) {
StreamBuffer str;
str.buffer = stream.buffer + cachedLen;
str.bufferLen = stream.bufferLen - cachedLen;
AUDIO_DEBUG_LOG("writing pending data to audio cache: %{public}d", str.bufferLen);
cachedLen += WriteToAudioCache(str);
}
}


pa_threaded_mainloop_unlock(mainLoop);
pError = error;
return cachedLen;
}
WriteStream方法不是直接調(diào)用pulseaudio庫的寫入方法,而是通過WriteToAudioCache方法將數(shù)據(jù)寫入緩存中,如果緩存沒有寫滿則直接返回,不會進入下面的流程,只有當(dāng)緩存寫滿后,才會調(diào)用下面的PaWriteStream方法。該方法涉及對pulseaudio庫寫入操作的調(diào)用,所以緩存的目的是避免對pulseaudio庫頻繁地做IO操作,提高了效率。

六、總結(jié)

本文主要對OpenHarmony 3.2 Beta多媒體子系統(tǒng)的音頻渲染模塊進行介紹,首先梳理了Audio Render的整體流程,然后對幾個核心的方法進行代碼的分析。整體的流程主要通過pulseaudio庫啟動流,然后通過pulseaudio庫的pa_stream_write方法進行數(shù)據(jù)的寫入,最后播放出音頻數(shù)據(jù)。

音頻渲染主要分為以下幾個層次:
(1)AudioRenderer的創(chuàng)建,實際創(chuàng)建的是它的子類AudioRendererPrivate實例。
(2)通過AudioRendererPrivate設(shè)置渲染的回調(diào)。
(3)啟動渲染,這一部分代碼最終會調(diào)用到pulseaudio庫中,相當(dāng)于啟動了pulseaudio的流。
(4)通過pulseaudio庫的pa_stream_write方法將數(shù)據(jù)寫入設(shè)備,進行播放。

對OpenHarmony 3.2 Beta多媒體系列開發(fā)感興趣的讀者,也可以閱讀我之前寫過幾篇文章:《OpenHarmony 3.2 Beta多媒體系列——視頻錄制》《OpenHarmony 3.2 Beta源碼分析之MediaLibrary》《OpenHarmony 3.2 Beta多媒體系列——音視頻播放框架》《OpenHarmony 3.2 Beta多媒體系列——音視頻播放gstreamer》。


原文標(biāo)題:OpenHarmony 3.2 Beta Audio——音頻渲染

文章出處:【微信公眾號:OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 鴻蒙
    +關(guān)注

    關(guān)注

    59

    文章

    2587

    瀏覽量

    43924
  • OpenHarmony
    +關(guān)注

    關(guān)注

    29

    文章

    3847

    瀏覽量

    18414

原文標(biāo)題:OpenHarmony 3.2 Beta Audio——音頻渲染

文章出處:【微信號:gh_e4f28cfa3159,微信公眾號:OpenAtom OpenHarmony】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    LE-Audio是什么?

    近年來,隨著藍牙技術(shù)的快速發(fā)展,無線通信領(lǐng)域的應(yīng)用變得越來越廣泛。然而,在對音頻質(zhì)量和功耗不斷追求的同時,藍牙技術(shù)也需要不斷創(chuàng)新和改進。在這方面,LE-Audio(低功耗音頻)作為一項新興技術(shù)
    發(fā)表于 06-28 21:32

    開源鴻蒙6.0Beta1版本發(fā)布!觸覺智能將率先適配RK3566/RK3568/RK3576等芯片平臺芯片

    開放原子開源鴻蒙(OpenAtomOpenHarmony,簡稱“開源鴻蒙”或“OpenHarmony”)6.0Beta1版本正式發(fā)布。相比5.1.0Release版本進一步增強ArkUI組件能力
    的頭像 發(fā)表于 06-20 14:05 ?288次閱讀
    開源鴻蒙6.0<b class='flag-5'>Beta</b>1版本發(fā)布!觸覺智能將率先適配RK3566/RK3568/RK3576等芯片平臺芯片

    藍牙LE Audio技術(shù)簡介和優(yōu)勢分析

    藍牙LE Audio,也稱為低功耗音頻(Bluetooth Low Energy Audio),是藍牙技術(shù)家族中的最新成員,專門為音頻傳輸而設(shè)計。它繼承了藍牙低功耗(Bluetooth
    的頭像 發(fā)表于 05-21 16:08 ?503次閱讀

    CPU渲染、GPU渲染、XPU渲染詳細對比:哪個渲染最快,哪個效果最好?

    動畫渲染動畫3D渲染技術(shù)需要應(yīng)對復(fù)雜的計算任務(wù)和精細的圖像處理,作為渲染技術(shù)人員,選擇合適的渲染模式,會直接影響制作效率和成品質(zhì)量。在主流的渲染
    的頭像 發(fā)表于 04-15 09:28 ?400次閱讀
    CPU<b class='flag-5'>渲染</b>、GPU<b class='flag-5'>渲染</b>、XPU<b class='flag-5'>渲染</b>詳細對比:哪個<b class='flag-5'>渲染</b>最快,哪個效果最好?

    STM32如何移植Audio框架?

    最近在學(xué)習(xí)音頻解碼,想用一下Audio框架。 1、這個該如何移植到自己創(chuàng)建的BSP并對接到device框架中?看了官方移植文檔沒有對沒有對該部分的描述。 2、我只想實現(xiàn)一個簡單的播放功能,只用一個DAC芯片(比如CS4344)是否就能達到我的需求?
    發(fā)表于 04-01 08:08

    PCB設(shè)計丨AUDIO音頻接口

    音頻接口(audio interface)是連接麥克風(fēng)、其他聲源和計算機的設(shè)備,它可以在模擬信號和數(shù)字信號之間起到橋梁連接的作用。主要作用是將模擬信號轉(zhuǎn)換為數(shù)字信號,并將其傳輸?shù)接嬎銠C中進行處理
    發(fā)表于 03-19 14:31

    PCB設(shè)計丨AUDIO音頻接口

    音頻接口(audio interface)是連接麥克風(fēng)、其他聲源和計算機的設(shè)備,它可以在模擬信號和數(shù)字信號之間起到橋梁連接的作用。主要作用是將模擬信號轉(zhuǎn)換為數(shù)字信號,并將其傳輸?shù)接嬎銠C中進行處理
    的頭像 發(fā)表于 03-19 14:30 ?2552次閱讀
    PCB設(shè)計丨<b class='flag-5'>AUDIO</b><b class='flag-5'>音頻</b>接口

    LE Audio Combo模組智能座艙的應(yīng)用

    ,憑借其先進的LE Audio技術(shù)和經(jīng)典藍牙支持,為智能座艙提供了卓越的解決方案,滿足了用戶在音質(zhì)、連接穩(wěn)定性上的高標(biāo)準(zhǔn)需求。 LE AudioCombo模組:引領(lǐng)智能座艙音頻體驗的未來 藍牙技術(shù)的每次迭代都帶來了巨大的性能提升,而藍牙5.2版本中引入的LE
    的頭像 發(fā)表于 03-07 14:02 ?413次閱讀

    【北京迅為】itop-3568 開發(fā)板openharmony鴻蒙燒寫及測試-第2章OpenHarmony v3.2-Beta4版本測試

    【北京迅為】itop-3568 開發(fā)板openharmony鴻蒙燒寫及測試-第2章OpenHarmony v3.2-Beta4版本測試
    的頭像 發(fā)表于 03-05 10:53 ?412次閱讀
    【北京迅為】itop-3568 開發(fā)板<b class='flag-5'>openharmony</b>鴻蒙燒寫及測試-第2章<b class='flag-5'>OpenHarmony</b> v<b class='flag-5'>3.2-Beta</b>4版本測試

    大聯(lián)大品佳集團推出基于達發(fā)科技(Airoha)產(chǎn)品的LE Audio耳機方案

    的LE Audio耳機方案的展示板圖 LE Audio(低功耗音頻)技術(shù)標(biāo)準(zhǔn)的誕生為業(yè)內(nèi)帶來低復(fù)雜性通信編解碼器(LC3)、多重串流音頻、助聽器功能擴展和廣播
    的頭像 發(fā)表于 02-22 11:06 ?647次閱讀
    大聯(lián)大品佳集團推出基于達發(fā)科技(Airoha)產(chǎn)品的LE <b class='flag-5'>Audio</b>耳機方案

    e絡(luò)盟大幅擴充PUI Audio產(chǎn)品系列以強化音頻產(chǎn)品組合

    安富利旗下全球電子元器件產(chǎn)品與解決方案分銷商e絡(luò)盟大幅擴充了 PUI Audio產(chǎn)品種類。作為音頻、觸覺反饋及傳感器解決方案領(lǐng)域的全球創(chuàng)新者和供應(yīng)商,PUI Audio產(chǎn)品的加入進一步豐富e絡(luò)盟的產(chǎn)品組合。新擴展的產(chǎn)品線使客戶能
    的頭像 發(fā)表于 02-18 16:29 ?504次閱讀
    e絡(luò)盟大幅擴充PUI <b class='flag-5'>Audio</b>產(chǎn)品系列以強化<b class='flag-5'>音頻</b>產(chǎn)品組合

    請問cc3200 audio boosterpack音頻采集是不是底噪很大?

    基于TLV320AIC3254的音頻開發(fā)辦,我燒入wifi_audio_app例程(例程中關(guān)掉板載咪頭輸入,并將音量調(diào)到最大),另兩入輸入接口沒有接音頻信號,但是板子一直吱吱吱的響,是板子本身底噪就這么大嗎?
    發(fā)表于 10-25 06:28

    TPS6595 Audio Codec輸出音頻偶發(fā)混入7Khz雜波是怎么回事?

    主芯片是DM3730, 音頻使用的是TPS65950的Audio 外設(shè)。 DM3730使用MCBSP輸出8Khz音頻數(shù)據(jù),通過I2C設(shè)置 TPS65950相關(guān)寄存器。 采用Audio
    發(fā)表于 10-15 07:08

    【龍芯2K0300蜂鳥板試用】OpenHarmony代碼

    fetch origin OpenHarmony-3.2-Release:OpenHarmony-3.2-Release git switch OpenHarmony-3.2
    發(fā)表于 09-18 11:42

    LE Audio音頻技術(shù)助推影音、助聽市場,藍牙+助聽芯片成為趨勢

    3.0版本支持高速數(shù)據(jù)傳輸和更低的功耗,藍牙4.0版本引入了低功耗模式(BLE),藍牙5.0版本提高了傳輸速度。再到藍牙5.2版本提出了LE Audio,增強了藍牙音頻體驗。 進入無損時代,LE Audio帶來低延遲、高音質(zhì)體驗
    的頭像 發(fā)表于 07-08 07:41 ?3747次閱讀
    LE <b class='flag-5'>Audio</b><b class='flag-5'>音頻</b>技術(shù)助推影音、助聽市場,藍牙+助聽芯片成為趨勢