Android-再次解讀螢石雲視頻

来源:https://www.cnblogs.com/qinzishuai/archive/2019/09/06/11471207.html
-Advertisement-
Play Games

### 前言 我之前寫過一篇螢石雲的集成文章,很多人問我有沒有demo, 今天我再次總結一下, 並加個些功能。 - 集成步驟 - 視頻預覽播放 - 視頻放大縮小 - 視頻的質量切換 - 截圖 - 視頻載入細節 之前的文章大家可以看下麵的鏈接: https://mp.weixin.qq.com/s/V ...


### 前言 我之前寫過一篇螢石雲的集成文章,很多人問我有沒有demo, 今天我再次總結一下, 並加個些功能。 - 集成步驟 - 視頻預覽播放 - 視頻放大縮小 - 視頻的質量切換 - 截圖 - 視頻載入細節 之前的文章大家可以看下麵的鏈接: https://mp.weixin.qq.com/s/V4F2_bkY8QFN167KY9gSDg 先看效果圖: ![](https://img2018.cnblogs.com/blog/1312938/201909/1312938-20190906095754634-787402893.gif) ### 集成步驟 ###### 1.安裝SDK ``` dependencies { compile 'com.hikvision.ezviz:ezviz-sdk:4.8.6.2' } ``` ###### 2.配置工程 (1).許可權配置 在 AndroidMainfest.xml 文件中添加: ``` //網路許可權 //存儲許可權 //wifi 狀態許可權 //熱點配網掃描wifi需要使用 ``` (2).配置build.gradle ``` defaultConfig { ... ndk { abiFilters "armeabi-v7a"//只支持v7a } } sourceSets { main { jniLibs.srcDirs = ['libs'] } } ``` (3).配置 AndroidManifest.xml 添加如下activity定義,用於sdk中間頁顯示,包含登錄、開通雲存儲等。 ``` ``` 具體可以參考官方集成網站 https://open.ys7.com/doc/zh/book/4.x/android-sdk.html ### 視頻預覽播放 播放與之前版本不同,**加入設備的驗證碼** ``` mEZPlayer.setPlayVerifyCode("驗證碼"); ``` (1).SDK初始化(在application中初始化) ``` /** * sdk日誌開關,正式發佈需要去掉 */ EZOpenSDK.showSDKLog(true); /** * 設置是否支持P2P取流,詳見api */ EZOpenSDK.enableP2P(false); /** * APP_KEY請替換成自己申請的 */ EZOpenSDK.initLib(this, APP_KEY); ``` (2).播放主要代碼 設置token ``` EZOpenSDK.getInstance().setAccessToken("你的token"); ``` **實現代碼:** 佈局主要控制項是SurfaceView,SurfaceView的用法大家應該都知道吧,主要實現了implements SurfaceHolder.Callback介面,聲明SurfaceView 對象,並實方法,代碼如下: ``` private SurfaceView mRealPlaySv = null; private SurfaceHolder mRealPlaySh = null; ``` ``` mRealPlaySh = mRealPlaySv.getHolder(); mRealPlaySh.addCallback(VideoActivity.this); ``` ``` Override public void surfaceCreated(SurfaceHolder holder) { if (mEZPlayer != null) { mEZPlayer.setSurfaceHold(holder); } else { } mRealPlaySh = holder; } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { } @Override public void surfaceDestroyed(SurfaceHolder holder) { if (mEZPlayer != null) { mEZPlayer.setSurfaceHold(null); } mRealPlaySh = null; } ``` ``` ``` 實現Handler.Callback,來監聽播放結果回調: ``` @Override public boolean handleMessage(Message msg) { switch (msg.what){ } return false; } ``` 配置: ``` //用來存儲螢石雲的播放質量、序列號 mCameraInfo=new EZCameraInfo(); // 2-高清,1-標清,0-流暢 mCameraInfo.setVideoLevel(2); //序列號 mCameraInfo.setDeviceSerial("C86398971"); mCameraInfo.setCameraNo(1); ``` 開始播放: ``` private void startRealPlay() { mEZPlayer = YourApplication.getOpenSDK().createPlayer(mCameraInfo.getDeviceSerial(), mCameraInfo.getCameraNo()); mEZPlayer.setPlayVerifyCode(mVerificationCode); mEZPlayer.setHandler(mHandler); mEZPlayer.setSurfaceHold(mRealPlaySh); mEZPlayer.startRealPlay(); tvPlay.setEnabled(true); } ``` ### **視頻放大,手勢放大功能** 在播放成功的回調裡加上 setRealPlaySvLayout();方法,方法的代碼如下: ``` private void setRealPlaySvLayout() throws InnerException, PlaySDKException { DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); int whdth = dm.widthPixels; int height = dm.heightPixels; mRealPlayTouchListener.setSacaleRect(Constant.MAX_SCALE, 0, 0, whdth, height); setPlayScaleUI(1, null, null); } ``` ``` private void setPlayScaleUI(float scale, CustomRect oRect, CustomRect curRect) { if (scale == 1) { try { if (mEZPlayer != null) { mEZPlayer.setDisplayRegion(false, null, null); } } catch (BaseException e) { // TODO Auto-generated catch block e.printStackTrace(); } } else { if (mPlayScale == scale) { try { if (mEZPlayer != null) { mEZPlayer.setDisplayRegion(true, oRect, curRect); } } catch (BaseException e) { // TODO Auto-generated catch block e.printStackTrace(); } return; } try { if (mEZPlayer != null) { mEZPlayer.setDisplayRegion(true, oRect, curRect); } } catch (BaseException e) { // TODO Auto-generated catch block e.printStackTrace(); } } mPlayScale = scale; } ``` ### 視頻質量切換 效果圖: ![](https://img2018.cnblogs.com/blog/1312938/201909/1312938-20190906095808850-1209709960.gif) 核心方法 ``` // 2-高清,1-標清,0-流暢 mCameraInfo.setVideoLevel ``` 切換畫質 ``` /** * 碼流配置 清晰度 2-高清,1-標清,0-流暢 * * @see * @since V2.0 */ private void setQualityMode(final EZConstants.EZVideoLevel mode) { if (mEZPlayer != null) { mWaitDialog.setWaitText("正在設置畫面質量…"); mWaitDialog.show(); Thread thr = new Thread(new Runnable() { @Override public void run() { try { // need to modify by yudan at 08-11 APP.getOpenSDK().setVideoLevel(mCameraInfo.getDeviceSerial(), mCameraInfo.getCameraNo(), mode.getVideoLevel()); mCurrentQulityMode = mode; Message msg = Message.obtain(); msg.what = MSG_SET_VEDIOMODE_SUCCESS; mHandler.sendMessage(msg); } catch (BaseException e) { mCurrentQulityMode = EZConstants.EZVideoLevel.VIDEO_LEVEL_FLUNET; e.printStackTrace(); Message msg = Message.obtain(); msg.what = MSG_SET_VEDIOMODE_FAIL; mHandler.sendMessage(msg); } } }) { }; thr.start(); } } ``` 切換畫質結果: ``` //切換畫質成功 case EZConstants.EZRealPlayConstants.MSG_SET_VEDIOMODE_SUCCESS: handleSetVedioModeSuccess(); break; //切換畫質失敗 case EZConstants.EZRealPlayConstants.MSG_SET_VEDIOMODE_FAIL: handleSetVedioModeFail(msg.arg1); break; ``` ### 聲音與截圖 1.聲音 核心方法: ``` mLocalInfo.setSoundOpen(false); ``` 2.截圖 核心方法: ``` mEZPlayer.capturePicture() ``` 需要**源碼**的朋友可以加我的微信:lengquele5311 ![](https://img2018.cnblogs.com/blog/1312938/201909/1312938-20190906095809708-1381148883.jpg) 大家可以關註我的微信公眾號:「秦子帥」一個有質量、有態度的公眾號! ![公眾號](https://img2018.cnblogs.com/blog/1312938/201909/1312938-20190906095809875-938818605.jpg)
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [mysqld] log_bin = mysql-bin binlog_format = mixed expire_logs_days = 7 # 超過7天的binlog刪除 slow_query_log = 1 long_query_time = 3 # 慢查詢時間 超過3秒則為慢查詢 slow-... ...
  • 實現批處理的技術許許多多,從各種關係型資料庫的sql處理,到大數據領域的MapReduce,Hive,Spark等等。這些都是處理有限數據流的經典方式。而Flink專註的是無限流處理,那麼他是怎麼做到批處理的呢? 無限流處理:輸入數據沒有盡頭;數據處理從當前或者過去的某一個時間 點開始,持續不停地進 ...
  • 1、下載安裝包 官網下載地址:https://redisdesktop.com/pricing 官網下載需要付費使用 再此附上一個免費的破解版本,綠色安全可用 鏈接:https://pan.baidu.com/s/1K5Yd1OQ8nAofCl79Hp8r1A 提取碼:528k 下載完後後直接打開e ...
  • Ethink組件取值手冊一、取值Sql查詢配置中取值方式:所有可以對外過濾的組件都可以用id.output取值 就是取組件setOutput()里輸出的值 ,具體分為以下兩種:1)$p{OBJ_1.output}—用於sql語句中根據值的類型加引號 如:’安徽’2)$p[OBJ_1.output]—... ...
  • 修改so庫中的依賴名 在 "ArchLinuxArm" 上有一些針對 aarch64, arm, armeabi v7a 等Android常用架構的so庫可以下載,有時候可以省去很多編譯時間,且都是編譯optimize比較好的版本,而且基本都是最新版本的代碼編譯的。比如SuiteSparse就是例子 ...
  • 版權聲明:本文為xing_star原創文章,轉載請註明出處! 本文同步自http://javaexception.com/archives/207 ImageView設置rounded corner 到2019年,現在的圖片載入框架,幾乎都是Glide了。 最近的需求又碰到了要給圖片設置圓角,發現之 ...
  • 任務結果標簽 當 Gradle 執行一個任務時,它會在控制台和 Tooling API 根據任務結果給任務打標簽。 這些標簽是根據任務是否有操作,是否應該執行操作,是否執行了操作以及這些操作做了哪些改變 來標記的。 下麵是 Gradle 的標簽以及對應的條件 (無標簽)或者 EXECUTED 任務執 ...
  • 將string字元串轉換為array數組 NSArray *array = [Str componentsSeparatedByString:@","]; ==反向方法 將array數組轉換為string字元串 NSString *tempString = [mutableArray compone ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...