Skip to content

zhydaxq/h5player

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

HTML5 Player

Bower NPM License Downloads

Installation

$ bower install h5player

Usage

var player = new Player({
  container: document.getElementById('player'),
  image: 'http://example.com/path/to/default/image',
  lyricCallback: function (song, cb) {
    var lyric = getLyricFromSomewhereElse(song);
    cb(lyric);
  },
});
player.setSongs([
  {
    name: 'Song1',
    url: 'http://example.com/path/to/song1.mp3',
    additionalInfo: 'whatever',
  }, {
    name: 'Song2',
    url: 'http://example.com/path/to/song2.mp3',
  }
]);
player.play(0);

Document

  1. Load h5player
  • Via global

    <script src="dist/player.js"></script>
    <script>
    var Player = window.h5player.Player;
    </script>
  • Via CMD

    var Player = require('h5player').Player;
  1. Each player is built with new Player(options). options is an object with properties below:

    • container: required DOM
      Reference to a DOM element to hold the player panel.

    • theme: optional string
      Currently there are two themes available: simple and normal. The default value is normal.

    • image: optional string or object
      Image shown when no image is assigned for the current song.
      It can be a string of the path to the image or an object with theme names as the keys and image paths as the values.
      The recommended image size for normal theme is 130 * 130, and 34 * 34 for simple theme.

    • classes: optional object
      A dict with custom classes of each button, the default values are:

      classes: {
        list: 'fa fa-list',
        prev: 'fa fa-step-forward',
        play: 'fa fa-play',
        next: 'fa fa-step-forward',
        pause: 'fa fa-pause',
      }

      Notice: the default values require Font-Awesome.

    • lyricCallback: optional function
      An async function to get the lyric. There are two parameters for the callback. The first parameter is the song object and the second is a callback to send the lyric to the player.

    The Player object has following methods:

    • setSongs(Array songs)
      Set playlist for the player, songs is a list of objects with properties below:

      • name: required string
        The name of the song.
      • url: required string
        A downloadable URL.
      • artist: optional string
        The name of the artist.
      • duration: optional integer
        Length of the song in seconds.
      • image: optional string or object
        The image for the current song. Similar to the default image in common settings.
      • lyric: optional string
        Lyric of the song. May be something like [00:00]foo\n[00:05]bar\n....
    • play(int index)
      Start playing the index-th song.

    When the play status is changed, a PlayerEvent will be fired with its detail set to an object with following attributes:

    • player
      The Player object that is related to this event

    • type
      'play' or 'pause'

Demos

Snapshots

Normal theme:

snapshot

Simple theme: (multiple players)

snapshot

Packages

No packages published

Languages

  • JavaScript 82.6%
  • CSS 17.4%