Media Element JS - 视频中的剩余时间

时间:2013-06-24 13:23:31

标签: video mediaelement.js

我已使用MediaElement JS将多个视频 - 演示和解释性视频集成到网站的各个页面中。

我们的客户希望视频的剩余时间与视频的currentduration一起显示。 我用google搜索荣耀(字面意思),但无法找到任何解决方案。 任何人都可以指导我把它放在一起。

请帮忙。谢谢:)

1 个答案:

答案 0 :(得分:3)

您可能已经知道,您可以从文档中定义应在mediaelement播放器上显示的功能/插件:

// the order of controls you want on the control bar (and other plugins below)
features: ['playpause','progress','current','duration','tracks','volume','fullscreen'],

现在文档中还不清楚 - 但您也可以为Mediaelement.js添加/实现自己的插件/功能。例如,查看time-feature的源代码 - 这应该为您提供足够的信息来构建您自己的剩余时间插件。您基本上只需复制时间功能代码,并将currenttime替换为您的功能插件名称,例如timeleft,然后插入剩余时间而不是当前时间/持续时间。

以下是如何为mediaelement.js创建所需插件的示例,请注意插件名称前面的“build”前缀:

(function ($) {
    // loop toggle
    MediaElementPlayer.prototype.buildtimeleft = function (player, controls, layers, media) {
        var t = this;

        $('<div class="mejs-time">' +
            '<span class="mejs-timeLeft">&#45;' + // use &minus; for a wider sign
            (t.options.duration > 0 ?
                mejs.Utility.secondsToTimeCode(t.options.duration, t.options.alwaysShowHours || t.media.duration > 3600, t.options.showTimecodeFrameCount, t.options.framesPerSecond || 25) :
                ((player.options.alwaysShowHours ? '00:' : '') + (player.options.showTimecodeFrameCount ? '00:00:00' : '00:00'))
                ) +
            '</span>' +
            '</div>')
            // append it to the toolbar
            .appendTo(controls);

        //attach element we want to update to t (this) for easier access
        t.timeLeft = t.controls.find('.mejs-timeLeft');

        // add a timeupdate event
        media.addEventListener('timeupdate', function () {
            if (t.timeLeft && t.media.duration) {
                //replace with whatever time you want to insert here
                t.timeLeft.html('&#45;' + mejs.Utility.secondsToTimeCode(t.media.duration - t.media.currentTime, t.options.alwaysShowHours || t.media.duration > 3600, t.options.showTimecodeFrameCount, t.options.framesPerSecond || 25));
            }
        }, false);
    }
})(jQuery);

最后记得在您创建的mediaelement实例中将您的功能/插件添加到features:参数:

$('video').mediaelementplayer({
   features: ['playpause','progress','current','duration','timeleft','tracks','volume','fullscreen']
});

您还可以在此处查看如何从文档中添加循环按钮的示例: http://mediaelementjs.com/examples/?name=loop