![](/style/images/good.png)
![](/style/images/bad.png)
Awesome 🎧 Music Player + tutorial
source link: https://dev.to/kerthin/awesome-music-player-g81
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
Introduction
Last week I posted my calculator made in the style of Neomorphism. Today I decided to continue posting my similar works. Therefore, I want to present to you my music player, also made in the style of neomorphism.
Calculator
Music Player
Full Page Demo
Functional
01. Switching tracks
- It is possible to switch your tracks. If you switch a track while playing music, the next track will start by clicking on the "Play" button.
02. Switching tracks
- While the music is playing, the animation of scrolling the image of the song will be started.
03. Rewind the song time
- You can also rewind the song. The song can be rewound manually using the timeline or using the buttons that scroll the song forward or backward for 5 seconds.
04. Random launch of a track
When you click the lower right button, the tracks will start in random order, and not in order as specified in the array.
This only works if the track ended on its own, and you didn't switch it.
05. Repeat an album or track
- If there is a number 1 in the button, it means that the track will be played again at the end (
Repeat
). - If the button is highlighted, but there are no numbers in it, it means that when the last track is played, the album will automatically start playing again from the first track.
- If the button is pale, it means that after playing the last track, the first one will not start.
Responsive
Phone:
The site is adapted for screen resolutions such as:@media 414px
@media 375px
@media 320px
Desktop:
I also decided to adapt the site to different screen heights so that there would be no problems with the display.
You can add your own tracks through the array.
Here it is:
const list = [
{
id: 1,
class: 'jerryHerman',
url: "music/JerryHerman_PutOnYourSundayClothes.mp3",
author: "Jerry Herman",
title: "Put On Your Sunday"
},
{
id: 2,
class: 'elvisPresley',
url: "music/ElvisPresley_CantHelpFallingInLove.mp3",
author: "Elvis Presley",
title: "Can't Falling In Love"
},
{
id: 3,
class: 'royOrbison',
url: "music/RoyOrbison_OhPrettyWoman.mp3",
author: "Roy Orbison",
title: "Oh, Pretty Woman"
},
{
id: 4,
class: 'frankSinatra',
url: "music/FrankSinatra_ThatsLife.mp3",
author: "Frank Sinatra",
title: "That's Life"
},
{
id: 5,
class: 'jimCroce',
url: "music/JimCroce_TimeInABottle.mp3",
author: "Jim Croce",
title: "Time In A Bottle"
},
{
id: 6,
class: 'redHotChiliPeppers',
url: "music/RedHotChiliPeppers_DarkNecessities.mp3",
author: "Red Hot Chili Peppers",
title: "Dark Necessities"
},
{
id: 7,
class: 'stephaneGrappelli',
url: "music/StephaneGrappelli_laMer.mp3",
author: "Stephane Grappelli",
title: "La Mer"
},
{
id: 8,
class: 'evanKing',
url: "music/EvanKing_Overwatch.mp3",
author: "Evan King",
title: "Overwatch"
},
{
id: 9,
class: 'JR',
url: "music/JR_SouthSac.mp3",
author: "JR",
title: "SouthSac"
},
{
id: 10,
class: 'theDeli',
url: "music/TheDeli_Sun.mp3",
author: "The Deli",
title: "Sun"
}
];
It displays information about the track, changes the class for changing the image, and adds the track.
To add an image, you need to create a line in the mixin. The image class must be the same as in the array specified above.
@mixin albumBgMix($albumBgName, $bgPath) {
.#{$albumBgName} {
.album:before {
background-image: url(#{$bgPath});
}
}
}
@include albumBgMix('jerryHerman', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/jerryHerman.jpg');
@include albumBgMix('elvisPresley', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/elvisPresley.jpg');
@include albumBgMix('royOrbison', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/royOrbison.jpg');
@include albumBgMix('frankSinatra', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/frankSinatra.jpg');
@include albumBgMix('jimCroce', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/jimCroce.jpg');
@include albumBgMix('redHotChiliPeppers', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/redHotChiliPeppers.jpg');
@include albumBgMix('stephaneGrappelli', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/stephaneGrappelli.jpg');
@include albumBgMix('evanKing', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/evanKing.jpg');
@include albumBgMix('JR', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/JR.jpg');
@include albumBgMix('theDeli', 'https://rawcdn.githack.com/Kerthin/musicPlayer-templateSait/4df6444e97123a39d036f1f9b57973858f70bae5/docs/image/albumBg/theDeli.png');
GitHub
You can also download this project from the GitHub repository.
Kerthin / musicPlayer-templateSait
A music player made in the style of neomorphism.
Description
The project is a working music player made in the style of neomorphism.
In the player it is possible:
- to switch tracks;
- rewind a track for 5 seconds forward and back;
- use the music bar to scroll the track in more detail;
- to enable repeat track;
- to enable repeat playlist;
- you can enable random track launch mode.
Use technology.
The following technologies were used to create this project:
Task-Manager
Software platform
Preprocessors
Package manager
Languages
Plugins
To develop the project through gulp, I used the following types of NPM plugins:
…Plugin Status Description gulp-sourcemaps
Intended for generation of
css source maps
which will be necessary at debugging of a code. gulp-imageminMinify
PNG
,JPEG
,GIF
andSVG
images withimagemin
Prefix
CSS
withAutoprefixer
Pngquant imagemin
plugin gulp-uglifyMinify
JavaScript
withUglifyJS3
. gulp-rigger
Rigger
is a build time include engine forJavascript
,Full Page Demo
The End
Thank you for giving your precious time to my post. See you soon.
I can advise you to subscribe to my Twitter, I also post my work there.
Goodbye
Recommend
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK