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

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

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

【Purple Pi OH RK3566 Harmony開發(fā)板】OpenHarmony音頻播放應(yīng)用

觸覺智能 ? 2023-09-14 08:35 ? 次閱讀

01注意事項

DevEco Studio 4.0 Beta2(Build Version: 4.0.0.400)

OpenHarmony SDK API 9

創(chuàng)建工程類型選擇Application

修改entry/build-profile.json5配置文件中的targets>runtimeOS為OpenHarmony,然后進(jìn)行Sync Now(同步)

02工程概述

PPI有聲是一款基于OpenHarmony API 9 開發(fā)的,運行于Purple Pi 開發(fā)板(安裝OpenHarmony標(biāo)準(zhǔn)系統(tǒng))的音頻播放應(yīng)用程序。

03場景化

智慧家居類(電子門鈴,溫濕度顯示儀,屏顯燈控開關(guān)等)

智慧辦公類(打卡機,大屏顯示等)

智慧教育類(電子班牌,校園大屏,電子講臺等)

04創(chuàng)建工程

6f931fc8-5296-11ee-a20b-92fbcf53809c.png

Project name:工程名稱

Bundle name:包名

Save location:工程存儲路徑

Compile SDK:編譯API版本

Compatible SDK:兼容的最新API版本

Module name:模塊名稱

Model:模型

Enable Super Visual:是否啟用低代碼開發(fā)

Device Type:設(shè)備類型

Node:nodejs路徑

05媒體服務(wù)

媒體子系統(tǒng)為開發(fā)者提供一套簡單且易于理解的接口,使得開發(fā)者能夠方便接入系統(tǒng)使用系統(tǒng)的媒體資源。

媒體子系統(tǒng)包含了音視頻相關(guān)媒體業(yè)務(wù),提供以下常用共功能:

音視頻播放(AVPlayer)

音視頻錄制(AVRecorder)


5.1 AVPlayer概述

AVPlayer主要工作是將Audio/Video媒體資源(比如mp4/mp3/mkv/mpeg-ts等)轉(zhuǎn)碼為可供渲染的圖像或可聽見的模擬信號,并通過輸出設(shè)備進(jìn)行播放。

使用AVPlayer可以實現(xiàn)端到端播放原始媒體資源,播放對的全流程包含:創(chuàng)建AVPlayer,設(shè)置播放資源,設(shè)置播放參數(shù) (音量/倍速/焦點模式),播放控制(播放/暫停/跳轉(zhuǎn)/停止),重置,銷毀資源。

開發(fā)過程中開發(fā)者可以通過AVPlayer的state屬性主動獲取當(dāng)前狀態(tài)或使用on('stateChange')方法監(jiān)聽狀態(tài)變化。若應(yīng)用在音頻播放器處于錯誤狀態(tài)時執(zhí)行操作,系統(tǒng)可能會拋出異?;蛏善渌炊x的行為。

6fb2b82e-5296-11ee-a20b-92fbcf53809c.png

主:當(dāng)播放處于prepared/playing/paused/completed狀態(tài)時,播放引擎處于工作狀態(tài),需要占用系統(tǒng)較多的運行內(nèi)容。當(dāng)客戶端暫時不適用播放器時,調(diào)用reset()或release()回收內(nèi)存資源。

5.2開發(fā)步驟

導(dǎo)入media模塊,調(diào)用createAVPlayer()方法創(chuàng)建AVPlayer實例,AVPlayer初始化idle狀態(tài)。

設(shè)置業(yè)務(wù)監(jiān)聽事件,搭配全流程場景使用,如監(jiān)聽播放器state屬性改變的stateChange;監(jiān)聽播放器錯誤信息的error;用于進(jìn)度條,監(jiān)聽進(jìn)度條長度,刷新資源時長的durationUpdate等。

設(shè)置資源:設(shè)置屬性url,AVPlayer進(jìn)入initialized狀態(tài)

準(zhǔn)備播放:調(diào)用prepare(),AVPlayer進(jìn)入prepared狀態(tài),此時可以獲取duration,設(shè)置音量。

音頻播控:播放play(),暫停pause(),跳轉(zhuǎn)seek(),停止stop()等操作。

調(diào)用reset()重置資源,AVPlayer重新進(jìn)入idle狀態(tài),此時可更換播放源url。

調(diào)用release()銷毀實例,AVPlayer進(jìn)入released狀態(tài),退出播放。

06構(gòu)建PPI有聲

6.1 準(zhǔn)備資源文件

音頻文件拷貝到resources/rawfile目錄

將拷貝到resources/base/mdiea目錄

音頻播放背景圖audio_bg.png

音頻播放旋轉(zhuǎn)圖audio.png

暫停ic_pause.svg

播放ic_play.svg

6fc63f70-5296-11ee-a20b-92fbcf53809c.png

6.2 構(gòu)建UI頁面

整個UI以Flex彈性布局為主,子組件以列方式排列,分別為可旋轉(zhuǎn)的音頻播放控件,播放進(jìn)度條以及播放控制按鈕組成。

6.2.1 可旋轉(zhuǎn)的音頻播放控件

使用Stack堆疊布局容器為主,將旋轉(zhuǎn)控件置于背景圖之上。

Stack({alignContent: Alignment.Center }) {
Image($r('app.media.audio_bg'))
.width(200).height(200)
Image($r('app.media.audio'))
.width(100).height(100)
.backgroundColor(Color.White)
.borderRadius(50)
.rotate({angle: this.angleNum })
.animation({
duration: this.duration,
tempo:1,
curve: Curve.Linear,
iterations: -1,
playMode: PlayMode.Normal
})
}

6.2.2 進(jìn)度條

播放進(jìn)度由置于上部的播放時長和總時長,底部的播放進(jìn)度條組成,包裹在Column列容器中。

Column({ space:4}) {
Row() {
Text(this.msToS(this.currentProgress))
.fontSize(12)
.fontColor(0xc1c3c5)
Text(this.msToS(this.duration))
.fontSize(12)
.fontColor(0xc1c3c5)
}
.width('100%')
.justifyContent(FlexAlign.SpaceBetween)
// 播放進(jìn)度條
Slider({
value:this.currentProgress,
min:0,
max:this.duration,
style: SliderStyle.OutSet
})
.showTips(true)
.onChange((value: number, mode: SliderChangeMode) => {
this.currentProgress =value;
// 跳轉(zhuǎn)到指定位置播放
this.avPlayer.seek(value);
})
}
.width('90%')

6.2.3 播放控件

播放控件通過當(dāng)前AVPlayer的狀態(tài)判斷顯示播放/暫停圖標(biāo)按鈕。

Row({ space:10}) {
if(this.state ==='playing') {
//暫停
Image($r('app.media.ic_pause'))
.width(64).height(64)
.fillColor(0xff5722)
.onClick(()=>{
//暫停播放
this.avPlayer.pause().then(()=>{
this.angleNum =0;
})
})
}else{
//播放
Image($r('app.media.ic_play'))
.width(64).height(64)
.fillColor(0x00aaee)
.onClick(async () => {
if(this.avPlayer &&this.avPlayer.state ==="paused") {
this.avPlayer.play().then(()=>{
this.angleNum =360;
})
}else{
awaitthis.initAVPlayer();
}
})
}
}
.width('100%')
.justifyContent(FlexAlign.Center)

6.3 實現(xiàn)音頻播放

6.3.1 初始化AVPlayer

// 播放音頻AVPlayer實例
privateavPlayer: media.AVPlayer = undefined;

// 初始化AVPlayer
asyncinitAVPlayer(){
// 創(chuàng)建AVPlayer實例對象
this.avPlayer =awaitmedia.createAVPlayer();
// 創(chuàng)建狀態(tài)機變化回調(diào)函數(shù)
this.setAVPlayerCallback();

awaitthis.loadingResourceFile();
}

6.3.2 加載HAP包資源文件

// 加載HAP包資源文件
loadingResourceFile =async() => {
// 通過UIAbilityContext的resourceManager成員的getRawFd接口獲取媒體資源播放地址
letcontext = getContext(this)ascommon.UIAbilityContext;
letfileDir =awaitcontext.resourceManager.getRawFd("audio.wav");
// 為fdSrc賦值觸發(fā)initialized狀態(tài)機上報
this.avPlayer.fdSrc = fileDir;
}

6.3.3 注冊AVPlayer回調(diào)函數(shù)

// 注冊AVPlayer回調(diào)函數(shù)
setAVPlayerCallback =()=>{
// 狀態(tài)機變化回調(diào)函數(shù)
// state:表示當(dāng)前播放狀態(tài)
// reason:表示當(dāng)前播放狀態(tài)的切換原因
this.avPlayer.on('stateChange',async(state, reason) => {
this.state =this.avPlayer.state;
switch(state) {
case'initialized':
this.avPlayer.prepare().then(()=>{
// 音頻播放準(zhǔn)備完畢后,獲取音頻總時長
this.duration =this.avPlayer.duration;
})
break;
case'prepared':
// 開始播放
this.avPlayer.play().then(()=>{
// 設(shè)置圖標(biāo)開始旋轉(zhuǎn)
this.angleNum =360;
})
break;
}
})

// 播放錯誤回調(diào)函數(shù)
this.avPlayer.on('error',(err) =>{
console.error(`Error happened. Cause:${JSON.stringify(err)}`);
})
// 監(jiān)聽資源播放當(dāng)前時間回調(diào)函數(shù)
this.avPlayer.on('timeUpdate',(time:number) =>{
if(this.avPlayer.state ==='completed') {
this.currentProgress =0;
this.duration =0;
this.angleNum =0;
}else{
this.currentProgress = time;
}
})
}

07效果預(yù)覽

6fdb4424-5296-11ee-a20b-92fbcf53809c.png

7029b97e-5296-11ee-a20b-92fbcf53809c.png

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

    關(guān)注

    29

    文章

    3025

    瀏覽量

    83053
  • 開發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    5532

    瀏覽量

    102417
  • OpenHarmony
    +關(guān)注

    關(guān)注

    27

    文章

    3835

    瀏覽量

    18171
  • Harmony
    +關(guān)注

    關(guān)注

    0

    文章

    64

    瀏覽量

    2896
收藏 0人收藏

    評論

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

    鴻蒙北向開發(fā)OpenHarmony5.0 DevEco Studio開發(fā)工具安裝與配置

    本文介紹OpenHarmony5.0 DevEco Studio開發(fā)工具安裝與配置,鴻蒙北向開發(fā)入門必備!由觸覺智能Purple Pi
    的頭像 發(fā)表于 03-28 18:05 ?599次閱讀
    鴻蒙北向<b class='flag-5'>開發(fā)</b><b class='flag-5'>OpenHarmony</b>5.0 DevEco Studio<b class='flag-5'>開發(fā)</b>工具安裝與配置

    OpenHarmony源碼編譯后燒錄鏡像教程,RK3566鴻蒙開發(fā)板演示

    本文介紹瑞芯微主板/開發(fā)板編譯OpenHarmony源碼后燒錄鏡像的教程,觸覺智能Purple Pi OH鴻蒙
    的頭像 發(fā)表于 12-30 10:08 ?662次閱讀
    <b class='flag-5'>OpenHarmony</b>源碼編譯后燒錄鏡像教程,<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>演示

    OpenHarmony怎么修改DPI密度值?觸覺智能RK3566鴻蒙開發(fā)板演示

    開源鴻蒙OpenHarmony系統(tǒng)下,修改DPI密度值的方法,觸覺智能Purple Pi OH鴻蒙開發(fā)板演示,搭載了瑞芯微
    的頭像 發(fā)表于 12-24 11:46 ?613次閱讀
    <b class='flag-5'>OpenHarmony</b>怎么修改DPI密度值?觸覺智能<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>演示

    瑞芯微主板/開發(fā)板Linux系統(tǒng)播放音頻方法,觸覺智能RK3562開發(fā)板演示

    本文介紹瑞芯微方案主板/開發(fā)板Linux系統(tǒng)播放音頻的方法,觸覺智能RK3562開發(fā)板演示,通用RK3566、
    的頭像 發(fā)表于 12-13 11:40 ?765次閱讀
    瑞芯微主板/<b class='flag-5'>開發(fā)板</b>Linux系統(tǒng)<b class='flag-5'>播放音頻</b>方法,觸覺智能<b class='flag-5'>RK</b>3562<b class='flag-5'>開發(fā)板</b>演示

    OpenHarmony屬性信息怎么修改?觸覺智能RK3566鴻蒙開發(fā)板來演示

    本文介紹開源鴻蒙OpenHarmony系統(tǒng)下,修改產(chǎn)品屬性信息的方法,觸覺智能Purple Pi OH鴻蒙開發(fā)板演示,已適配全新
    的頭像 發(fā)表于 11-27 09:31 ?643次閱讀
    <b class='flag-5'>OpenHarmony</b>屬性信息怎么修改?觸覺智能<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>來演示

    如何在開源鴻蒙OpenHarmony開啟SELinux模式?RK3566鴻蒙開發(fā)板演示

    本文介紹開源鴻蒙OpenHarmony系統(tǒng)下,開啟/關(guān)閉SELinux權(quán)限的方法,觸覺智能Purple Pi OH鴻蒙開發(fā)板演示,已適配全新
    的頭像 發(fā)表于 11-18 19:03 ?753次閱讀
    如何在開源鴻蒙<b class='flag-5'>OpenHarmony</b>開啟SELinux模式?<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>演示

    瑞芯微RK3566/RK3568 Android11下該如何默認(rèn)屏蔽導(dǎo)航欄/狀態(tài)欄?看這篇文章就懂了

    本文介紹瑞芯微RK3566/RK3568在Android11系統(tǒng)默認(rèn)屏蔽導(dǎo)航欄/狀態(tài)欄方法,觸覺智能的Purple Pi OH鴻蒙
    的頭像 發(fā)表于 10-30 18:26 ?959次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>/<b class='flag-5'>RK</b>3568 Android11下該如何默認(rèn)屏蔽導(dǎo)航欄/狀態(tài)欄?看這篇文章就懂了

    觸覺智能Purple Pi OH鴻蒙開發(fā)板成功適配OpenHarmony5.0 Release,開啟新征程

    觸覺智能Purple Pi OH鴻蒙開發(fā)板,成功適配OpenHarmony5.0 Release版本!為大家?guī)?/div>
    的頭像 發(fā)表于 10-25 10:51 ?962次閱讀
    觸覺智能<b class='flag-5'>Purple</b> <b class='flag-5'>Pi</b> <b class='flag-5'>OH</b>鴻蒙<b class='flag-5'>開發(fā)板</b>成功適配<b class='flag-5'>OpenHarmony</b>5.0 Release,開啟新征程

    瑞芯微RK3566/RK3568 Android11使用OTA升級固件方法,深圳觸覺智能鴻蒙開發(fā)板演示,備戰(zhàn)第九屆華為ICT大賽

    本文介紹瑞芯微RK3566/RK3568在Android11系統(tǒng)OTA升級固件方法,使用觸覺智能的Purple Pi OH鴻蒙
    的頭像 發(fā)表于 10-12 11:57 ?1355次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>/<b class='flag-5'>RK</b>3568 Android11使用OTA升級固件方法,深圳觸覺智能鴻蒙<b class='flag-5'>開發(fā)板</b>演示,備戰(zhàn)第九屆華為ICT大賽

    開源鴻蒙OpenHarmony系統(tǒng)更換開機Logo方法,RK3566鴻蒙開發(fā)板備戰(zhàn)第九屆華為ICT大賽

    本文適用開源鴻蒙OpenHarmony系統(tǒng)更換開機Logo,本次使用了觸覺智能的Purple Pi OH鴻蒙開源主板,搭載了瑞芯微RK3566
    的頭像 發(fā)表于 09-26 09:18 ?1320次閱讀
    開源鴻蒙<b class='flag-5'>OpenHarmony</b>系統(tǒng)更換開機Logo方法,<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>備戰(zhàn)第九屆華為ICT大賽

    OpenHarmony4.0系統(tǒng)修改屏幕旋轉(zhuǎn)方法,RK3566鴻蒙開發(fā)板備戰(zhàn)第九屆華為ICT大賽

    本文提供OpenHarmony4.0系統(tǒng)豎屏修改為旋轉(zhuǎn)時的操作方法,本次使用了觸覺智能的Purple Pi OH鴻蒙開源主板,搭載了瑞芯微RK356
    的頭像 發(fā)表于 09-25 00:29 ?1069次閱讀
    <b class='flag-5'>OpenHarmony</b>4.0系統(tǒng)修改屏幕旋轉(zhuǎn)方法,<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>備戰(zhàn)第九屆華為ICT大賽

    瑞芯微RK3566鴻蒙開發(fā)板Android11修改第三方輸入法為默認(rèn)輸入法

    本文適用于觸覺智能所有支持Android11系統(tǒng)的開發(fā)板修改第三方輸入法為默認(rèn)輸入法。本次使用的是觸覺智能的Purple Pi OH鴻蒙開源主板,搭載了瑞芯微
    的頭像 發(fā)表于 09-24 09:43 ?945次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>Android11修改第三方輸入法為默認(rèn)輸入法

    瑞芯微RK3566鴻蒙開發(fā)板OpenHarmony標(biāo)準(zhǔn)系統(tǒng)應(yīng)用兼容性測試指導(dǎo)

    本文OpenHarmony標(biāo)準(zhǔn)系統(tǒng)應(yīng)用兼容性測試指導(dǎo),適用鴻蒙系統(tǒng)軟件開發(fā)測試的新手入門學(xué)習(xí)課程,設(shè)備為觸覺智能的瑞芯微RK3566開發(fā)板,型號Pu
    的頭像 發(fā)表于 09-10 11:56 ?1045次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b><b class='flag-5'>OpenHarmony</b>標(biāo)準(zhǔn)系統(tǒng)應(yīng)用兼容性測試指導(dǎo)

    瑞芯微RK3566鴻蒙開發(fā)板Ubuntu虛擬機環(huán)境搭建教程,觸覺智能Purple Pi OH主板

    本文適用于Ubuntu虛擬機環(huán)境搭建教程學(xué)習(xí),設(shè)備為觸覺智能開發(fā)的瑞芯微RK3566開發(fā)板,型號Purple Pi
    的頭像 發(fā)表于 09-08 18:25 ?2538次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>Ubuntu虛擬機環(huán)境搭建教程,觸覺智能<b class='flag-5'>Purple</b> <b class='flag-5'>Pi</b> <b class='flag-5'>OH</b>主板

    瑞芯微RK3566鴻蒙開發(fā)板Ubuntu虛擬機環(huán)境搭建教程,觸覺智能Purple Pi OH主板

    本文適用于Ubuntu虛擬機環(huán)境搭建教程學(xué)習(xí),設(shè)備為觸覺智能開發(fā)的瑞芯微RK3566開發(fā)板,型號Purple Pi
    的頭像 發(fā)表于 09-05 17:47 ?335次閱讀
    瑞芯微<b class='flag-5'>RK3566</b>鴻蒙<b class='flag-5'>開發(fā)板</b>Ubuntu虛擬機環(huán)境搭建教程,觸覺智能<b class='flag-5'>Purple</b> <b class='flag-5'>Pi</b> <b class='flag-5'>OH</b>主板

    電子發(fā)燒友

    中國電子工程師最喜歡的網(wǎng)站

    • 2931785位工程師會員交流學(xué)習(xí)
    • 獲取您個性化的科技前沿技術(shù)信息
    • 參加活動獲取豐厚的禮品