Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
A browser based HTML5/JS karaoke 'Player', that takes a zip file containing an mp3 and cdg file, allowing the user to render and play directly in the browser.
A browser based HTML5/JS karaoke 'Player', that takes a .zip
rile containing an .mp3
and .cdg
file, allowing the
user to render and play directly in the browser.
CDGPlayer
is written for modern browsers, in ECMAScript 6. You may require Babel to bundle the
player into your application. Code does not support Internet Explorer. (It might work in IE 10 or 11, but I'm not
testing for it.)
The CDGPlayer
requires that JSZip, JSZipUtils
and jsmediatags be included in your html.
<script type="text/javascript" src="my/assets/jszip.min.js"></script>
<script type="text/javascript" src="my/assets/jszip-utils.min.js"></script>
<script type="text/javascript" src="my/assets/jsmediatags.min.js"></script>
To include the player in your application, simply install it via npm:
npm install cdgplayer
The package contains two objects for use in your code. Import the objects that you require directly into your project.
import { CDGPlayer, CDGControls } from 'cdgplayer';
The CDGPlayer
object will handle adding the output 'screen' to a container that you define in your html, and provides
methods for loading a .zip
file from your server.
const player = new CDGPlayer('#cdg_video_wrapper');
To load your karaoke file into the player, the player expects that the file is a .zip
file containing the two
necessary files for CD+G playback: the .mp3
file and it's corresponding .cdg
file. This is the industry standard
today for distributing CD+G files.
Currently loading a file takes a string as a relative path on your server. The player will handle the GET
request
to request the file.
const myFilePath = 'path/on/my/server/to/song.zip';
player.load(myFilePath);
The other methods are really only necessary for anyone not using the CDGControls, which handle all of these function calls automatically. If you want to use a custom control set, these methods are provided for your convenience. If you don't require a custom control set, then I suggest you jump straight to the CDGControls documentation.
Starts the audio and video display
player.start();
Pauses the audio and video display
player.pause();
Stops the audio and video display, and resets the playhead to the beginning of the song
player.stop();
Will start or pause the audio and video display, depending on it's current state
player.togglePlay();
Resets the playhead to the percentage of the song passed in.
player.changePlayerPosition(36);
Changes the song key by semitones (half steps) up or down. Maintains the song tempo regardless.
player.changeKey(-1); // takes it down half a step
Changes the song volume up or down.
player.volume(.5); // takes it up a few steps
player.volume(-.5); // takes it down a few steps
Toggles the "Mute". If volume is greater than 0 it will "Mute" the audio. If already "Mute"d it will put the volume back to it's previous value.
player.toggleMute();
None. Video is loaded with the file, and plays/pauses when the audio plays/pauses. Size of your overall video is controlled by how you size your 'player' container, and will automatically maintain it's aspect ratio of 300:216.
Convenience method to remove all DOM listeners, classes, and elements that had been applied to the DOM.
Note: Calling methods on the instance, after calling destroy()
, will throw many errors.
player.destroy();
There are several properties that are 'observed' in the prayer. It is possible to subscribe to updates of these properties, so that your application can automatically respond to player changes. The 'observed' properties are
These are 'observed' properties, so you can 'listen' for changes.
const onLoadingChange = player.props.on('loading', (val, prev) => {
if (val !== prev) {
// loading changed, so now do something
}
});
Remember to clean up your 'listeners' if you're tearing down your player instance.
player.props.off(onLoadingChange);
player.destroy(); // 'destroy()' doesn't know about **your** listeners, so you have to handle it yourself
The CDGControls
object provides you with a prebuilt, fully configured player interface for controlling the song
loaded into the CDGPlayer
, including base styling. It allows you to start/pause your song, change the playhead
position, and change the key. This makes setting up a fully functional player very easy. Control defaults to 100% of
the width of it's container.
<div class="cdg-player">
<div id="cdg_controls"></div>
<div id="cdg_wrapper"></div>
</div>
import { CDGPlayer, CDGControls } from 'cdgplayer';
const player = new CDGPlayer('#cdg_wrapper');
const controls = new CDGControls('#cdg_controls', player);
// logic to get your songlist and load songs
Options is an optional object. Currently the only option is position
, which defaults to bottom
. If you place the
controls above your player, use postion: 'top'
. This will allow the volume slider to switch positions.
There are no methods, as all control is handled directly from the interface and it's connection to your player.
It's fairly common to want something to display when the player is not yet loaded. We've provided a container, with a transparent background, which will automatically cover the video canvas whenever the player is not 'loaded'. Here you can add your own CSS to include your own title image. Because you want to use something that works at almost any size, we suggest you use a large SVG (maybe 1024x1024). Just remember that your video window's aspect ration is 75:54. Here's an example of your possible CSS.
.titleImage {
background-image: url('./myTitleGraphic.svg');
background-size: 90% 90%;
background-position: center;
background-repeat: no-repeat;
}
The following classes are automatically appended to the head of your document, by the package. If you choose to override the default display, write a css file that is appened to the body of your document.
CDGPlayer
constructorcanvas
(base size is 300px x 216px) + 12px paddingprogress
HTML elementIf you cloned this repository you can easily run the included example.
npm install
& Place a CD+G karaoke .zip
file in the zipfiles
folder.zip
filename into the root index.js
file.npm start
I've done a lot of back-and-forth/trial-and-error on this player over the last year or so. I had a working player
that worked with the HTML audio
element, but it didn't give me the control to change the key (critical for any
real karaoke player). The original player was based on the HTML5 cdg player from CD+Graphics Magic.
I rewrote SoundTouch JS to a distributable SoundTouchJS
package, and included a PitchShifter
component for handling key changes. See that repository for credits there.
The current player is based on, and uses pieces of the karaoke player written by Keith McKnight. He gives some additional credits in that repository too.
I got my observable properties courtesy of proxy-observable by Anton Lapshin.
And I got royalty free play
and pause
font icons courtesy of IcoFont.
FAQs
A browser based HTML5/JS karaoke 'Player', that takes a zip file containing an mp3 and cdg file, allowing the user to render and play directly in the browser.
The npm package cdgplayer receives a total of 6 weekly downloads. As such, cdgplayer popularity was classified as not popular.
We found that cdgplayer demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.