当前仓库属于关闭状态,部分功能使用受限,详情请查阅 仓库状态说明
7 Star 0 Fork 0

lflippancyl/miu_vue
关闭

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
index.html 9.13 KB
一键复制 编辑 原始数据 按行查看 历史
lflippancyl 提交于 2016-07-07 16:54 . 完成所有基本功能
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="format-detection" content="telephone=no, email=no">
<meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
<meta name="full-screen" content="yes">
<meta name="browsermode" content="application">
<meta name="screen-orientation" content="portrait">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<title>miu</title>
<style>
/*进度条样式*/
.progressBar {
width: 100%;
height: 2px;
}
.progressBar div {
position: absolute;
}
.progressBar .progressBac {
width: 100%;
height: 2px;
background: rgba(56, 64, 63, 0.5);
}
.progressBar .speed {
width: 100%;
height: 2px;
left: -100%;
background: linear-gradient(to right, rgb(240, 220, 64), rgb(140, 170, 64));
}
.progressBar .drag {
position: absolute;
left: -8px;
top: -14px;
margin: 10px 10px 10px 0;
width: 20px;
height: 25px;
border-radius: 5px;
}
</style>
</head>
<body>
<div id="app">
<router-view></router-view>
</div>
<audio src="" id="mainAudio">
你的浏览器不支持播放器
</audio>
<div style="position: fixed;bottom: 5px;z-index: 10;width: 100%;">
<div id="time" style="color: rgba(255,255,255,0.8);">
<div class="tiemDetail">
<span class="currentTime" id="currentTime">00:00</span>/
<span class="allTime" id="allTime">00:00</span>
</div>
</div>
<section class="progressBar">
<div class="progressBac"></div>
<div class="speed" id="speed"></div>
<img src="" style="z-index: -9;" class="drag" id="drag"/>
</section>
</div>
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<script>
var audio = document.getElementById("mainAudio");
// var ROOT = '/';
var ROOT = 'http://flippancy.ngrok.cc//';
function timeChange(time, timePlace) { //默认获取的时间是时间戳改成我们常见的时间格式
var timePlace = document.getElementById(timePlace);
//分钟
var minute = time / 60;
var minutes = parseInt(minute);
if (minutes < 10) {
minutes = "0" + minutes;
}
//秒
var second = time % 60;
seconds = parseInt(second);
if (seconds < 10) {
seconds = "0" + seconds;
}
var allTime = "" + minutes + "" + ":" + "" + seconds + "";
timePlace.innerHTML = allTime;
}
//播放事件监听
function playCotrol() {
audio.addEventListener("loadeddata", //歌曲一经完整的加载完毕( 也可以写成上面提到的那些事件类型)
function() {
addListenTouch(); //歌曲加载之后才可以拖动进度条
var allTime = audio.duration;
timeChange(allTime, "allTime");
setInterval(function() {
var currentTime = audio.currentTime;
timeChange(currentTime, "currentTime")
}, 1000);
}, false);
audio.addEventListener("play",
function() {
dragMove();
}, false);
audio.addEventListener("ended", function() {}, false)
}
var startX, x, aboveX = 0; //触摸时的坐标 //滑动的距离 //设一个全局变量记录上一次内部块滑动的位置
//1拖动监听touch事件
function addListenTouch() {
document.getElementById("time").addEventListener("touchstart", touchStart, false);
document.getElementById("time").addEventListener("touchmove", touchMove, false);
document.getElementById("time").addEventListener("touchend", touchEnd, false);
var drag = document.getElementById("drag");
var speed = document.getElementById("speed");
}
//touchstart,touchmove,touchend事件函数
function touchStart(e) {
e.preventDefault();
var touch = e.touches[0];
startX = touch.pageX;
x = 0;
}
function touchMove(e) { //滑动
e.preventDefault();
var touch = e.touches[0];
x = touch.pageX - startX; //滑动的距离
//drag.style.webkitTransform = 'translate(' + 0+ 'px, ' + y + 'px)'; //也可以用css3的方式
drag.style.left = aboveX + x - 8 + "px"; //
speed.style.left = -((window.innerWidth) - (aboveX + x)) + "px";
}
function touchEnd(e) { //手指离开屏幕
e.preventDefault();
if (x != 0) {
aboveX = parseInt(drag.style.left);
var touch = e.touches[0];
var dragPaddingLeft = drag.style.left;
var change = dragPaddingLeft.replace("px", "");
numDragpaddingLeft = parseInt(change);
var currentTime = (numDragpaddingLeft / (window.innerWidth)) * audio.duration;
audio.currentTime = currentTime;
} else {
var currentTime = (e.changedTouches[0].pageX / (window.innerWidth)) * audio.duration;
audio.currentTime = currentTime;
}
}
//拖动的滑动条前进
function dragMove() {
setInterval(function() {
drag.style.left = ((audio.currentTime / audio.duration) * (window.innerWidth) - 8) + "px";
speed.style.left = -((window.innerWidth) - (audio.currentTime / audio.duration) * (window.innerWidth)) + "px";
}, 500);
}
Date.prototype.format = function(format) {
var o = {
"M+": this.getMonth() + 1, //month
"d+": this.getDate(), //day
"h+": this.getHours(), //hour
"m+": this.getMinutes(), //minute
"s+": this.getSeconds(), //second
"q+": Math.floor((this.getMonth() + 3) / 3), //quarter
"S": this.getMilliseconds() //millisecond
}
if (/(y+)/.test(format)) format = format.replace(RegExp.$1,
(this.getFullYear() + "").substr(4 - RegExp.$1.length));
for (var k in o)
if (new RegExp("(" + k + ")").test(format))
format = format.replace(RegExp.$1,
RegExp.$1.length == 1 ? o[k] :
("00" + o[k]).substr(("" + o[k]).length));
return format;
}
function GetDateStr(AddDayCount) {
var dd = new Date();
dd.setDate(dd.getDate() + AddDayCount); //获取AddDayCount天后的日期
var y = dd.getFullYear();
var m = dd.getMonth() + 1; //获取当前月份的日期
var d = dd.getDate();
if (m < 10) {
m = '0' + m.toString();
} else {
m = m.toString();
}
if (d < 10) {
d = '0' + d.toString();
} else {
d = d.toString();
}
var date = new Object();
date.ny = y.toString() + '-' + m;
date.r = d.toString();
return date;
}
</script>
</body>
</html>
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
NodeJS
1
https://gitee.com/flippancy/miu_vue.git
git@gitee.com:flippancy/miu_vue.git
flippancy
miu_vue
miu_vue
master

搜索帮助