腾讯云云点播集成指引_音视频解决方案_同尘科技

云点播 2年前 (2023-09-04) 浏览 192

本文主要介绍如何快速地将腾讯云视立方·播放器SDK集成到您的项目中,不同版本的 SDK 集成方式都通用,按照如下步骤进行配置,就可以完成 SDK 的集成工作。

开发环境要求

Android Studio 2.0+。Android 4.1(SDK API 16)及以上系统。

集成 SDK(aar)

您可以选择使用 Gradle 自动加载的方式,或者手动下载 aar 再将其导入到您当前的工程项目中。

方法一:自动加载(aar)

播放器 SDK 已经发布到 mavenCentral 库(播放高级版本 mavenCentral 库),您可以通过在 gradle 配置 mavenCentral 库,自动下载更新 LiteAVSDK_Player。
只需要用 Android Studio 打开需要集成 SDK 的工程,然后通过简单的四个步骤修改 build.gradle 文件,就可以完成 SDK 集成:
1. 打开工程根目录下的 build.gradle,添加mavenCentral库。

repositories { mavenCentral()}

2. 打开 app 下的 build.gradle,在 dependencies 中添加 LiteAVSDK_Player 的依赖。

dependencies {  // 此配置默认集成 LiteAVSDK_Player 最新版本 implementation 'com.tencent.liteav:LiteAVSDK_Player:latest.release'  // 集成历史版,如:10.7.0.13038 版本,可通过下面方式集成  // implementation 'com.tencent.liteav:LiteAVSDK_Player:10.7.0.13038'}

如果您需要集成播放高级版本(Premium)SDK,在 dependencies 中添加如下依赖:

 dependencies {  // 此配置默认集成 LiteAVSDK_Player_Premium 最新版本 implementation 'com.tencent.liteav:LiteAVSDK_Player_Premium:latest.release'  // 集成历史版,如:10.7.0.13038 版本,可通过下面方式集成  // implementation 'com.tencent.liteav:LiteAVSDK_Player_Premium:10.7.0.13038'}

3. 在 defaultConfig 中,指定 App 使用的 CPU 架构(目前 LiteAVSDK_Player 支持 armeabi 、 armeabi-v7a 和 arm64-v8a)。

defaultConfig { ndk {     abiFilters "armeabi", "armeabi-v7a", "arm64-v8a" }}

4. 单击 Sync Now 按钮同步 SDK,如果您的网络连接 mavenCentral 没有问题,很快 SDK 就会自动下载集成到工程里。

方法二:手动下载(aar)

如果您的网络连接 mavenCentral 有问题,也可以手动下载 SDK 集成到工程里:1. 下载 LiteAVSDK_Player ,下载完成后进行解压。如果您需要集成播放高级版本(Premium)SDK,请 单击此处 下载。2. 将下载文件解压之后 SDK 目录下的 aar 文件拷贝到工程的 app/libs 目录下:
3. 在工程根目录下的 build.gradle 中,添加 flatDir,指定本地仓库路径。
4. 添加 LiteAVSDK_Player 依赖,在 app/build.gradle 中,添加引用 aar 包的代码。


implementation(name:'LiteAVSDK_Player_10.7.0.13038', ext:'aar')

5. 在 app/build.gradle 的 defaultConfig 中,指定 App 使用的 CPU 架构(目前 LiteAVSDK_Player 支持 armeabi 、armeabi-v7a 和 arm64-v8a)。

defaultConfig { ndk {     abiFilters "armeabi", "armeabi-v7a", "arm64-v8a" }}

6. 单击 Sync Now 按钮同步 SDK,完成 LiteAVSDK 的集成工作。

集成 SDK(jar)

如果您不想集成 aar 库,也可以通过导入 jar 和 so 库的方式集成 LiteAVSDK:1. 下载 LiteAVSDK_Player ,下载完成后进行解压。在 SDK 目录下找到 LiteAVSDK_Player_xxx.zip(其中 xxx 为 LiteAVSDK 的版本号),解压后得到 libs 目录,里面主要包含 jar 文件和 so 文件夹,文件清单如下:
如果您还需要 armeabi 架构 so,复制一份 armeabi-v7a 目录,重命名为 armeabi 即可。如果您需要集成播放高级版本(Premium)SDK,请 单击此处 下载。 2. 将解压得到的 jar文件和 armeabi、armeabi-v7a、arm64-v8a 文件夹拷贝到 app/libs 目录下。
3. 在 app/build.gradle 中,添加引用 jar 库的代码。


dependencies{ implementation fileTree(dir:'libs',include:['*.jar'])}

4. 在工程根目录下的 build.gradle 中,添加 flatDir,指定本地仓库路径。
5. 在 app/build.gradle 中,添加引用 so 库的代码。
6. 在 app/build.gradle 的 defaultConfig 中,指定 App 使用的 CPU 架构(目前 LiteAVSDK 支持 armeabi、armeabi-v7a 和 arm64-v8a)。

defaultConfig { ndk {     abiFilters "armeabi", "armeabi-v7a", "arm64-v8a" }}

7. 单击 Sync Now 按钮同步 SDK,完成 LiteAVSDK 的集成工作。

配置 App 打包参数

注意:如果之前没有使用过9.4以及更早版本的 SDK 的 下载缓存功能(TXVodDownloadManager 中的相关接口),并且不需要在9.5及后续 SDK 版本播放9.4及之前缓存的下载文件,可以不需要该功能的 so 文件,达到减少安装包的体积。例如:在9.4及之前版本使用了 TXVodDownloadManager 类的 setDownloadPath 和 startDownloadUrl 函数下载了相应的缓存文件,并且应用内存储了 TXVodDownloadManager 回调的 getPlayPath 路径用于后续播放,这时候需要 libijkhlscache-master.so 播放该 getPlayPath 路径文件,否则不需要。可以在 app/build.gradle 中添加:

// 新客户集成 SDK 建议把下面的脚本加上,可以优化包体积packagingOptions {    exclude "lib/armeabi/libijkhlscache-master.so"    exclude "lib/armeabi-v7a/libijkhlscache-master.so"    exclude "lib/arm64-v8a/libijkhlscache-master.so"}

配置 App 权限

在 AndroidManifest.xml 中配置 App 的权限,LiteAVSDK 需要以下权限:

网络安全配置允许 App 发送 http 请求出于安全考虑,从 Android P 开始,Google 要求 App 的请求都使用加密链接。播放器 SDK 会启动一个 localsever 代理 http 请求,如果您的应用 targetSdkVersion 大于或等于28,可以通过 网络安全配置 来开启允许向127.0.0.1发送 http 请求。 否则播放时将出现 “java.io.IOException: Cleartext HTTP traffic to 127.0.0.1 not permitted” 错误, 导致无法播放视频。配置步骤如下:1. 在项目新建 res/xml/network_security_config.xml 文件,设置网络安全性配置。

            127.0.0.1    

2. 在 AndroidManifest.xml 文件下的 application 标签增加以下属性。

                        ... >        ...    

设置混淆规则

在 proguard-rules.pro 文件中,将 LiteAVSDK 相关类加入不混淆名单:

-keep class com.tencent.** { *; }

配置 License 授权

单击 License 申请 获取测试用 License,不配置 License 将会播放时视频失败,具体操作请参见 测试版 License。您会获得两个字符串:一个字符串是 licenseURL,另一个字符串是解密 key。在您的 App 调用 SDK 相关功能之前(建议在 Application类中)进行如下设置:

public class MApplication extends Application {
@Override public void onCreate() { super.onCreate(); String licenceURL = ""; // 获取到的 licence url String licenceKey = ""; // 获取到的 licence key TXLiveBase.getInstance().setLicence(this, licenceURL, licenceKey); TXLiveBase.setListener(new TXLiveBaseListener() { @Override public void onLicenceLoaded(int result, String reason) { Log.i(TAG, "onLicenceLoaded: result:" + result + ", reason:" + reason); } }); }}

查看方法

License 设置成功后(需稍等一段时间,具体时间长短依据网络情况而定),您可以通过调用如下方法查看 License 信息:

TXLiveBase.getInstance().getLicenceInfo();

常见问题

项目里面同时集成了直播 SDK/实时音视频/播放器等 LiteAVSDK 系列的多个 SDK 报符号冲突问题怎么解决?

如果集成了2个或以上产品(直播、播放器、TRTC、短视频)的 LiteAVSDK 版本,编译时会出现库冲突问题,因为有些 SDK 底层库有相同符号文件,这里建议只集成一个全功能版 SDK 可以解决,直播、播放器、TRTC、短视频这些都包含在一个 SDK 里面。具体请参见 SDK 下载。

对音视频的解决方案有疑惑?想了解解决方案收费? 联系解决方案专家

腾讯云限时活动1折起,即将结束: 马上收藏

同尘科技为腾讯云授权服务中心,购买腾讯云享受折上折,更有现金返利:同意关联,立享优惠

阿里云解决方案也看看?: 点击对比阿里云的解决方案

- 0人点赞 -

发表点评 (0条)

not found

暂无评论,你要说点什么吗?