分享一个开源免费、功能强大的视频播放器库

这是「进击的Coder」的第 571 篇技术分享

作者:崔庆才

最近在开发一个前端项目,用到播放视频的功能,所以就查了下有什么前端的视频播放器库可以使用,今天来分享一下给大家。

这个库的名字叫做 Plyr,顾名思义其实就是 Player 的缩写,整体的预览效果如下:

408218c06a87c3ca8adcee4760a1b07e.png

官方网站:https://plyr.io/

GitHub 地址是:https://github.com/sampotts/plyr

看来一圈,发现这个库不仅美观优雅,而且功能十分丰富。

下面我们来介绍下它的一些内置功能。

总体概览

首先我们来看看它都支持什么功能,我们可以打开它的官方 Demo 网站,可以直接播放一个视频查看效果,如图所示:

f41325ce15274a48cff3a886d5c40450.png

整体看起来很不错,比浏览器自带的原生播放器看起来好看多了,各种控制条的 UI 都挺好看的。

接着我们来看看有什么功能。

进度条和音量控制就不说了。

接着看看右边还有什么,第一个是字幕控制:

8052caf9f90e39d53bf08abe6755ed78.png

这里可以通过点击来开启或者关闭字幕,也就是说,这个播放器是支持我们嵌入字幕文件的。

同时还支持很多设置,比如分辨率控制、播放速度控制:

edfd4eb018e4c2be3aec908afa440372.png

其中播放速度控制还支持各种自定义速度,比如 1.25 倍、4 倍等等:

f5cf424e11e3ded4aedd94c8b94c0661.png

另外还支持视频画中画模式播放,只需要点击那个弹出按钮即可:

7ae30630e67c0e7e19f3b870d026cacf.png

整体看来,这个官网的 Demo 就足以让我心动选择它了!

详细功能

但功能肯定不止这些,接下来我们再回到 GitHub 主页看看它的介绍,它的介绍如下:

  • 📼 HTML 视频和音频、YouTube 和 Vimeo - 支持主要格式

  • 💪 无障碍- 完全支持 VTT 字幕和屏幕阅读器

  • 🔧 可定制- 我们可以自定义各种选项来让播放器呈现不同的 UI。

  • 😎 干净的 HTML - 使用正确的元素,比如<input type="range"> 控制音量和使用<progress>控制进度。

  • 📱 响应式- 适用于任何屏幕尺寸

  • 💵 获利- 从您的视频中赚钱

  • 📹 流式传输- 支持 hls.js、Shaka 和 dash.js 流式播放

  • 🎛 API - 通过标准化 API 切换播放、音量、搜索等

  • 🎤 事件- 不用搞乱 Vimeo 和 YouTube API,所有事件都是跨格式标准化的

  • 🔎 全屏- 支持原生全屏并回退到“全窗口”模式

  • ⌨️ 快捷键- 支持键盘快捷键

  • 🖥 画中画- 支持画中画模式

  • 📱 Playsinline - 支持playsinline属性

  • 🏎 速度控制- 即时调整速度

  • 📖 多个字幕- 支持多个字幕轨道

  • 🌎 i18n 支持- 支持控件的国际化

  • 👌 预览缩略图- 支持显示预览缩略图

  • 🤟 没有框架- 用“vanilla” ES6 JavaScript 编写,不需要 jQuery

  • 💁‍♀️ SASS - 包含在您的构建过程中

可谓是非常之强大了!

那这个具体怎么使用呢?下面我们再来介绍下。

使用

要使用 Plyr,可以直接引用 Plyr 的 CDN 文件,添加如下引用即可:

<script src="https://cdn.plyr.io/3.6.12/plyr.js"></script>
<link rel="stylesheet" href="https://cdn.plyr.io/3.6.12/plyr.css" />

当然 Plyr 还支持 Node.js 项目直接引用,安装方式如下:

yarn add plyr

然后这样引用即可:

import Plyr from 'plyr';

const player = new Plyr('#player');

Plyr 有一个非常强的功能,那就是它扩展了原生 HTML5 中 Media 相关标签的功能,比如我们现在可以给 video 标签添加一些自定义的功能,比如添加一个 data-poster 属性来当作视频预览封面,比如添加一个 track 标签来添加字幕文件,写法如下:

<video id="player" playsinline controls data-poster="/path/to/poster.jpg">
  <source src="/path/to/video.mp4" type="video/mp4" />
  <source src="/path/to/video.webm" type="video/webm" />

  <!-- Captions are optional -->
  <track kind="captions" label="English captions" src="/path/to/captions.vtt" srclang="en" default />
</video>

同时 Plyr 还支持嵌入一些外链网站,比如 Youtube、Vimeo (如果支持中国的一些视频网站就好了)。

如果要引用 Youtube,那么只需要给 div 添加一些 class 即可,比如:

<div class="plyr__video-embed" id="player">
  <iframe
    src="https://www.youtube.com/embed/bTqVqk7FSmY?origin=https://plyr.io&amp;iv_load_policy=3&amp;modestbranding=1&amp;playsinline=1&amp;showinfo=0&amp;rel=0&amp;enablejsapi=1"
    allowfullscreen
    allowtransparency
    allow="autoplay"
  ></iframe>
</div>

样式自定义

另外 Plyr 还支持我们添加一些自定义样式,我们需要使用 CSS Custom Properties 即可轻松实现样式复写。

比如说,我们想要把默认的按钮颜色由蓝色改成红色,那就可以直接添加 CSS 样式:

:root {
  --plyr-color-main: red
}

这样 Plyr 就可以读取这个 CSS 属性,然后实现样式控制了。

更多的自定义样式名称可以参考:https://github.com/sampotts/plyr#customizing-the-css。

配置自定义

刚才我们还提到了,Plyr 支持我们配置一些 Options 选项来实现一些自定义的功能,这里功能也非常全面,比如:*

  • settings:是一个列表,我们可以控制 settings 的功能列表,比如配置成 ['captions', 'quality', 'speed', 'loop'] 即可控制设置功能里面出现字幕、分辨率、速度、循环播放等控制。

  • i18n:可以控制多语言配置。

  • blankVideo:如果是空的视频的话,默认播放什么。

  • autoplay:是否自动播放。

等等,还有很多,大家可以参考 https://github.com/sampotts/plyr#options 来查看更多功能,总之能想到的几乎都有了。

JavaScript API

另外 Play 还暴露了很多 API,比如 play、pause、stop、restart 等方法可以控制播放、暂停、停止、重新播放等等,甚至还有 airplay 都支持。

具体的功能大家可以参考 https://github.com/sampotts/plyr#methods 查看。

那么就介绍到这里啦,希望对大家有帮助~

c3531847644a96ea6fc978e0a3e49626.png

End

崔庆才的新书《Python3网络爬虫开发实战(第二版)》已经正式上市了!书中详细介绍了零基础用 Python 开发爬虫的各方面知识,同时相比第一版新增了 JavaScript 逆向、Android 逆向、异步爬虫、深度学习、Kubernetes 相关内容,‍同时本书已经获得 Python 之父 Guido 的推荐,目前本书正在七折促销中!

内容介绍:《Python3网络爬虫开发实战(第二版)》内容介绍

720159d33b9717fcfabb8affef101a8f.png

扫码购买

(现在半价促销中,活动很快结束了)

909d75d5780dac5b0085a06c5e6602d6.png

ea1b07b841397e37e097d7ce4ad49256.png

点个在看你最好看

outside_default.png

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是微信小程序视频播放器项目文档的主要内容: 1. 项目概述 本项目是一款基于微信小程序平台的视频播放器应用。用户可以在小程序中观看在线视频和本地视频,并且支持视频缓存和下载等功能。 2. 功能需求 2.1 在线视频播放 用户可以通过搜索或浏览视频列表,选择在线视频进行播放。 2.2 本地视频播放 用户可以在本地视频中选择已经下载的视频进行播放。 2.3 视频缓存和下载 用户可以将在线视频进行缓存和下载,以便在没有网络连接的情况下进行观看。 2.4 播放控制和交互 用户可以通过视频播放控制面板,控制播放进度、音量、播放模式等,同时还可以进行全屏播放分享和评论等操作。 3. 技术实现 3.1 使用开源视频播放 本项目使用了开源的 weui-video 和 wx-video ,它们提供了常用的视频播放功能和接口,包括视频加载、播放、暂停、跳转、全屏等。 3.2 视频缓存和下载 本项目使用了微信小程序提供的 wx.downloadFile 接口实现视频的缓存和下载功能。同时,为了提高用户体验,本项目使用了本地存储技术,将下载的视频保存在用户的手机上,以便在没有网络连接的情况下进行观看。 3.3 播放控制和交互 本项目使用了微信小程序提供的组件和接口,实现了视频播放控制面板的显示和隐藏、全屏播放、音量控制、进度条拖动等操作。同时,本项目还使用了微信小程序提供的评论和分享接口,增加了用户的交互体验。 4. 性能优化 4.1 视频缓存和下载优化 为了提高视频缓存和下载的速度和流畅度,本项目使用了多线程下载技术和断点续传技术,同时还对视频文件进行了压缩和优化。 4.2 界面渲染和响应优化 为了提高用户体验,本项目对界面的渲染和响应速度进行了优化,使用了异步加载和懒加载等技术,减少了用户等待时间和页面卡顿现象。 以上就是微信小程序视频播放器项目文档的主要内容,如果您有其他问题或需要更多指导,请随时向我提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值