...

воскресенье, 16 августа 2015 г.

jQuery Video Extend — расширение возможностей HTML5 видео плеера

Часто вижу, что владельцы сайтов и разработчики используют видео-плееры вроде VideoJS, Flowplayer, Uppod и т.д., но очень редко вижу стандартные HTML5 плееры на сайтах. Мне это кажется странным, ведь обычные плееры в браузерах тоже выглядят очень симпатично. Что есть у стандартного «браузерного» видео плеера:
  1. Стильный дизайн. Зависит от браузера, но везде на хорошем уровне.
  2. Поддержка самого популярного формата — Mpeg4 (H.264) (Chrome, Firefox, IE, Safari, Opera).
  3. Очень удобное API — http://ift.tt/1fpoLLZ
  4. Быстрая работа и поддержка мобильных устройств.

Почему же такие плееры не популярны? Вот список возможных причин:
  1. Нет простого способа добавить свой логотип.
  2. Нет поддержки FLV видео, которое часто ещё встречается.
  3. Нет возможности ставить метки на видео и создавать свои расширения.
  4. Нет возможности менять внешний вид и стиль плеера.

С последним пунктом сложнее всего, но довольно редко эта возможность используется и на плеерах, о которых я писал в начале. Чаще используется первая стандартная тема оформления. Первые три пункта я решил восполнить, написав jQuery плагин, так появился Video Extend.

Подключение jQuery и плагина:

<script src="js/jquery-2.1.4.min.js"></script>
<script src="js/jquery.video-extend.js"></script>


Плеер с логотипом и маркерами:
<script>
    $(document).bind('ready',function(){
        
        $('#video1').videoExtend({
            logo: 'img/example_logo.png',// картинка логотипа
            logoLink: 'http://example.com/',// ссылка с логотипа
            logoSize: [ 60, 40 ],// размеры логотипа - ширина и высота
            markers: [
                {
                    time: 39,// секунды
                    text: 'Chapter 1'
                },
                {
                    time: 350,
                    text: 'Chapter 2'
                },
                {
                    time: 470,
                    text: 'Chapter 3'
                },
                {
                    time: 677,
                    text: 'Chapter 4'
                }
            ]
        });
        
    });
</script>
<video id="video1" width="640" height="360" poster="video/Sintel_poster.png" controls>
    <source src="video/Sintel.mp4" type="video/mp4">
</video>


Другой способ:
<script>
    $(document).bind('ready',function(){
        $('video').videoExtend();
    });
</script>
<video width="640" height="360" data-logo="img/example_logo.png" data-markers='[{"time":39,"text":"Chapter 1"},{"time":350,"text":"Chapter 2"}]'>
    <source src="video/Sintel.mp4" type="video/mp4">
</video>


Параметры можно задавать через атрибуты с префиксом «data-».

Проигрывание видео с YouTube:

<script>
    $(document).bind('ready',function(){
        
        $('#video2').videoExtend({
            logo: 'img/example_logo.png',
            logoLink: 'http://example.com/',
            logoSize: [ 60, 40 ],
            logoPosition: [ 'auto', 10, 50, 'auto' ] // положение логотипа - сверху, справа, снизу, слева
        });
        
    });
</script>
<video id="video2" width="640" height="360" controls>
    <source src="https://www.youtube.com/watch?v=eRsGyueVLvQ" type="video/youtube">
</video>

Проигрывание FLV видео (только базовая поддержка):

<script>
    $(document).bind('ready',function(){
        
        $('video.video-extend').videoExtend({
            logo: 'img/example_logo.png',
            logoLink: 'http://example.com/',
            logoSize: [ 60, 40 ],
            swfPath: 'swf/video-js.swf',
            textPlay: 'Play movie'
        });
        
    });
</script>
<video class="video-extend" width="640" height="360" poster="video/Sintel_poster.png" controls>
    <source src="video/Sintel.flv" type="video/flv">
</video>


SWF, который воспроизводит FLV видео, взят у VideoJS.

Пример использования API:

$('#video1').get(0).play();// воспроизвести


Буду рад, если кому-то пригодится.

Демо | Краткая документация | Исходный код

This entry passed through the Full-Text RSS service - if this is your content and you're reading it on someone else's site, please read the FAQ at http://ift.tt/jcXqJW.

Комментариев нет:

Отправить комментарий