1.
視頻直播功能,這是一款直播App最主要的功能,要能支持視頻直播RTMP推流,使畫面?zhèn)鬏斄鲿?、清晰?/div>
2. 聊天功能,用戶之間的互動聊天,包括文字和表情;
3. 互動功能,用戶與主播間的互動,點亮個燈,送一束花等等;
4. 支付&提現(xiàn)功能,用戶用現(xiàn)金購買禮物送給心儀的主播,主播收到禮物后可再兌換成現(xiàn)金取出;
5. 視頻回放功能,在直播的過程中同時錄像,使得沒看到直播的小粉絲也有機會再看;
6. 分享功能,將房間號分享到微信、微博、QQ等。
第二步:尋找合適的云服務SDK進行嵌入,在APICloud的聚合API中可以輕易找到以上的功能模塊,挑選合適的模塊封裝到自己的App中
1. 視頻直播功能有ytylive qupaiLive 親加云等模塊。
拿ytylive舉例,此模塊支持主流 RTMP 服務器 支持目前所有主流的 RTMP 服務器 (simple-rtmp-server、crtmpserver、FMS 等)。 支持所有的 RTMP 協(xié)議 支持所有 RTMP 協(xié)議及變種 (RTMP、RTMPT、RTMPE、RTMPS、RTMPTE、RTMPTS 等)。 性能強大 資源 (CPU/內(nèi)存) 占用率低,使用硬件加速進行編碼,壓縮比例大,延時小。 支持實時濾鏡 支持多種實時濾鏡效果 (Gray、InvertColors、Sepia、Fisheye、Glow、GaussionBlur)。
而像親加云模塊共有4個,包括視頻直播基礎(chǔ)模塊、視頻直播模塊、視頻播放器模塊和視頻直播聊天室模塊。
2. 聊天文本/表情輸入有chatbox,UIChatbox等模塊。效果如下:
3. 及時通訊(互動功能):融云,環(huán)信等模塊,也可以自己通過socketManager自己封裝協(xié)議實現(xiàn);
4. 支付提現(xiàn):支付寶、ping++、微信支付、銀聯(lián)支付、現(xiàn)在支付等模塊;
5. 視頻回放:視頻回放功能的實現(xiàn)其實是錄像+存儲到服務器中,因此使用APICloud的數(shù)據(jù)云功能,或是七牛云存儲,又拍云等模塊都可以實現(xiàn);
6. 直播/主播分享:微信、新浪微博、QQ等平臺分享模塊。
第三步:完成App開發(fā)5步驟
現(xiàn)在我們所有的模塊已經(jīng)挑選完畢,開發(fā)者按照之前和大家分享過App開發(fā)5步驟的內(nèi)容就可以完成一款直播App的開發(fā)。這5步驟包括:
1. App框架搭建,在APICloud Studio中直接創(chuàng)建應用框架,有三個常用頁面框架備選;
2. 積木式拼裝,將所有你挑選好的模塊,用JavaScript編寫頁面及模塊調(diào)用,運用HTML5+CSS3搭建應用的界面UI,完成App編碼全過程;
3. 真機調(diào)試,通過模擬器和真機調(diào)試功能進行App優(yōu)化,一鍵點擊即可在iOS和Android手機中進行App優(yōu)化;
4. 云編譯,在APICloud官網(wǎng)上傳App的icon、啟動頁和證書,一鍵“云編譯”即可同時生成iOS和Android的原生安裝包;
5. 云修復,使用云修復快速迭代,隨時發(fā)布新版本、新功能,無需提交新的安裝包。
做完以上這三個步驟,開發(fā)直播App的全過程也就結(jié)束了。估計大家還會考慮開發(fā)成本的問題,除去部分模塊是收費之外,其他步驟都是免費的。況且,由于是積木式拼裝的方式,開發(fā)時間會大幅縮短。
最后,再分享一些開發(fā)直播App的難點和細節(jié)。
1. 在網(wǎng)絡(luò)信號弱的情況下,需要保證視頻質(zhì)量。用戶如果經(jīng)常會發(fā)生信號不好需要緩存的情況,那么會大大降低用戶體驗。
2. 直播畫面的延遲情況。數(shù)據(jù)傳輸是按照客戶端上傳到服務器,服務器再下傳到客戶端的模式,數(shù)據(jù)越大尤其是高清視頻畫面,那么整體上傳下載速度越慢,客戶端顯示出現(xiàn)延遲,用戶會出現(xiàn)不停緩沖等狀況,影響用戶的使用。
3. 頁面交互動畫?;又辈サ膬?nèi)在就是主播與用戶的一個互動過程。主流的直播APP通常會添加諸如送花、打賞等等,對于系統(tǒng)兼容性、直播APP運行速度以及流暢度都會造成一定的影響,甚至會出現(xiàn)BUG。