Skip to content

Simple mplayer (http://www.mplayerhq.hu/) wrapper for use in node written in Typescript and presenting a promise-heavy API

License

Notifications You must be signed in to change notification settings

jskalama/mplayer-as-promised

 
 

Repository files navigation

mplayer-as-promised

Simple mplayer (http://www.mplayerhq.hu/) wrapper for use in node written in Typescript and presenting a promise-heavy API. The library currently is geared towards audio playback applications.

Usage

Import the module and create an instance of the MPlayer object

import { MPlayer, MPlayerMediaItem } from 'mplayer-as-promised'

const mplayer = new MPlayer();

Open a file for playback (playback starts when the file is opened)

let item: MPlayerMediaItem;
mplayer.openFile('/path/to/file.wav').then((value) => {
  console.log('Playing!');
  item = value;
});

Pause a playing item

item.pause().then(() => {
  console.log('Paused!');
});

Play a paused item

item.play().then(() => {
  console.log('Playing again!');
});

Stop an item (the item cannot be replayed - openFile() must be called again)

item.stop().then(() => {
  console.log('Stopped!');
});

Listen to an item (resolves when the item is complete or stop() has been called)

item.listen().then(() => {
  console.log('Finished!');
});

Seek to a specific time in an item (in seconds)

item.seekTo(120).then(() => {
  console.log('At the 2 minute mark!');
});

Seek by an offset from the current position (in seconds)

item.seekBy(-20).then(() => {
  console.log('Went back 20 seconds!');
});

Get the current position in the track in seconds

item.getCurrentTime().then((time) => {
  console.log(`Currently at ${time} seconds`);
});

Get the current position in the track as a percentage

item.getCurrentPercent().then((percent) => {
  console.log(`Currently at ${percent} %`);
});

Shutdown mplayer

mplayer.shutdown().then(() => {
  console.log('Shutdown!');
});

About

Simple mplayer (http://www.mplayerhq.hu/) wrapper for use in node written in Typescript and presenting a promise-heavy API

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 99.5%
  • JavaScript 0.5%