zoukankan      html  css  js  c++  java
  • 视频帧数缩略图

      七牛云-开源的播放器 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=" 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.researchWeb_Vue_Componentsdemo_Video_qiniu	ool";
                    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 是指当前鼠标悬浮的秒数。



  • 相关阅读:
    pstree
    gvisor vfs2
    gvisor entersyscall exitsyscall
    gvisor在arm64下syscall.SIGILL信号处理
    SpringBlade 为id添加自增长属性
    SQL Server Update 一个列的数据为随机数
    SpringBlade Saber 关闭验证码
    SpringBlade Saber 用户列表的新增按钮 是怎么个显示原理
    SpringBlade Saber 切换标签页 不刷新
    SpringBlade 00 常见问题汇总
  • 原文地址:https://www.cnblogs.com/yasoPeng/p/12190488.html
Copyright © 2011-2022 走看看