头图

本项目由 RTE 开发者社区 x 小红书 联合运营

播放器最初出现在 19 世纪,当时主要用于播放音频,例如通过留声机播放唱片。

随着技术的进步,音频播放器不断改进,品质越来越好,体积也越来越小。到了今天,通过手机或网络,人们可以随时随地播放音频和视频。

优秀的播放器有几个特性:需要提供强大、可扩展的功能,流畅的播放效果,顺畅的用户体验,兼容主流平台,资源占用小,安全性高。而市面上大多数播放器在兼容性、功能、性能、可定制性等方面还有一定的优化空间,这也是很多开发者/公司选择自主开发播放器的原因之一。

基于此,小红书自主研发了一款跨平台播放器 —— REDPlayer。不同于行业其他播放器,REDPlayer 具有结构简单、耦合度低、功能边界清晰等特点,提供了多种接入方式,技术人员可根据需要灵活选择,既可快速集成 SDK 使用,也可基于源码进行定制开发。

REDPlayer 开源地址:https://github.com/RTE-Dev/REDPlayer

划重点:Android、iOS、HarmonyOS 等平台统统支持!如 HLS、MP4、FLV 等多种协议和格式也都支持~

关于 REDPlayer

REDPlayer 的宗旨是让开发者可以快速清晰的了解播放器的基本构造,并可根据个人需求进行简单扩展,满足不同用户的多样需求,可作为学生学习的基础工具,也可作为企业的商用平台。


(REDPlayer 架构图)

REDPlayer 支持点播、直播场景下的多种协议和格式(如 HLS、MP4、FLV 等),并可二次扩展更多协议(如 RTC 等)。每个模块均是解耦的,开发者可以根据需要挂载自定义模块,如自研解码器、渲染器等。

添加小助手微信,备注 REDPlayer 进群
和作者交流工具使用与开发的日常

功能亮点

在过去,由于代码质量、文档等问题,播放器的二次开发和定制化很困难。REDPlayer 兼容多平台,开发者现在可以直接集成 REDPlayer,提高开发效率,节省开发时间,让大家更加专注于业务逻辑的开发。此外,REDPlayer 架构清晰、扩展性好,这为二次开发提供了便利,可以根据实际业务需要定制播放器的功能,提升用户体验。

功能支持全面,降低开发成本:

  • REDPlayer 同时支持多端(如:Android、iOS、HarmonyOS等)点播、直播下的多种协议和格式(如:HLS、MP4、FLV 等);
  • 支持预载、边下边播等功能,减少等待时间,提升播放流畅性,给用户更好的观看体验;
  • 选择性支持 HDR、超分等能力;

便利的二次开发:

  • 架构清晰、结构简单,各模块耦合度低且可插拔、拓展性较好,能满足不同包体积要求下的业务使用;

低成本:

  • 内存占用较小、接入成本较低,可同时满足不同的场景使用(如:课堂学习、企业商用等);

用户自主性高:

  • 可选择直接根据 Interface 快速接入 SDK 使用、也可以选择基于 REDPlayer 代码做二次开发。开发者们可以根据自身需要选择。



目前 REDPlayer 开源的功能支持用于创建更复杂的场景,例如在播放一个视频的过程中,用户可以通过拖动进度条进行实时预览,或在观看过程中同时输入文字形成弹幕等,以丰富整个互动场景的体验。甚至,可以通过 REDPlayer,实现将抠图后的人像与视频画面共享叠加在一起的新视频画面。

REDPlayer 集成与使用

那么如何开始集成 REDPlayer 呢?REDPlayer 支持两种形式的接入方式,即直接 SDK 接入和代码接入,下面将针对这两种方式进行一一说明。

1、直接 SDK 接入

REDPlayer 既支持单一 URL 的输入,也支持多 URL 的方式(JSON 方式)输入,使用者可根据自己的需求灵活选择。

具体步骤如下:

步骤 1:

IMediaPlayer mMediaPlayer = new RedMediaPlayer(); //创建播放器、初始化

步骤 2:

mMediaPlayer.setDataSource(mAppContext, url); //设置url

步骤 3:

mMediaPlayer.setEnableMediaCodec(true); //配置播放参数 mMediaPlayer.setVideoCacheDir(cacheDir);
mMediaPlayer.setLoop(true);
...

步骤 4:

mMediaPlayer.prepareAsync(); //prepare

步骤 5:

mMediaPlayer.start(); //开始播放,prepared状态后调用
至此,视频已经正常播起来了,接下来用户可以根据需要调用不同的接口(具体可见 INTERFACE 介绍)获取对应的信息或做对应的动作,如:
void pause(); //暂停播放
void stop(); //停止播放
void reset(); //重置播放
void release(); //退出播放
long getCurrentPosition(); //获取播放位置
long getDuration(); //获取视频时长
float getSpeed(); //获取播放速度

2、C++ 代码接入

该模块可基于上述架构图中介绍,用户选择性地接入或替换,在此暂不做详细说明,具体可见开源工程(https://github.com/RTE-Dev/RedPlayer)。

💪写在最后

相信长期的价值,REDPlayer 将采取分步开源、逐渐演进的方式落地。因此,我们在 2024 年 1 月进行了第一波代码的开源:1、播放中间层代码开源(含:实例管理、接口调用等),2、REDPlayer 以 SDK 的形式开源。

未来,REDPlayer 也将持续维护迭代。二期,我们将陆续引入 OpenCore 核心模块的自定义开发和支持鸿蒙系统设备应用等功能,开源 OpenCore 模块代码、鸿蒙版块,进一步提升 REDPlayer 相关能力和开发者体验。

REDPlayer 开源地址:https://github.com/RTE-Dev/REDPlayer

3 月 7 日晚间的 Dev Talk 直播中, 我们邀请了三位深耕音视频领域及播放器的大佬,大家可以来与 REDPlayer 的作者一起交流互动哦!


添加小助手微信,备注 REDPlayer 进群
和作者交流工具使用与开发的日常


RTE开发者社区
647 声望966 粉丝

RTE 开发者社区是聚焦实时互动领域的中立开发者社区。不止于纯粹的技术交流,我们相信开发者具备更加丰盈的个体价值。行业发展变革、开发者职涯发展、技术创业创新资源,我们将陪跑开发者,共享、共建、共成长。