百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

阿里云短视频 SDK For Android 快速接入

liuian 2025-03-25 15:18 24 浏览

摘要: 近期的一些创意短视频 App 风靡年轻群体,比较典型的例如抖音、MUSE 等,阿里云也适时地推出了简单易用的短视频 SDK,帮助开发者们以较低的成本快速引入功能完备的创意短视频功能。本文主要介绍如何快速接入阿里云短视频 SDK 的三个版本(基础版、标准版和专业版)。

前言

近期的一些创意短视频 App 风靡年轻群体,比较典型的例如抖音、MUSE 等,阿里云也适时地推出了简单易用的短视频 SDK,帮助开发者们以较低的成本快速引入功能完备的创意短视频功能。

本文主要介绍如何快速接入阿里云短视频 SDK 的三个版本(基础版、标准版和专业版)。帮助开发者以最快的速度了解接入的基本方式。

本文描述的阿里云短视频 SDK 版本基于 3.4.0,后续升级接口变动请参考 阿里云短视频 SDK 文档。

示例工程代码为 Kotlin,Java 接入类似。

正文

由于三个版本接入方式大同小异,本文将着重介绍基础版接入过程,标准版和专业版可以基于基础版方式接入,后续仅说明接入差异的地方。

基础版接入

1. 引入 aar 以及 so

目前 aar 平台版本最低要求 >= 4.3,先从SDK 下载页面下载相应版本的 SDK,解压之后,将 libs
文件夹下的 QuSdk-RC.aar拷到 Android 工程模块中的 libs文件夹下,将 jniLibs文件夹下的 armeabi-v7a文件夹也整体拷贝到 libs文件夹下。

拷贝完成之后目录的文件如下:

之后按照如下方式修改 Android 项目工程主模块下的 build.gradle文件:

Step1. 修改 jniLibs的源文件夹;

android {
 sourceSets.main {
 jniLibs.srcDir "libs"
 }
}

Step2. 将 libs文件夹加入仓库中;

repositories {
 flatDir {
 dirs 'libs'
 }
}

Step3. 增加 aar 所需依赖。

dependencies {
 implementation(name: 'QuSdk-RC', ext: 'aar')
 implementation 'com.android.support:appcompat-v7:24.2.1'
 implementation 'com.android.support:design:24.2.1'
 implementation 'com.google.code.findbugs:jsr305:3.0.0'
 implementation 'com.github.bumptech.glide:glide:3.7.0'
 implementation 'pub.devrel:easypermissions:0.2.1'
 implementation 'com.squareup.okhttp3:okhttp:3.2.0'
 implementation 'com.github.bumptech.glide:okhttp3-integration:1.4.0@aar'
 implementation 'com.squareup.okio:okio:1.12.0'
 implementation 'com.google.code.gson:gson:2.8.0'
}

如果此处遭遇
java.lang.NoSuchFieldError
错误,可以参考短视频安卓常见问题解决。

2. 初始化 SDK

请根据具体的项目情况选择合适的 SDK 初始化时机,Demo 工程在 Applicatioin 的 onCreate()方法中初始化。

package me.bogerchan.alishortvideodemoimport android.app.Applicationimport com.aliyun.common.httpfinal.QupaiHttpFinal/**
* Created by hb.chen on 2018/1/6.
*/class MyApplication : Application() { override fun onCreate() { super.onCreate()
 System.loadLibrary("QuCore-ThirdParty")
 System.loadLibrary("QuCore")
 QupaiHttpFinal.getInstance().initOkHttpFinal()
 }
}

3. 开始书写你的业务逻辑

经过上述过程,实际上已经接入完成,这时候你可以参考文档直接开始使用各种 API 了,附下示例代码。

package me.bogerchan.alishortvideodemoimport android.Manifestimport android.app.Activityimport android.content.Intentimport android.content.pm.PackageManagerimport android.os.Bundleimport android.support.v4.app.ActivityCompatimport android.support.v7.app.AppCompatActivityimport android.widget.Toastimport com.aliyun.demo.recorder.AliyunVideoRecorderimport com.aliyun.struct.common.VideoQualityimport com.aliyun.struct.snap.AliyunSnapVideoParamimport me.bogerchan.alishortvideodemo.basic.Rclass MainActivity : AppCompatActivity() {
 companion object {
 val REQUEST_CODE_RECORD_VIDEO = 1
 val REQUEST_CODE_FOR_PERMISSION = 2
 } override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState)
 setContentView(R.layout.activity_main)
 findViewById(R.id.btn_start_record).setOnClickListener {
 startRecordActivity()
 }
 ActivityCompat.requestPermissions(this,
 arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE,
 Manifest.permission.READ_EXTERNAL_STORAGE,
 Manifest.permission.CAMERA,
 Manifest.permission.RECORD_AUDIO),
 REQUEST_CODE_FOR_PERMISSION)
 } private fun startRecordActivity() {
 val recordParam = AliyunSnapVideoParam.Builder()
 .setResolutionMode(AliyunSnapVideoParam.RESOLUTION_720P)
 .setRatioMode(AliyunSnapVideoParam.RATIO_MODE_9_16)
 .setRecordMode(AliyunSnapVideoParam.RECORD_MODE_AUTO)
 .setNeedClip(true)
 .setMaxDuration(10000)
 .setMinDuration(2000)
 .setVideQuality(VideoQuality.HD)
 .setSortMode(AliyunSnapVideoParam.SORT_MODE_MERGE)
 .build()
 AliyunVideoRecorder.startRecordForResult(this, REQUEST_CODE_RECORD_VIDEO, recordParam)
 } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { super.onActivityResult(requestCode, resultCode, data)
 when (requestCode) {
 REQUEST_CODE_RECORD_VIDEO -> { if (resultCode == Activity.RESULT_OK && data != null) {
 val type = data.getIntExtra(AliyunVideoRecorder.RESULT_TYPE, 0) if (type == AliyunVideoRecorder.RESULT_TYPE_CROP) {
 Toast.makeText(this, "类型为裁剪", Toast.LENGTH_SHORT).show()
 } else if (type == AliyunVideoRecorder.RESULT_TYPE_RECORD) {
 Toast.makeText(this, "文件路径为 " + data.getStringExtra(AliyunVideoRecorder.OUTPUT_PATH), Toast.LENGTH_SHORT).show()
 }
 } else if (resultCode == Activity.RESULT_CANCELED) {
 Toast.makeText(this, "用户取消录制", Toast.LENGTH_SHORT).show()
 }
 }
 }
 } override fun onRequestPermissionsResult(requestCode: Int, permissions: Array, grantResults: IntArray) { super.onRequestPermissionsResult(requestCode, permissions, grantResults)
 when (requestCode) {
 REQUEST_CODE_FOR_PERMISSION -> {
 grantResults.forEach { if (it == PackageManager.PERMISSION_DENIED) {
 Toast.makeText(this, "没有权限,不玩了", Toast.LENGTH_SHORT).show()
 finish() return@forEach
 }
 }
 }
 }
 }
}

标准版接入

1. 引入 aar 以及 so

标准版相较于基础版,在引入 so 文件时候多了几个文件,同时 aar文件名有所变动。最终拷贝结果如下:

build.gradle文件修改与基础版接入一样,只是需要将接入 aar
文件名替换成标准版对应的名字。

2. 初始化 SDK

相较于基础版,需要加载的 so 增多了几个,其中部分 so 文件作为可选功能根据实际情况决定是否加载,具体可以参阅阿里云短视频 SDK 文档。接入后的 Application 文件参考:

package me.bogerchan.alishortvideodemoimport android.app.Applicationimport com.aliyun.common.httpfinal.QupaiHttpFinal/**
* Created by hb.chen on 2018/1/6.
*/class MyApplication : Application() { override fun onCreate() { super.onCreate()
 System.loadLibrary("aliresample")
 System.loadLibrary("live-openh264")
 System.loadLibrary("QuCore-ThirdParty")
 System.loadLibrary("QuCore")
 QupaiHttpFinal.getInstance().initOkHttpFinal()
 }
}

3. 开始书写你的业务逻辑

经过上述过程,实际上已经接入完成,这时候你可以参考文档直接开始使用各种 API 了,附下示例代码。

package me.bogerchan.alishortvideodemoimport android.Manifestimport android.content.pm.PackageManagerimport android.opengl.GLSurfaceViewimport android.os.Bundleimport android.support.v4.app.ActivityCompatimport android.support.v7.app.AppCompatActivityimport android.widget.Toastimport com.aliyun.recorder.AliyunRecorderCreatorimport com.aliyun.struct.recorder.CameraTypeimport com.aliyun.struct.recorder.MediaInfoimport me.bogerchan.alishortvideodemo.std.Rclass MainActivity : AppCompatActivity() {
 companion object {
 val REQUEST_CODE_FOR_PERMISSION = 1
 } private val mRecorder by lazy {
 AliyunRecorderCreator.getRecorderInstance(this)
 } private var mCameraType = CameraType.FRONT
 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState)
 setContentView(R.layout.activity_main)
 ActivityCompat.requestPermissions(this,
 arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE,
 Manifest.permission.READ_EXTERNAL_STORAGE,
 Manifest.permission.CAMERA,
 Manifest.permission.RECORD_AUDIO),
 REQUEST_CODE_FOR_PERMISSION)
 initAliyunRecorder()
 findViewById(R.id.btn_start_record).setOnClickListener {
 Toast.makeText(this, "开始录制片段", Toast.LENGTH_SHORT).show()
 mRecorder.startRecording()
 }
 findViewById(R.id.btn_stop_record).setOnClickListener {
 Toast.makeText(this, "停止录制片段", Toast.LENGTH_SHORT).show()
 mRecorder.stopRecording()
 }
 findViewById(R.id.btn_finish_record).setOnClickListener {
 Toast.makeText(this, "结束录制", Toast.LENGTH_SHORT).show()
 mRecorder.finishRecording()
 }
 findViewById(R.id.btn_change_camera_type).setOnClickListener {
 Toast.makeText(this, "切换前后置", Toast.LENGTH_SHORT).show()
 mRecorder.switchCamera()
 }
 } override fun onStart() { super.onStart()
 mRecorder.startPreview()
 } override fun onPause() { super.onPause()
 mRecorder.stopPreview()
 } override fun onDestroy() { super.onDestroy()
 AliyunRecorderCreator.destroyRecorderInstance()
 } private fun initAliyunRecorder() {
 mRecorder.setDisplayView(findViewById(R.id.glsv_content) as GLSurfaceView)
 val mediaInfo = MediaInfo()
 mediaInfo.videoWidth = 800
 mediaInfo.videoHeight = 1200
 mediaInfo.isHWAutoSize = true
 mRecorder.setMediaInfo(mediaInfo)
 mRecorder.setCamera(mCameraType)
 mRecorder.setOutputPath(externalCacheDir.absolutePath + "/capture.mp4")
 } override fun onRequestPermissionsResult(requestCode: Int, permissions: Array, grantResults: IntArray) { super.onRequestPermissionsResult(requestCode, permissions, grantResults)
 when (requestCode) {
 REQUEST_CODE_FOR_PERMISSION -> {
 grantResults.forEach { if (it == PackageManager.PERMISSION_DENIED) {
 Toast.makeText(this, "没有权限,不玩了", Toast.LENGTH_SHORT).show()
 finish() return@forEach
 }
 }
 }
 }
 }
}

专业版接入

1. 引入 aar 以及 so

专业版相较于基础版,在引入 so 文件时候多了几个文件,同时 aar文件名有所变动。最终拷贝结果如下:

build.gradle 文件修改与基础版接入一样,只是需要将接入 aar文件名替换成专业版对应的名字。

2. 初始化 SDK

相较于基础版,需要加载的 so 增多了几个,其中部分 so 文件作为可选功能根据实际情况决定是否加载,具体可以参阅阿里云短视频 SDK 文档。接入后的 Application 文件参考:

package me.bogerchan.alishortvideodemoimport android.app.Applicationimport com.aliyun.common.httpfinal.QupaiHttpFinal/**
* Created by hb.chen on 2018/1/6.
*/class MyApplication : Application() { override fun onCreate() { super.onCreate()
 System.loadLibrary("live-openh264")
 System.loadLibrary("QuCore-ThirdParty")
 System.loadLibrary("QuCore")
 System.loadLibrary("FaceAREngine")
 System.loadLibrary("AliFaceAREngine")
 QupaiHttpFinal.getInstance().initOkHttpFinal()
 }
}

3. 开始书写你的业务逻辑

经过上述过程,实际上已经接入完成,这时候你可以参考文档直接开始使用各种 API 了,附下示例代码。

package me.bogerchan.alishortvideodemoimport android.Manifestimport android.content.pm.PackageManagerimport android.opengl.GLSurfaceViewimport android.os.Bundleimport android.support.v4.app.ActivityCompatimport android.support.v7.app.AppCompatActivityimport android.widget.Toastimport com.aliyun.recorder.AliyunRecorderCreatorimport com.aliyun.struct.recorder.CameraTypeimport com.aliyun.struct.recorder.MediaInfoimport me.bogerchan.alishortvideodemo.pro.Rclass MainActivity : AppCompatActivity() {
 companion object {
 val REQUEST_CODE_FOR_PERMISSION = 1
 } private val mRecorder by lazy {
 AliyunRecorderCreator.getRecorderInstance(this)
 } private var mCameraType = CameraType.FRONT
 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState)
 setContentView(R.layout.activity_main)
 ActivityCompat.requestPermissions(this,
 arrayOf(Manifest.permission.WRITE_EXTERNAL_STORAGE,
 Manifest.permission.READ_EXTERNAL_STORAGE,
 Manifest.permission.CAMERA,
 Manifest.permission.RECORD_AUDIO),
 REQUEST_CODE_FOR_PERMISSION)
 initAliyunRecorder()
 findViewById(R.id.btn_start_record).setOnClickListener {
 Toast.makeText(this, "开始录制片段", Toast.LENGTH_SHORT).show()
 mRecorder.startRecording()
 }
 findViewById(R.id.btn_stop_record).setOnClickListener {
 Toast.makeText(this, "停止录制片段", Toast.LENGTH_SHORT).show()
 mRecorder.stopRecording()
 }
 findViewById(R.id.btn_finish_record).setOnClickListener {
 Toast.makeText(this, "结束录制", Toast.LENGTH_SHORT).show()
 mRecorder.finishRecording()
 }
 findViewById(R.id.btn_change_camera_type).setOnClickListener {
 Toast.makeText(this, "切换前后置", Toast.LENGTH_SHORT).show()
 mRecorder.switchCamera()
 }
 } override fun onStart() { super.onStart()
 mRecorder.startPreview()
 } override fun onPause() { super.onPause()
 mRecorder.stopPreview()
 } override fun onDestroy() { super.onDestroy()
 AliyunRecorderCreator.destroyRecorderInstance()
 } private fun initAliyunRecorder() {
 mRecorder.setDisplayView(findViewById(R.id.glsv_content) as GLSurfaceView)
 val mediaInfo = MediaInfo()
 mediaInfo.videoWidth = 800
 mediaInfo.videoHeight = 1200
 mediaInfo.isHWAutoSize = true
 mRecorder.setMediaInfo(mediaInfo)
 mRecorder.setCamera(mCameraType)
 mRecorder.needFaceTrackInternal(true)
 mRecorder.setOutputPath(externalCacheDir.absolutePath + "/capture.mp4")
 } override fun onRequestPermissionsResult(requestCode: Int, permissions: Array, grantResults: IntArray) { super.onRequestPermissionsResult(requestCode, permissions, grantResults)
 when (requestCode) {
 REQUEST_CODE_FOR_PERMISSION -> {
 grantResults.forEach { if (it == PackageManager.PERMISSION_DENIED) {
 Toast.makeText(this, "没有权限,不玩了", Toast.LENGTH_SHORT).show()
 finish() return@forEach
 }
 }
 }
 }
 }
}

结语

至此已经介绍完了阿里云短视频 SDK 的接入方法,示例代码展示的仅仅只是阿里云视频 SDK 强大功能的冰山一角,开发者们可以通过相关的 SDK 文档获取更多的接口信息。如果集成过程中遇到问题,在联系客服之前不妨先看下 常见问题解决,说不定你的问题就在里面。

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...