【Android RTMP】NV21 圖像旋轉處理 ( 快速搭建 RTMP 服務器 Shell 腳本 | 創建 RTMP 服務器鏡像 | 瀏覽器觀看直播 | 前置 / 後置攝像頭圖像旋轉效果展示 )





安卓直播推流專欄博客總結



Android RTMP 直播推流技術專欄 :


0 . 資源和源碼地址 :


1. 搭建 RTMP 服務器 : 下面的博客中講解了如何在 VMWare 虛擬機中搭建 RTMP 直播推流服務器 ;

2. 準備視頻編碼的 x264 編碼器開源庫 , 和 RTMP 數據包封裝開源庫 :

3. 講解 RTMP 數據包封裝格式 :

4. 圖像數據採集 : 從 Camera 攝像頭中採集 NV21 格式的圖像數據 , 並預覽該數據 ;

5. NV21 格式的圖像數據編碼成 H.264 格式的視頻數據 :

6. 將 H.264 格式的視頻數據封裝到 RTMP 數據包中 :

7. 階段總結 : 阿里雲服務器中搭建 RTMP 服務器 , 並使用電腦軟件推流和觀看直播內容 ;

8. 處理 Camera 圖像傳感器導致的 NV21 格式圖像旋轉問題 :

9. 下面這篇博客比較重要 , 裏面有一個快速搭建 RTMP 服務器的腳本 , 強烈建議使用 ;

10. 編碼 AAC 音頻數據的開源庫 FAAC 交叉編譯與 Android Studio 環境搭建 :

11. 解析 AAC 音頻格式 :

12 . 將麥克風採集的 PCM 音頻採樣編碼成 AAC 格式音頻 , 並封裝到 RTMP 包中 , 推流到客戶端 :






Android 直播推流流程 : 手機採集視頻 / 音頻數據 , 視頻數據使用 H.264 編碼 , 音頻數據使用 AAC 編碼 , 最後將音視頻數據都打包到 RTMP 數據包中 , 使用 RTMP 協議上傳到 RTMP 服務器中 ;


Android 端中主要完成手機端採集視頻數據操作 , 並將視頻數據傳遞給 JNI , 在 NDK 中使用 x264 將圖像轉爲 H.264 格式的視頻 , 最後將 H.264 格式的視頻打包到 RTMP 數據包中 , 上傳到 RTMP 服務器中 ;


上一篇博客中實現將 NV21 圖像順時針旋轉 90 度的算法 , 後置攝像頭需要順時針旋轉 90 度, 前置攝像頭與後置攝像頭相反 , 需要逆時針旋轉 90 度 ;


本博客展示 NV21 圖像前置 , 後置攝像頭旋轉後的效果 , 先搭建起 RTMP 服務器 , 這一次直接編寫一個快速搭建 RTMP 服務器的 Shell 腳本 , 每次重新搭建太麻煩 ;





一、 編寫快速搭建 RTMP 服務器 Shell 腳本



每次購買開啓服務器測試都要搭建 RTMP 服務器 , 這裏寫一個簡單的 Shell 腳本 , 上傳指定的文件到指定目錄後 , 自動完成 RTMP 服務器搭建並啓動 RTMP 服務器 ;


購買阿里雲服務器 , 參考之前的博客內容 , 【Android RTMP】RTMP 直播推流 ( 阿里雲服務器購買 | 遠程服務器控制 | 搭建 RTMP 服務器 | 服務器配置 | 推流軟件配置 | 直播軟件配置 | 推流直播效果展示 ) ;

服務器設置 : 一定要確保入方向打開了 8080 和 1935 端口 , 否則 RTMP 服務器 HTTP 無法訪問 , RTMP 無法推流 ;

在這裏插入圖片描述


上傳路徑 : 將博客資料中的 RTMP 服務器搭建需要的 44 個文件上傳到遠程 Ubuntu 18.04 服務器中的 /root/rtmp 目錄下 ; ( 注意 Shell 腳本全部基於該目錄 )

在這裏插入圖片描述


編寫 Shell 腳本 : 將每一步操作記錄下來 , 下一次啓動服務器 , 上傳 55 個文件到 /root/rtmp 目錄下 , 執行該 Shell 腳本 , 即可完成 RTMP 服務器搭建 ;

#!/bin/bash

# 該 Shell 腳本必須在 /root/rtmp 目錄下執行
# 此外 nginx.conf , nginx-1.15.3.tar.gz , nginx-rtmp-module-1.2.1.tar.gz , sources.list
# 四個文件必須上傳到該 /root/rtmp 目錄下

# 備份源
mv /etc/apt/sources.list /etc/apt/sourses.list.backup
# 拷貝國內源
cp sources.list /etc/apt/
# 更新源
sudo apt-get update

# 安裝 pcre 庫
sudo apt-get install libpcre3 libpcre3-dev
# 安裝 OpenSSL 庫
sudo apt-get install openssl libssl-dev
# 安裝 zlib 庫
sudo apt-get install zlib1g-dev

# 解壓 Nginx 服務器源碼
tar xvf nginx-1.15.3.tar.gz
# 解壓 nginx-rtmp-module 模塊源碼
tar xvf nginx-rtmp-module-1.2.1.tar.gz

# 進入 Nginx 源碼目錄
cd nginx-1.15.3/

# 生成 Makefile 文件
./configure --prefix=./bin --add-module=../nginx-rtmp-module-1.2.1

# 編譯安裝
make install

# 備份 Nginx 服務器配置腳本
mv /root/rtmp/nginx-1.15.3/bin/conf/nginx.conf /root/rtmp/nginx-1.15.3/bin/conf/nginx.conf.backup

# 複製上傳到腳本 nginx.conf 到 nginx-1.15.3/bin/conf/ 目錄下
cp /root/rtmp/nginx.conf /root/rtmp/nginx-1.15.3/bin/conf/

# 查看 1935 和 8080 端口號
lsof -i:8080
lsof -i:1935 

# 啓動服務器
# 特別注意 : 一定要確保阿里雲服務器的安全組開啓了 入方向的 TCP 8080 和 1935 端口
/root/rtmp/nginx-1.15.3/bin/sbin/nginx

# 查看 1935 和 8080 端口號
lsof -i:8080
lsof -i:1935 




二、 RTMP 快速搭建方法



再起一臺服務器測試下上面的 Shell 腳本 , 購買後注意開啓入方向的 TCP 1935 和 8080 端口 ;


1 . 上傳服務器文件 : 將這 55 個文件上傳到服務器端 /root/rtmp 目錄下 , 注意不要傳錯目錄 , 否則 Shell 腳本執行肯定出錯 ;

在這裏插入圖片描述



2 . 執行 Shell 腳本 :


① 進入 /root/rtmp 目錄 : 必須在該目錄下執行 , 否則會出錯 ;


② 給 rtmp_server_build.sh 腳本賦予執行權限 ;

$ chmod -R 777 rtmp_server_build.sh

③ 在該目錄下執行 :

$ rtmp_server_build.sh

④ 出現下面錯誤解決方案 : 這是在 Windows 中編輯保存文件導致的 , 使用 vi rtmp_server_build.sh 命令打開文件 , 在命令模式下 , 該模式輸入 :set ff=unix , 將文件設置成 Unix 文件 , 然後執行 :wq 保存退出即可 ; ( : 是進入底線命令模式 )

-bash: ./rtmp_server_build.sh: /bin/bash^M: bad interpreter: No such file or directory

⑤ RTMP 服務器啓動成功 : 瀏覽器訪問 http://123.57.37.45:8080/stat 地址 ;

在這裏插入圖片描述





三、創建阿里雲 RTMP 服務器鏡像



創建鏡像 :

在這裏插入圖片描述


創建的鏡像 : 其中只有 RTMP 服務器相關文件 ;

在這裏插入圖片描述


創建個鏡像 , 之後避免每次都要手動搭建 RTMP 服務器 , 如果有需要的 , 可以在博客下方瀏覽 , 共享鏡像 ;





四、瀏覽器查看直播內容



1 . 瀏覽器查看直播內容 : Android 手機端將推流地址修改爲 rtmp://59.110.116.214/myapp/mystream , 即可在服務器的 http://59.110.116.214:8080/ 地址的 jwplayer 播放器中播放該推流的內容 , 可以不使用直播軟件觀看該直播 ;


2 . 頁面源碼分析 : 這是 http://59.110.116.214:8080/ 地址頁面的源碼 , 可以分析出該界面播放器播放的視頻來源 ; 需要將 rtmp://localhost/myapp?carg=1/mystream?sarg=2 鏈接中的 localhost 修改爲 實際的 IP 地址 59.110.116.214 ;

<b>Play</b> | <a href="record.html">Record</a>
<br/>
<script type="text/javascript" src="/jwplayer/jwplayer.js"></script>

<div id="container">Loading the player ...</div>
    <script type="text/javascript">
        jwplayer("container").setup({
        sources: [
            {
                file: "rtmp://localhost/myapp?carg=1/mystream?sarg=2"
            }
        ],
        image: "bg.jpg",
        autostart: false,
        width: 640,
        height: 480,
        primary: "flash"
});
</script>

3 . 修改 HTML 頁面信息 : 使用 vim 編輯器修改 /root/rtmp/nginx-rtmp-module-1.2.1/test/www/index.html 主頁的 RTMP 直播源 IP 地址 , 將該 IP 地址改爲當前的的服務器的 IP 地址 ;

$ vim /root/rtmp/nginx-rtmp-module-1.2.1/test/www/index.html

在這裏插入圖片描述


4 . 瀏覽器觀看直播 : 之後可以通過 http://59.110.116.214:8080/ 地址觀看直播內容 ;





五、前置 / 後置攝像頭圖像旋轉效果展示



1 . 後置攝像頭橫屏效果展示 :


① 手機端 : 推流地址 rtmp://59.110.116.214/myapp/mystream ;

在這裏插入圖片描述


② 瀏覽器端 : 訪問 http://59.110.116.214:8080/ 地址 , 注意要將該 HTML 頁面中的 rtmp 源修改爲

        sources: [
            {
                file: "rtmp://59.110.116.214/myapp?carg=1/mystream?sarg=2"
            }
        ],

在這裏插入圖片描述



2 . 後置攝像頭豎屏效果展示 :


① 手機端 : 推流地址 rtmp://59.110.116.214/myapp/mystream ;

在這裏插入圖片描述


② 瀏覽器端 : 訪問 http://59.110.116.214:8080/ 地址 , 注意要將該 HTML 頁面中的 rtmp 源修改爲

        sources: [
            {
                file: "rtmp://59.110.116.214/myapp?carg=1/mystream?sarg=2"
            }
        ],

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章