CDN加速

Android 播放器SDK

更新时间:2021-01-27 16:09:19

简介

网宿提供Android播放器SDK,用于嵌入到Android端应用中,支持安卓手机、安卓平板、安卓系统的电视,实现流媒体直播、点播播放。

SDK下载

请联系网宿技术支持申请。

使用说明

  • 播放器分为轻量版和完整版,供用户应用于不同场景中,通常轻量版已经足以覆盖 大部分使用场景,因此通常推荐使用轻量版本,可以有效的减少引入播放器带来的 体积增长。
  • 轻量版播放器支持 MP4/FLV/HLS/RTMP,完整版更支持 MKV/RMVB 等更全面的 功能项,除此外两个版本并无其他区别。
  • 配合云点播、云直播服务获取播放地址,集成播放器 SDK 框架,然后调用播放器的 URL 播放接口即可播放视频或观看直播。

image

快速集成

系统支持

  • Android:支持 Android 4.0 以上, 支 持 armv5 / armv7a / arm64 / x86 / x86_64 等芯片架构;

运行环境

  • Android:推荐开发者使用 Android Studio 作为自己的开发工具,本开发文档也 是基于 Android Studio 开发环境下进行编写的;

如何导入

  1. 下载播放器 SDK
  2. 添加对 CNCMediaPlayerSDK 的依赖
    (针对 Android Plugin Version 3.0.0 以下版本的依赖),以工程库的方式将 CNCMediaPlayerSDK 依赖到工程中(修改 build.gradle 的 dependencies)。
    完整版使用:
fullCompile project(path: ':CNCMediaPlayerSDK', configuration: 'fullRelease')

轻量版使用:

liveCompile project(path: ':CNCMediaPlayerSDK', configuration: 'liveRelease')
  1. 添加布局
    在 FrameLayout 布局下添加 CNCVideoViewEx 和 CNCMediaController,用于渲染播放 器的播放界面和控制界面
<FrameLayout
android:id="@+id/video_layout" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@android:color/black">
<com.cnc.mediaplayer.sdk.CNCVideoViewEx android:id="@+id/video_view" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center"/>
<com.cnc.mediaplayer.sdk.controller.CNCMediaController android:id="@+id/media_controller" android:layout_width="match_parent" android:layout_height="match_parent"/>
</FrameLayout>
  1. 修改 AndroidManifest.xml,添加权限:
<uses-permission android:name="android.permission.INTERNET"/> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> <uses-permission android:name="android.permission.WAKE_LOCK"/> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> <uses-permission android:name="android.permission.READ_LOGS" />

修改相应 Activity 的 configChanges:

android:configChanges="keyboardHidden|orientation|screenSize"

修改相应 Activity 的 screenOrientation 锁定竖屏,避免 Android 系统自带的自动翻转:

android:screenOrientation="portrait"

SDK使用

  1. 在初始化播放器之前需对 SDK 进行鉴权,SDK 内部会检查鉴权结果,请求鉴
    权的接口为:
void requestAuth(Context context, String appId, String authKey, ValidListener listener);

理论上一个自然日内只会发起一次网络鉴权(可能较耗时),为避免在 SDK 内部发起网络 鉴权请求,建议在 app 启动时调用:

CNCMediaPlayerAuthentication.requestAuth(getApplicationContext(), mAuthAppId, mAuthKey, null);
 void requestAuth(Context context, String appId, String authKey, ValidListener listener);
  1. 初始化播放器,对播放器做初始化配置(请参考 SinglePlayerFragment 类的 initSDKSettings)
//首先获取配置参数,避免作用到当前播放
Bundle bundle = getArguments();
//获取播放 url
mUrl = bundle.getString(Constants.URL);
//获取配置类对象
mSDKSettings = new CNCSDKSettings();
//初始化配置
initSDKSettings(mSDKSettings, bundle);
  1. 播放和控制界面布局,CNCVideoViewEx 和 CNCMediaController 分别是 SDK 显示布局和控制界面布局。
    首 先 从 activity_cnc_mediaplayer.xml 布 局 文 件 中 获 取 mCNCVideoViewEx 和 mCNCMediaController 两个实例,然后添加全屏变化的监听以在全屏时做 UI 调整。
setContentView(R.layout.activity_cnc_mediaplayer);
mCNCVideoViewEx = (CNCVideoViewEx) findViewById(R.id.video_view); mCNCMediaController = (CNCMediaController) findViewById(R.id.media_controller);
//关联 CNCVideoViewEx 和 CNCMediaController mCNCVideoViewEx.setMediaController(mCNCMediaController);
//全屏变化监听 mCNCVideoViewEx.setOnFullscreenChangeListener(mOnFullscreenChangeListener); //监听视频事件 mCNCVideoViewEx.setOnMediaEventsListener(mMediaEventsListener);
  1. 调用 mCNCVideoViewEx 的方法启动播放器开始播放,调用 mCNCMediaController 的方法设置视频的 title 用于显示在播放器顶部。
mCNCVideoViewEx.play(url);
if (mCNCMediaController != null) {
mCNCMediaController.setTitle(url); }

SDK配置

在初始化完成后,可根据需要对播放器进行配置,否则 SDK 将按照默认配置执行。

//设置是否允许后台播放
mSDKSettings.setEnableBackgroundPlay(bundle.getBoolean(Constants.ENABLE_BAC KGROUND_PLAY));
//设置是否后台时不解码视频以降低 cpu 消耗 mSDKSettings.setDisableDecodeVideoInBackground(bundle.getBoolean(Constants. DISABLE_DECODE_VIDEO_IN_BACKGROUND));
//设置是否使能手势控制
mSDKSettings.setUsingGestureController(bundle.getBoolean(Constants.USING_GE STURE_CONTROLLER));
//设置是否自动旋转 mSDKSettings.setAutoRotate(bundle.getBoolean(Constants.AUTO_ROTATE)); //手势控制时,设置控制亮度和音量的区域 mSDKSettings.setGestureBrightnessVolume(Constants.GESTURE_LEFT_BRIGHTNESS_R IGHT_VOLUME);
//设置是否直播
mSDKSettings.setLive(bundle.getBoolean(Constants.LIVE));
//设置是否使用延时追赶
mSDKSettings.setUsingCatchLiveDelay(bundle.getBoolean(Constants.USING_CATCH _LIVE_DELAY));
//设置是否使用硬件解码视频 mSDKSettings.setUsingMediaCodec(bundle.getBoolean(Constants.USING_MEDIACODE C));
//设置是否使用 OpenSL ES 音频加速
mSDKSettings.setUsingOpenSLES(bundle.getBoolean(Constants.USING_OPENSLES));
//设置触发延时追赶的阈值
mSDKSettings.setCatchLiveDelayTimeInMs(bundle.getInt(Constants.CATCH_LIVE_D ELAY_TIME_IN_MS));
//设置缓冲阈值,默认 0,最小 0,最大 5000 mSDKSettings.setBufferingTimeInMs(bundle.getInt(Constants.BUFFERING_TIME_IN _MS));
//传入鉴权 id
mSDKSettings.setAuthAppId(bundle.getString(Constants.AUTH_APP_ID));
//传入鉴权 key
mSDKSettings.setAuthKey(bundle.getString(Constants.AUTH_KEY));
//设置是否使用分辨率重建
mSDKSettings.setIsSuperRes(bundle.getBoolean(Constants.USING_SUPER_SR));
//设置是否 MP4 解密播放
mSDKSettings.setUsingMp4Encryption(bundle.getBoolean(Constants.USING_MP4_EN CRYPTION));
//设置是否使 hls 解密播放 mSDKSettings.setUsingHls(bundle.getBoolean(Constants.USING_HLS)); mSDKSettings.setHlsVideoId(bundle.getString(Constants.HLS_VIDEO_ID));

混淆配置

混淆时,注意添加以下代码:

-keep class cnc.cad.validsdk.** { *;
}
-keep class com.cnc.mediaplayer.sdk.lib.** {
*; }
-keep class tv.danmaku.ijk.media.player.** { *;
}

如果使用到 CNCMediaPlayerSDK 包,添加以下这行

 -keep class com.cnc.mediaplayer.sdk.**{ *;
}

SDK 其他功能

详见随 SDK 一起提供的使用说明文档和 API 接口文档。