七牛云-开源的播放器 sdk
一。项目中安装
https://sdk-release.qnsdk.com/qiniu-web-player-1.2.3.js
<script charset="utf-8" type="text/javascript" src="https://sdk-release.qnsdk.com/qiniu-web-player-1.2.3.js"></script>引到项目中即可
二。展示demo
html 部分
<div id="player" style="width: 640px; height: 480px;"> </div>
javescript 部分
window.onload = function () {
loadPlay()
}
function loadPlay() { const url = "http://vfx.mtime.cn/Video/2019/02/04/mp4/190204084208765161.mp4"
player = new QPlayer({
url: url,
container: document.getElementById("player"),
})
player.on("ready", handleReady);
}
此时可以展示出基础画面
三。增加进度条上的视频帧缩略图
先以固定图片作为代替。
javascript
const imgbase64 = ""
function getVideoImage(e, time) { // time 是当前鼠标悬浮的时间点。秒
const jindutiao = document.getElementsByClassName('qplayer-timetooltip')[0]
const imgBase = imgbase64
var thubImg = document.getElementById("thubImg");
if(thubImg) {
thubImg.remove();
}
var img = new Image()
img.src = imgBase
img.id = "thubImg"
img.className = "thubImg"
img.style.top = "-80px"
jindutiao.appendChild(img)
}
css
<style>
[data-balloon]:hover > .thubImg{
opacity: 1 !important;
pointer-events: auto;
transform: translate(-50%, 0);
}
.thubImg {
content: attr(data-balloon);
bottom: 100%;
left: 50%;
margin-bottom: 11px;
-webkit-transform: translate(-50%, 10px);
transform: translate(-50%, 10px);
-webkit-transform-origin: top;
transform-origin: top;
opacity: 0;
pointer-events: none;
transition: all 0.1s ease-out 0.1s;
position: absolute;
z-index: 1;
width: 134px;
height: 76px;
}
</style>
将七牛云sdk,下载到本地。进行修改源码
搜索 handleHoverTooltips 。增加一下代码
// *** 当鼠标移动到进度条时 getVideoImage(e, $o(t))

此时效果已经有了缩略图。

四。根据时间获取视频帧的缩略图
C# 通用,利用插件ffmpeg.exe
#region 生成视频缩略图
[HttpGet("GenThupImage")]
public QueryResultModel GenThupImage(int index)
{
QueryResultModel returnValue = new QueryResultModel();
try
{
// 基本文件路径
string url = @"E:\300.research\Web_Vue_Components\demo_Video_qiniu\tool\";
string videoName = "test";
string base64 = "";
string DirectoryPath = videoName + @"thubDir\";
// 判断是否有帧数图片文件夹
if (!Directory.Exists(url + DirectoryPath))
{
Directory.CreateDirectory(url + DirectoryPath);
}
//判断是否有当前秒数的图片
string ImagePath = url + DirectoryPath + index+"_test" + ".jpg";//为生成的缩略图所在的路径
if (System.IO.File.Exists(ImagePath)) // 该帧图片存在时
{
base64 = getImgBase64(ImagePath);
}
else
{ // 该帧图片不存在时
string ffmpegPath = url + "ffmpeg.exe";//为ffmpeg的全路径
string oriVideoPath = url + videoName+".mp4";//为视频的全路径
int frameIndex = index;//为帧处在的秒数
int thubWidth = 96;//为缩略图的宽度
int thubHeight = 54; //为缩略图的高度
string command = string.Format("\"{0}\" -i \"{1}\" -ss {2} -vframes 1 -r 1 -ac 1 -ab 2 -s {3}*{4} -f image2 \"{5}\"", ffmpegPath, oriVideoPath, frameIndex, thubWidth, thubHeight, ImagePath);
base64 = Execute(command, ImagePath);
}
returnValue.Data = base64;
return returnValue;
}
catch (Exception ex)
{
returnValue.Code = QueryActionResult.ServerError;
returnValue.Message = ex.Message;
return returnValue;
}
}
/// <summary>
/// 调用cmd命令
/// </summary>
/// <param name="str"></param>
private string Execute(string str, string ImagePath)
{
System.Diagnostics.Process p = new System.Diagnostics.Process();
p.StartInfo.FileName = "cmd.exe";
p.StartInfo.UseShellExecute = false; //是否使用操作系统shell启动
p.StartInfo.RedirectStandardInput = true;//接受来自调用程序的输入信息
p.StartInfo.RedirectStandardOutput = true;//由调用程序获取输出信息
p.StartInfo.RedirectStandardError = true;//重定向标准错误输出
p.StartInfo.CreateNoWindow = true;//不显示程序窗口
p.Start();//启动程序
//向cmd窗口发送输入信息
p.StandardInput.WriteLine(str + "&exit");
p.StandardInput.AutoFlush = true;
//获取cmd窗口的输出信息
string output = p.StandardOutput.ReadToEnd();
p.WaitForExit();//等待程序执行完退出进程
p.Close();
return getImgBase64(ImagePath);
}
public string getImgBase64(string imgPath)
{
Bitmap bmp = new Bitmap(imgPath);
MemoryStream ms = new MemoryStream();
bmp.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
byte[] arr = new byte[ms.Length];
ms.Position = 0;
ms.Read(arr, 0, (int)ms.Length);
ms.Close();
return Convert.ToBase64String(arr);
}
#endregion
testthubDir 是帧图片保存文件夹
ffmpeg.exe 是取帧缩略图的插件
test.mp4 是源视频

文件夹中的内容。

此时可以根据接口,传递当前时间,返回当前的缩略图。
此时只是第一步。刚写到这里。
接下来打算按照b站的思路。
把一个视频分成5段。
然后截出500张图。
然后拼成5个雪碧图。
最多5个请求即可返回所有的缩略图,然后进行展示,就可以达到你想要到效果,此段代码根据使用场景自行修改,便不发了。
getVideoImage方法中,的参数 time 是指当前鼠标悬浮的秒数。
来源:https://www.cnblogs.com/yasoPeng/p/12190488.html