点击上方蓝字关注 ??

前言

我之前写过一篇萤石云的集成文章,很多人问我有没有demo, 今天我再次总结一下, 并加个些功能。

  • 集成步骤

  • 视频预览播放

  • 视频放大缩小

  • 视频的质量切换

  • 截图

之前的文章大家可以看下面的链接:

https://mp.weixin.qq.com/s/V4F2_bkY8QFN167KY9gSDg

效果图:(因为压缩的缘故,请忽略图片质量)

集成步骤

1.安装SDK

dependencies {compile 'com.hikvision.ezviz:ezviz-sdk:4.8.6.2'
}

2.配置工程

(1).权限配置

在 AndroidMainfest.xml 文件中添加:

//网络权限<uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/><uses-permission android:name="android.permission.RECORD_AUDIO"/><uses-permission android:name="android.permission.READ_PHONE_STATE"/>
//存储权限<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
//wifi 状态权限<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/><uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/><uses-permission android:name="android.permission.CHANGE_WIFI_MULTICAST_STATE"/>
//热点配网扫描wifi需要使用<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>

(2).配置build.gradle

defaultConfig {
...
ndk {
abiFilters "armeabi-v7a"//只支持v7a
}
}
sourceSets {
main {
jniLibs.srcDirs = ['libs']
}
}

(3).配置 AndroidManifest.xml

添加如下activity定义,用于sdk中间页显示,包含登录、开通云存储等。

android:name="com.videogo.main.EzvizWebViewActivity"
android:screenOrientation="portrait"
android:configChanges="orientation|keyboardHidden">activity>

具体可以参考官方集成网站

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);

Overridepublic void surfaceCreated(SurfaceHolder holder) {if (mEZPlayer != null) {
mEZPlayer.setSurfaceHold(holder);
} else {
}
mRealPlaySh = holder;
}@Overridepublic void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
}@Overridepublic void surfaceDestroyed(SurfaceHolder holder) {if (mEZPlayer != null) {
mEZPlayer.setSurfaceHold(null);
}
mRealPlaySh = null;
}

android:id="@+id/realplay_sv"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_alignParentLeft="true"android:layout_alignParentStart="true"android:layout_alignParentTop="true"android:background="@android:color/transparent" />

实现Handler.Callback,来监听播放结果回调:

@Overridepublic boolean handleMessage(Message msg) {switch (msg.what){
}return false;
}

配置播放质量与序列号等:

//用来存储萤石云的播放质量、序列号 mCameraInfo=new EZCameraInfo();// 2-高清,1-标清,0-流畅 mCameraInfo.setVideoLevel(2);//序列号 mCameraInfo.setDeviceSerial("你的设备序列号"); 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;
}

视频质量切换

效果图:

核心方法

// 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() {@Overridepublic 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()

源码获取:

加我的微信备注源码,我的微信:

—————END—————

     

   创作不易,点个“在看

android p wifi一直在扫描_Android再次解读萤石云视频相关推荐

  1. android p wifi一直在扫描_Android Wifi 扫描及自动连接

    缘起 最近有个需求,要求App能够自动扫描到某个热点然后自动连接上热点.背景是我们公司属于IoT行业,这个热点是设备发出的,有固定的前缀(比如设备热点名为SmartLife-xx),可以直接连接无需密 ...

  2. 萤石android播放成功没画面,Android-再次解读萤石云视频

    前言 我之前写过一篇萤石云的集成文章,很多人问我有没有demo, 今天我再次总结一下, 并加个些功能. 集成步骤 视频预览播放 视频放大缩小 视频的质量切换 截图 视频加载细节 之前的文章大家可以看下 ...

  3. android p wifi一直在扫描_(一百六十八)Android P wifi 扫描失败结果上报流程梳理-扫描上报梳理②...

    接(一百五十五)Android P wifi 扫描失败结果上报流程梳理-扫描上报梳理 扫描失败上报梳理发现梳理的差了很多,特补充 1.WificondScannerImpl @Override pub ...

  4. android p wifi一直在扫描_在Android上的每次WiFi扫描之间我应该使用什么时间间隔?...

    我需要定期执行Wifi扫描.当时间间隔设置为1-2秒时,我遇到了问题.好像我没有得到任何ScanResult.是否有最短的时间设置,以便WifiManager能够执行成功的WiFi扫描? 这是代码.我 ...

  5. android扫描wifi列表,android 生成wifi热点以及扫描连接wifi

    public abstract class WifiAdmin { private static final String TAG ="Show"; private WifiMan ...

  6. 【Android App】检查手机连接WiFi信息以及扫描周围WiFi的讲解及实战(附源码和演示 超详细必看)

    需要全部代码请点赞关注收藏后评论区留言私信~~~ 一.检查是否连接WiFi以及输出WiFi信息 传统的定位方式不适用于室内的垂直定位,原因如下: (1)卫星定位要求没有障碍物遮挡,它在户外比较精准,在 ...

  7. Android 9 wifi PNO 扫描

    PNO 即Preferred Network Offload,用于系统在休眠的时候连接WiFi 四种场景 亮屏情况: 在WiFi Settings界面,无论WiFi是否有连接,固定扫描时间间隔为10s ...

  8. (五十四)Android O WiFi 获取扫描结果流程梳理

    前言:之前在(五十) Android O WiFi的扫描流程梳理 已经梳理过扫描流程了,那扫描完的结果会呈现在设置的WiFi界面,那扫描结果是如何获取的呢? 1. wifi扫描结果简介 WiFi的扫描 ...

  9. Android中Wi-Fi扫描、连接和信息(一)

    1.Wi-Fi介绍 Wi-Fi是一种允许电子设备连接到一个无线局域网(WLAN)的技术,通常使用2.4G UHF或5G SHF ISM 射频频段.连接到无线局域网通常是有密码保护的:但也可是开放的,这 ...

最新文章

  1. 一文读懂云计算、边缘计算、移动边缘计算和自动驾驶的前世今生!
  2. python 搜索pdf文件中的文字_使用python查找搜索字符串在pdf文档中位于哪一页上...
  3. sqoop增量导入hdfs和导出
  4. 微软的平板电脑_Microsoft 微软 Surface Go 2 10.5英寸二合一平板电脑(m3-8100Y、8GB、128GB、LTE) 5788元...
  5. python实现雪花飘落的效果_使用javascript实现雪花飘落的效果
  6. idea 中maven编译速度过慢的问题的解决
  7. 指定的服务已经标记为删除_全球70%的“根服务器”设在美国,为避免关网,中国已经在行动!...
  8. 「leetcode」129. 求根到叶子节点数字之和【递归中隐藏着回溯】详解
  9. NiosII软处理器快速入门- 10分钟学会NiosII(3)
  10. Mac 安装 CentOS镜像 及 VMware虚拟机
  11. 市场需求分析(MRD)模板
  12. NDP和LLDP协议
  13. CSDN超实用的浏览器插件—去自家网站/搜索广告、超快捷万能搜索、各种实用小功能等诸多功能等你探索
  14. excel如何选中空单元格并计算总计、平均值、率
  15. 路由器组成及路由器发展概述
  16. 训练集、验证集、测试集的作用和意义
  17. 关于栈顶指针初值为-1和0的区别
  18. UWA学堂专栏推荐:Unity项目从Gamma转Linear颜色空间的经验分享
  19. MPS——超小尺寸 IEEE802.3af PD 解决方案
  20. 笔记:3.5 《数据库系统概论》之基本表更新(INSERT、UPDATE、ALTER、DELETE)与视图VIEW(定义、查询、更新)

热门文章

  1. MapReduce编程实践
  2. IDEA开发vue.js卡死问题
  3. sqlite性能优化
  4. 集合框架中的接口及其实现类
  5. [数分提高]2014-2015-2第9教学周第1次课 (2015-04-28)
  6. Objective-C组合模式(Composite)
  7. 思考设计模式在自助终端软件上的应用 ——Observer(观察着)模式
  8. 用户自定义的数据库备份(选自csdn\blog)
  9. 在div中设置文字与内部div垂直居中
  10. touchWX 自定义组件以及传值