日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

【Android RTMP】NV21 图像旋转处理 ( 图像旋转算法 | 后置摄像头顺时针旋转 90 度 | 前置摄像头顺时针旋转 90 度 )

發(fā)布時間:2025/6/17 Android 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【Android RTMP】NV21 图像旋转处理 ( 图像旋转算法 | 后置摄像头顺时针旋转 90 度 | 前置摄像头顺时针旋转 90 度 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 安卓直播推流專欄博客總結
  • 一、 后置攝像頭順時針旋轉 90 度
  • 二、 前置攝像頭順時針旋轉 90 度
  • 三、 NV21 格式圖像旋轉代碼





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



Android RTMP 直播推流技術專欄 :


0 . 資源和源碼地址 :

  • 資源下載地址 : 資源下載地址 , 服務器搭建 , x264 , faac , RTMPDump , 源碼及交叉編譯庫 , 本專欄 Android 直播推流源碼 ;
  • GitHub 源碼地址 : han1202012 / RTMP_Pusher

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

  • 【Android RTMP】RTMP 直播推流服務器搭建 ( Ubuntu 18.04.4 虛擬機 )

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

  • 【Android RTMP】RTMPDumb 源碼導入 Android Studio ( 交叉編譯 | 配置 CMakeList.txt 構建腳本 )

  • 【Android RTMP】Android Studio 集成 x264 開源庫 ( Ubuntu 交叉編譯 | Android Studio 導入函數庫 )

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

  • 【Android RTMP】RTMP 數據格式 ( FLV 視頻格式分析 | 文件頭 Header 分析 | 標簽 Tag 分析 | 視頻標簽 Tag 數據分析 )

  • 【Android RTMP】RTMP 數據格式 ( FLV 視頻格式分析 | AVC 序列頭格式解析 )

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

  • 【Android RTMP】Android Camera 視頻數據采集預覽 ( 視頻采集相關概念 | 攝像頭預覽參數設置 | 攝像頭預覽數據回調接口 )

  • 【Android RTMP】Android Camera 視頻數據采集預覽 ( NV21 圖像格式 | I420 圖像格式 | NV21 與 I420 格式對比 | NV21 轉 I420 算法 )

  • 【Android RTMP】Android Camera 視頻數據采集預覽 ( 圖像傳感器方向設置 | Camera 使用流程 | 動態(tài)權限申請 )

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

  • 【Android RTMP】x264 編碼器初始化及設置 ( 獲取 x264 編碼參數 | 編碼規(guī)格 | 碼率 | 幀率 | B幀個數 | 關鍵幀間隔 | 關鍵幀解碼數據 SPS PPS )

  • 【Android RTMP】x264 圖像數據編碼 ( Camera 圖像數據采集 | NV21 圖像數據傳到 Native 處理 | JNI 傳輸字節(jié)數組 | 局部引用變量處理 | 線程互斥 )

  • 【Android RTMP】x264 圖像數據編碼 ( NV21 格式中的 YUV 數據排列 | Y 灰度數據拷貝 | U 色彩值數據拷貝 | V 飽和度數據拷貝 | 圖像編碼操作 )

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

  • 【Android RTMP】RTMPDump 封裝 RTMPPacket 數據包 ( 封裝 SPS / PPS 數據包 )

  • 【Android RTMP】RTMPDump 封裝 RTMPPacket 數據包 ( 關鍵幀數據格式 | 非關鍵幀數據格式 | x264 編碼后的數據處理 | 封裝 H.264 視頻數據幀 )

  • 【Android RTMP】RTMPDump 推流過程 ( 獨立線程推流 | 創(chuàng)建推流器 | 初始化操作 | 設置推流地址 | 啟用寫出 | 連接 RTMP 服務器 | 發(fā)送 RTMP 數據包 )

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

  • 【Android RTMP】RTMP 直播推流 ( 阿里云服務器購買 | 遠程服務器控制 | 搭建 RTMP 服務器 | 服務器配置 | 推流軟件配置 | 直播軟件配置 | 推流直播效果展示 )

  • 【Android RTMP】RTMP 直播推流階段總結 ( 服務器端搭建 | Android 手機端編碼推流 | 電腦端觀看直播 | 服務器狀態(tài)查看 )

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

  • 【Android RTMP】NV21 圖像旋轉處理 ( 問題描述 | 圖像順時針旋轉 90 度方案 | YUV 圖像旋轉細節(jié) | 手機屏幕旋轉方向 )

  • 【Android RTMP】NV21 圖像旋轉處理 ( 圖像旋轉算法 | 后置攝像頭順時針旋轉 90 度 | 前置攝像頭順時針旋轉 90 度 )

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

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

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

  • 【Android RTMP】音頻數據采集編碼 ( 音頻數據采集編碼 | AAC 高級音頻編碼 | FAAC 編碼器 | Ubuntu 交叉編譯 FAAC 編碼器 )

  • 【Android RTMP】音頻數據采集編碼 ( FAAC 頭文件與靜態(tài)庫拷貝到 AS | CMakeList.txt 配置 FAAC | AudioRecord 音頻采樣 PCM 格式 )

11. 解析 AAC 音頻格式 :

  • 【Android RTMP】音頻數據采集編碼 ( AAC 音頻格式解析 | FLV 音頻數據標簽解析 | AAC 音頻數據標簽頭 | 音頻解碼配置信息 )

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

  • 【Android RTMP】音頻數據采集編碼 ( FAAC 音頻編碼參數設置 | FAAC 編碼器創(chuàng)建 | 獲取編碼器參數 | 設置 AAC 編碼規(guī)格 | 設置編碼器輸入輸出參數 )

  • 【Android RTMP】音頻數據采集編碼 ( FAAC 編碼器編碼 AAC 音頻解碼信息 | 封裝 RTMP 音頻數據頭 | 設置 AAC 音頻數據類型 | 封裝 RTMP 數據包 )

  • 【Android RTMP】音頻數據采集編碼 ( FAAC 編碼器編碼 AAC 音頻采樣數據 | 封裝 RTMP 音頻數據頭 | 設置 AAC 音頻數據類型 | 封裝 RTMP 數據包 )






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


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


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





一、 后置攝像頭順時針旋轉 90 度



1 . NV21 格式圖像數據的排列 : 161616 個 Y 灰度數據在前 , 然后 444 組 ( 888 個 ) VU 色彩值 , 飽和度 , 數據交替存放 ;


[y1y2y3y4y5y6y7y8y9y10y11y12y13y14y15y16v1u1v2u2v3u3v4u4]\begin{bmatrix} y1 & y2 & y3 & y4 \\\\ y5 & y6 & y7 & y8 \\\\ y9 & y10& y11& y12 \\\\ y13& y14& y15& y16 \\\\ v1 & u1 & v2 & u2 \\\\ v3 & u3 & v4 & u4\\ \end{bmatrix}???????????????????y1y5y9y13v1v3?y2y6y10y14u1u3?y3y7y11y15v2v4?y4y8y12y16u2u4????????????????????



2 . NV21 格式的圖像的 YUV 值順時針旋轉 90 度后的 YUV 矩陣為 :


[y13y9y5y1y14y10y6y2y15y11y7y3y16y12y8y4v3u3v1u1v4u4v2u2]\begin{bmatrix} y13 & y9 & y5 & y1 \\\\ y14 & y10 & y6 & y2 \\\\ y15 & y11& y7& y3 \\\\ y16& y12& y8& y4 \\\\ v3 & u3 & v1 & u1 \\\\ v4 & u4 & v2 & u2\\ \end{bmatrix}???????????????????y13y14y15y16v3v4?y9y10y11y12u3u4?y5y6y7y8v1v2?y1y2y3y4u1u2????????????????????



3 . 灰度值 Y 數據讀取順序 :


① 外層循環(huán) : 逐行遍歷, 從第一行遍歷到最后一行, 從 0 到 mWidth - 1 ;

② 內存循環(huán) : 遍歷每一行時, 從底部遍歷到頂部, 從 mHeight - 1 到 0 ;

for (int i = 0; i < mWidth; i++) {// 第 i 行, 從每一列的最后一個像素 ( 索引 mHeight - 1 ) 遍歷到第一個像素 ( 索引 0 )for (int j = mHeight - 1; j >= 0; j--) {// 將讀取到的 Y 灰度值存儲到 mNv21DataBuffer 緩沖區(qū)中mNv21DataBuffer[positionIndex++] = data[mWidth * j + i];} }

4 . 飽和度 色彩值 UV 數據讀取順序 :


① 數據高度個數 : Y 數據的高度與圖像高度相等 , UV 數據高度相當于 Y 數據高度的一半 ;

② UV 數據排列 : V 色彩值在前, U 飽和度在后, UV 數據交替排列 , 一行 mWidth 中, 排布了 mWidth / 2 組 UV 數據 ;

③ UV 數據組有 mWidth / 2 行, mHeight / 2 列, 因此遍歷時, 有如下規(guī)則 :

  • 按照行遍歷 : 遍歷 mWidth / 2 次
  • 按照列遍歷 : 遍歷 mHeight / 2 次

④ 外層遍歷 : 每隔 2 行, 遍歷一次, 遍歷 mWidth / 2 次 ; 遍歷行從 0 到 mWidth / 2 - 1 ;

⑤ 內層遍歷 : UV 數據也需要倒著讀 , 從 mHeight / 2 - 1 遍歷到 0 ;

for (int i = 0; i < mWidth / 2; i ++) {for (int j = UVByteHeight - 1; j >= 0; j--) {// 讀取數據時, 要從 YByteCount 之后的數據開始遍歷// 使用 mWidth 和 UVByteHeight 定位要遍歷的位置// 拷貝 V 色彩值數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i];// 拷貝 U 飽和度數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i + 1];} }



二、 前置攝像頭順時針旋轉 90 度



1 . NV21 格式圖像數據的排列 : 161616 個 Y 灰度數據在前 , 然后 444 組 ( 888 個 ) VU 色彩值 , 飽和度 , 數據交替存放 ;


[y1y2y3y4y5y6y7y8y9y10y11y12y13y14y15y16v1u1v2u2v3u3v4u4]\begin{bmatrix} y1 & y2 & y3 & y4 \\\\ y5 & y6 & y7 & y8 \\\\ y9 & y10& y11& y12 \\\\ y13& y14& y15& y16 \\\\ v1 & u1 & v2 & u2 \\\\ v3 & u3 & v4 & u4\\ \end{bmatrix}???????????????????y1y5y9y13v1v3?y2y6y10y14u1u3?y3y7y11y15v2v4?y4y8y12y16u2u4????????????????????



2 . NV21 格式的圖像的 YUV 值逆時針旋轉 90 度后的 YUV 矩陣為 :


[y4y8y12y16y3y7y11y15y2y6y10y14y1y5y9y13v2u2v4u4v1u1v3u3]\begin{bmatrix} y4 & y8 & y12 & y16 \\\\ y3 & y7 & y11 & y15 \\\\ y2 & y6& y10& y14 \\\\ y1& y5& y9 & y13 \\\\ v2 & u2 & v4 & u4 \\\\ v1 & u1 & v3 & u3 \\ \end{bmatrix}???????????????????y4y3y2y1v2v1?y8y7y6y5u2u1?y12y11y10y9v4v3?y16y15y14y13u4u3????????????????????



3 . 灰度值 Y 數據讀取順序 :


① 外層循環(huán) : 逐行遍歷, 從最后一行遍歷到第一行, 從 mWidth - 1 到 0 ;

② 內存循環(huán) : 遍歷第 i 行時, 從頂部遍歷到底部, 從 0 到 mHeight - 1

for (int i = mWidth - 1; i >= 0; i--) {// 第 i 行, 從每一列的最后一個像素 ( 索引 mHeight - 1 ) 遍歷到第一個像素 ( 索引 0 )for (int j = 0; j < mHeight; j++) {// 將讀取到的 Y 灰度值存儲到 mNv21DataBuffer 緩沖區(qū)中mNv21DataBuffer[positionIndex++] = data[mWidth * j + i];} }

4 . 飽和度 色彩值 UV 數據讀取順序 :


① 數據高度個數 : Y 數據的高度與圖像高度相等 , UV 數據高度相當于 Y 數據高度的一半 ;

② UV 數據排列 : V 色彩值在前, U 飽和度在后, UV 數據交替排列 , 一行 mWidth 中, 排布了 mWidth / 2 組 UV 數據 ;

③ UV 數據組有 mWidth / 2 行, mHeight / 2 列, 因此遍歷時, 有如下規(guī)則 :

  • 按照行遍歷 : 遍歷 mWidth / 2 次
  • 按照列遍歷 : 遍歷 mHeight / 2 次

④ 外層遍歷 : 每隔 2 行, 遍歷一次, 遍歷 mWidth / 2 次 ; 遍歷行從mWidth / 2 - 1 到 0 ;

⑤ 內層遍歷 : UV 數據也需要倒著讀 , 從 0 遍歷到 mHeight / 2 - 1 ;

for (int i = mWidth / 2 - 1; i >= 0 ; i --) {for (int j = 0; j < UVByteHeight; j++) {// 讀取數據時, 要從 YByteCount 之后的數據開始遍歷// 使用 mWidth 和 UVByteHeight 定位要遍歷的位置// 拷貝 V 色彩值數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i];// 拷貝 U 飽和度數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i + 1];} }



三、 NV21 格式圖像旋轉代碼



/*** 將 NV21 格式的圖片數據順時針旋轉 90 度* 后置攝像頭順時針旋轉 90 度* 前置攝像頭逆時針旋轉 90 度* @param data*/private void nv21PictureDataClockwiseRotation90(byte[] data){// Y 灰度數據的個數int YByteCount = mWidth * mHeight;// 色彩度 U, 飽和度 V 數據高度int UVByteHeight = mHeight / 2;// 色彩度 U, 飽和度 V 數據個數int UVByteCount = YByteCount / 4;// 數據處理索引值, 用于記錄寫入到 mNv21DataBuffer 中的元素個數// 及下一個將要寫入的元素的索引int positionIndex = 0;/*后置攝像頭處理后置攝像頭需要將圖像順時針旋轉 90 度*/if(mCameraFacing == Camera.CameraInfo.CAMERA_FACING_BACK){/*讀取 Y 灰度數據順時針旋轉 90 度外層循環(huán) : 逐行遍歷, 從第一行遍歷到最后一行內存循環(huán) : 遍歷每一行時, 從底部遍歷到頂部*/for (int i = 0; i < mWidth; i++) {// 第 i 行, 從每一列的最后一個像素 ( 索引 mHeight - 1 ) 遍歷到第一個像素 ( 索引 0 )for (int j = mHeight - 1; j >= 0; j--) {// 將讀取到的 Y 灰度值存儲到 mNv21DataBuffer 緩沖區(qū)中mNv21DataBuffer[positionIndex++] = data[mWidth * j + i];}}/*讀取 UV 數據Y 數據的高度與圖像高度相等UV 數據高度相當于 Y 數據高度的一半UV 數據排列 : V 色彩值在前, U 飽和度在后, UV 數據交替排列UV 數據交替排列, 一行 mWidth 中, 排布了 mWidth / 2 組 UV 數據UV 數據組有 mWidth / 2 行, mHeight / 2 列, 因此遍歷時, 有如下規(guī)則 :按照行遍歷 : 遍歷 mWidth / 2 次按照列遍歷 : 遍歷 mHeight / 2 次外層遍歷 : 遍歷行從 0 到 mWidth / 2外層按照行遍歷時, 每隔 2 行, 遍歷一次, 遍歷 mWidth / 2 次內層遍歷時 : 遍歷列, 從 mHeight / 2 - 1 遍歷到 0UV 數據也需要倒著讀 , 從 mHeight / 2 - 1 遍歷到 0*/for (int i = 0; i < mWidth / 2; i ++) {for (int j = UVByteHeight - 1; j >= 0; j--) {// 讀取數據時, 要從 YByteCount 之后的數據開始遍歷// 使用 mWidth 和 UVByteHeight 定位要遍歷的位置// 拷貝 V 色彩值數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i];// 拷貝 U 飽和度數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i + 1];}}}else if(mCameraFacing == Camera.CameraInfo.CAMERA_FACING_FRONT){/*前置攝像頭處理前置攝像頭與后置攝像頭相反, 后置攝像頭順時針旋轉 90 度前置攝像頭需要將圖像逆時針旋轉 90 度*//*讀取 Y 灰度數據逆時針旋轉 90 度外層循環(huán) : 逐行遍歷, 從最后一行遍歷到第一行, 從 mWidth - 1 到 0內存循環(huán) : 遍歷第 i 行時, 從頂部遍歷到底部, 從 0 到 mHeight - 1*/for (int i = mWidth - 1; i >= 0; i--) {// 第 i 行, 從每一列的最后一個像素 ( 索引 mHeight - 1 ) 遍歷到第一個像素 ( 索引 0 )for (int j = 0; j < mHeight; j++) {// 將讀取到的 Y 灰度值存儲到 mNv21DataBuffer 緩沖區(qū)中mNv21DataBuffer[positionIndex++] = data[mWidth * j + i];}}/*讀取 UV 數據Y 數據的高度與圖像高度相等UV 數據高度相當于 Y 數據高度的一半UV 數據排列 : V 色彩值在前, U 飽和度在后, UV 數據交替排列UV 數據交替排列, 一行 mWidth 中, 排布了 mWidth / 2 組 UV 數據UV 數據組有 mWidth / 2 行, mHeight / 2 列, 因此遍歷時, 有如下規(guī)則 :按照行遍歷 : 遍歷 mWidth / 2 次按照列遍歷 : 遍歷 mHeight / 2 次外層遍歷 : 遍歷行從 mWidth / 2 - 1 到 0外層按照行遍歷時, 每隔 2 行, 遍歷一次, 遍歷 mWidth / 2 次內層遍歷時 : 遍歷列, 從 0 遍歷到 mHeight / 2 - 1UV 數據也需要倒著讀 , 從 0 遍歷到 mHeight / 2 - 1*/for (int i = mWidth / 2 - 1; i >= 0 ; i --) {for (int j = 0; j < UVByteHeight; j++) {// 讀取數據時, 要從 YByteCount 之后的數據開始遍歷// 使用 mWidth 和 UVByteHeight 定位要遍歷的位置// 拷貝 V 色彩值數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i];// 拷貝 U 飽和度數據mNv21DataBuffer[positionIndex++] = data[YByteCount + mWidth / 2 * 2 * j + i + 1];}}}}

總結

以上是生活随笔為你收集整理的【Android RTMP】NV21 图像旋转处理 ( 图像旋转算法 | 后置摄像头顺时针旋转 90 度 | 前置摄像头顺时针旋转 90 度 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 一区二区三区日韩精品 | 福利在线一区 | 国产男女裸体做爰爽爽 | 亚洲一| 我要看免费毛片 | 国产黄片一区二区三区 | 日本福利片在线观看 | 97高清国语自产拍 | 色版视频| 91网站免费入口 | 91偷拍网站 | aaaaaaa毛片| 欧美黄色大片免费看 | 日本少妇久久久 | 日韩一级片网址 | 久久久久久亚洲精品 | 男生把女生困困的视频 | 毛片无码一区二区三区a片视频 | 天天都色 | 大地资源高清播放在线观看 | 激情拍拍 | 无码人妻精品一区二区蜜桃色欲 | 五月天国产精品 | 亚洲性视频网站 | 色偷偷资源网 | 国产亚洲精品成人a | 91呦呦| 40一50一60老女人毛片 | 丁香婷婷视频 | 亚洲免费小视频 | 午夜精品极品粉嫩国产尤物 | 超级变态重口av番号 | 一区二区传媒有限公司 | 麻豆亚洲av成人无码久久精品 | 欧美中文字幕一区二区 | 在线一区av | 国产精品人人人人 | 免费视频一二三区 | 小视频在线看 | 亚洲资源在线播放 | 国产又粗又猛又爽又黄又 | 黄av资源 | 短视频在线观看 | 欧美视频一区二区三区四区 | 色呦呦网| 欧美精品免费播放 | 性爱视频免费 | 精品久久久久久久免费人妻 | 四季av一区二区凹凸精品 | 777片理伦片在线观看 | 国产野外作爱视频播放 | 玖玖爱国产 | 99热在线免费观看 | 精品久久久久久久久久久aⅴ | 免费一级片网站 | 91美女片黄在线观看 | japansexxxxhd医生 夜夜操导航 | 在线观看一区二区三区视频 | 视频在线观看免费大片 | 国精产品一二三区精华液 | 老司机伊人 | 欧美大片免费看 | 91精品人妻一区二区三区 | 好吊色青青草 | 性――交――性――乱 | a级在线视频 | 成人精品区 | 黄色九九| 天堂久久一区 | 男人插女人的网站 | 青青草免费在线视频 | 国产欧美日韩 | 成人黄色在线网站 | 天天干天天舔 | 亚洲AV成人无码精电影在线 | 色狗网站 | 亚洲丁香花色 | 国产成人三级在线播放 | videos麻豆| 亚洲午夜国产 | 亚洲影音 | 大香伊人久久 | 美国av大片 | 穿情趣内衣被c到高潮视频 欧美性猛交xxxx黑人猛交 | 国产又黄又大又粗的视频 | 亚洲青涩 | 麻豆性生活| 国产suv精品一区二区60 | 中文字幕在线永久 | 欧美干干干 | 欧美大黑b | 国产夫妻性生活视频 | 午夜视频91| 69国产精品视频 | 免费看a | 亚洲永久在线观看 | 国产成人综合亚洲 | 99中文字幕| 国产首页 |