灵感的由来是前些天看到了博: http://www.cnblogs.com/li-cheng 的首页有一个很漂亮的播放器,感觉很不错,是用Flex做的Flash播放器。

于是我也便想到了,自己也来来弄个玩玩。

所以利用1天的时间,通过收集整理,做了一款自己专属的播放器!

播放器实现了以下功能操作:
1:播放、暂停
2:快进、快退
3:上一曲、下一曲
4:单曲循环

效果如下:

奉献JS源码如下:

(function ($) {
$.fn.Html5Player = function() {
//获取音频API
var audio = $('body').find('audio').get(); /**********歌曲列表***************/
var songDefualtSettings=[
{"Singer":"火星哥","SongName":"The Lazy Song","img":"./images/火星哥.jpg"},
{"Singer":"邓紫棋","SongName":"We Will Rock You","img":"./images/邓紫棋.jpg"},
{"Singer":"王菲","SongName":"闷","img":"./images/王菲.jpg"},
{"Singer":"梁静茹","SongName":"情歌","img":"./images/梁静茹.jpg"}
];
/*********当前播放的歌曲**********/
var pointerInt=; return this.each(function() { /*******音频处理操作********/
var ExcuteAudioCommon = {
//播放进度条的转变事件
DurationProcessRange:function (rangeVal) {
audio.currentTime = rangeVal * audio.duration;
audio.play();
},
//获得总的时间刻度
TimeSpan:function() {
var ProcessYet = ;
var _this = this;
setInterval(function () {
var ProgressYet = (audio.currentTime / audio.duration) * ;
$(".ProgressYet").css("width", ProgressYet);
var currentTime = _this.timeDispose(audio.currentTime);
var timeAll = _this.timeDispose(_this.TimeAll());
$(".SongTime").html(currentTime + " | " + timeAll);
}, );
},
//将时长计算成分秒
timeDispose: function (number) {
var minute = parseInt(number / );
var second = parseInt(number % );
minute = minute >= ? minute : "" + minute;
second = second >= ? second : "" + second;
return minute + ":" + second;
},
//获取音频总时长
TimeAll: function () {
return audio.duration;
}
} /*******上一曲**********/
$(this).find(".LeftControl").click(function(){
CreateSongStart(pointerInt=pointerInt==?:pointerInt-);
$("#MainControl").data("play")==="off"&&audio.play()&&ExcuteAudioCommon.TimeSpan();
}); /******播放,暂停********/
$("#MainControl").click(function() {
if($(this).data("play")==="off")
{
$("#MainControl").removeClass("PlayControl").addClass("StopControl");
audio.pause();
$(this).data("play","on");
}else{
$("#MainControl").addClass("PlayControl").removeClass("StopControl");
if (audio.src == "") {
pointerInt= parseInt(Math.random()*songDefualtSettings.length,);
CreateSongStart(pointerInt);
}
audio.play();
ExcuteAudioCommon.TimeSpan();
$(this).data("play","off");
}
}); function CreateSongStart(SongNumber){
var Defaultsong = songDefualtSettings[SongNumber];
$(".SongName").text(Defaultsong.SongName);
$(".Singer").text(Defaultsong.Singer)
$("#singerImg").attr("src",Defaultsong.img);
audio.src = "./media/" + Defaultsong.SongName + ".mp3";
} /*******下一曲********/
$(this).find(".RightControl").click(function(){
CreateSongStart(pointerInt=pointerInt==(songDefualtSettings.length-)?pointerInt:pointerInt+);
$("#MainControl").data("play")==="off"&&audio.play()&&ExcuteAudioCommon.TimeSpan();
}); /********音频进度条事件(进度增加)*******/
$(".Progress").click(function (e) {
//----播放进度条的基准参数
var Progress = $(".Progress").offset();
var ProgressStart = Progress.left;
var ProgressLength = $(".Progress").width(); var CurrentProces = e.clientX - ProgressStart;
ExcuteAudioCommon.DurationProcessRange(CurrentProces / ProgressLength);
$(".ProcessYet").css("width", CurrentProces);
}); /********音频进度条事件(进度减少)********/
$(".ProgressYet").click(function (e) {
//-----播放进度条的基准参数
var Progress = $(".Progress").offset();
var ProgressStart = Progress.left;
var ProgressLength = $(".Progress").width(); var CurrentProces = e.clientX - ProgressStart;
ExcuteAudioCommon.DurationProcessRange(CurrentProces / ProgressLength);
$(".ProgressYet").css("width", CurrentProces);
}) //监听媒体文件结束的事件(ended),这边一首歌曲结束就读取下一首歌曲,实现播放上的循环播放
audio.addEventListener('ended', function () {
CreateSongStart(pointerInt=(pointerInt>=&&(songDefualtSettings.length-)!=pointerInt)?++pointerInt:);
$("#MainControl").data("play")==="off"&&audio.play()&&ExcuteAudioCommon.TimeSpan();
}, false);
})
}
})(jQuery);

原创: 做一款属于自己风格的音乐播放器 (HTML5的Audio新特性)的更多相关文章

  1. 一款非常简单的android音乐播放器源码分享给大家

    一款非常简单的android音乐播放器源码分享给大家,该应用虽然很小,大家常用的播放器功能基本实现了,可能有点还不够完善,大家也可以自己完善一下,源码在源码天堂那里已经有了,大家可以到那里下载学习吧. ...

  2. ubuntu下一款有点感觉的 linux音乐播放器 clementine(小橘子))

    https://www.clementine-player.org/ 在linux听音乐的感觉确实不是很好,音乐播放器很多.但是仅仅只是数量上的优势,在确实不是很好用.自带的rhythmbox确实很占 ...

  3. 简单风格 在线音乐播放器(支持wav,MP3等)

    找了两天终于找到了,支持wav,MP3,其他格式没有测试. 1.修复了jQuery判断ie的bug, 2.修复播放循环 下载地址: http://pan.baidu.com/s/1o6upwHs

  4. 躁!DJ 风格 Java 桌面音乐播放器

    本文适合有 Java 基础知识的人群,跟着本文可学习和运行 Java 版桌面 DJ 音乐播放器. 本文作者:HelloGitHub-秦人 HelloGitHub 推出的<讲解开源项目>系列 ...

  5. [ 原创 ]学习笔记-做一个Android音乐播放器是遇到的一些困难

    最近再做一个安卓的音乐播放器,是实验室里学长派的任务,我是在eclipse上进行开发的,由于没有android的基础,所以做起来困难重重. 首先是布局上的困难 1.layout里的控件属性不熟悉 2. ...

  6. pygame系列_原创百度随心听音乐播放器_完整版

    程序名:PyMusic 解释:pygame+music 之前发布了自己写的小程序:百度随心听音乐播放器的一些效果图 你可以去到这里再次看看效果: pygame系列_百度随心听_完美的UI设计 这个程序 ...

  7. C# 一款属于自己的音乐播放器

    本文利用C# 调用Windows自带的Windows Media Player 打造一款属于自己的音乐播放器,以供学习分享使用,如有不足之处,还请指正. 概述 Windows Media Player ...

  8. 用PHP+H5+Boostrap做简单的音乐播放器(进阶版)

    前言:之前做了一个音乐播放器(纯前端),意外的受欢迎,然后有人建议我把后台一起做了,正好也想学习后台,所以学了两天php(不要吐槽我的速度,慢工出细活嘛~)然后在之前的基础上也又完善了一些功能,所以这 ...

  9. C#做音乐播放器时在自动下一曲中报异常的解决办法

    ---------------------- ASP.Net+Unity开发..Net培训.期待与您交流! ---------------------- 在利用Media Player做音乐播放器的时 ...

随机推荐

  1. java ZIP压缩文件

    问题描述:     使用java ZIP压缩文件和目录 问题解决:     (1)单个文件压缩 注:     以上是实现单个文件写入压缩包的代码,注意其中主要是在ZipOutStream流对象中创建Z ...

  2. uva 11609

    可以想到 答案为 1*C(1,n)+2*C(2,n)+3*C(3,n)+....+n*C(n,n); 由公式 k*C(k,n) = n*C(k-1,n-1) 所以最终答案 n*2^(n-1) 用到快速 ...

  3. 2016,除了 DevOps,企业还应该知道 CMDB!

    CMDB 是 Configuration Management Database(配置管理数据库)的简称,CMDB 存储与管理企业 IT 架构中设备的各种配置信息,它与所有服务支持和服务交付流程都紧密 ...

  4. ZOJ 2724 Windows Message Queue (优先级队列,水题,自己动手写了个最小堆)

    #include <iostream> #include <stdio.h> #include <string.h> #include <algorithm& ...

  5. Relevance Between Variable Declaration and Definition in C++

    A declaration makes a name known to a programm. A definition creates the assocatied entity. A variab ...

  6. NSString+URLEncoding.h --使用Obj-C对数据等进行URLEncoding编码

    在Objective-c进行网络编程时,经常需要把数据转换成URLEncoding编码,如对+号编码后,变成%2b.这里我们给出一种实现. //NSString+URLEncoding.h #impo ...

  7. python logging 学习笔记

    logging.basicConfig函数各参数: filename: 指定日志文件名 filemode: 和file函数意义相同,指定日志文件的打开模式,'w'或'a' format: 指定输出的格 ...

  8. Executing Raw SQL Queries using Entity Framework

    原文 Executing Raw SQL Queries using Entity Framework While working with Entity Framework developers m ...

  9. WP布局之Pivot和Panorama

    一.Pivot控件(枢轴控件) Pivot主要用于管理应用中的视图或者页面,此控件在WP中几乎处处可见,不管是短信的左右滑动,还是QQ的左右滑动都是此控件的功劳. 就是图片中的控件,是不是很熟悉呢. ...

  10. Linux 查找软件安装路径

    root@kali:~# whereis sqlmap sqlmap: /usr/bin/sqlmap /usr/share/sqlmap /usr/share/man/man1/sqlmap..gz ...