vue2.0+SVG实现音乐播放圆形进度条组件


Posted in Javascript onSeptember 21, 2019

vue2.0+SVG实现音乐播放圆形进度条组件,传入实时百分比实现圆圈进度动画效果

vue2.0+SVG实现音乐播放圆形进度条组件

需求分析:

类似于大多数音乐播放器中等mini播放器控制按钮,显示播放进度,实时更新进度。

progress-circle.vue源码:

<template>
 <div class="progress-circle">
 <svg :width="radius" :height="radius" viewBox="0 0 100 100" version="1.1" xmlns="http://www.w3.org/2000/svg">
  <circle class="progress-background" r="50" cx="50" cy="50" fill="transparent"/>
  <circle class="progress-bar" r="50" cx="50" cy="50" fill="transparent" :stroke-dasharray="dashArray"
    :stroke-dashoffset="dashOffset"/>
 </svg>
 <slot></slot>
 </div>
</template>
 
<script type="text/ecmascript-6">
 export default {
 props: {
  radius: {
  type: String,
  default: '0.32rem'
  },
  percent: {
  type: Number,
  default: 0
  }
 },
 data() {
  return {
  dashArray: Math.PI * 100
  }
 },
 computed: {
  dashOffset() {
  return (1 - this.percent) * this.dashArray
  }
 }
 }
</script>
 
<style scoped lang="stylus" rel="stylesheet/stylus">
 .progress-circle
 position: relative
 circle
  stroke-width: 0.16rem
  transform-origin: center
  &.progress-background
  transform: scale(0.9)
  stroke: rgba(255, 205, 49, 0.5)
  &.progress-bar
  transform: scale(0.9) rotate(-90deg)
  stroke: #ffcd32
</style>

本组件没有使用本地资源,可直接只用,在父组件中导入并注册后,调用组件。
父组件DOM结构:

<div class="control">
 <progress-circle :radius="radius" :percent="percent">
  <i @click.stop="togglePlaying" class="icon-mini" :class="iconMiniPlay"></i>
 </progress-circle>
</div>

解释:其中<i></i>中引用的是制作的css图标(播放/暂停按钮),通过iconMiniPlay决定展现是播放按钮还是暂停按钮(本例子只介绍原型进图条组件的开发和使用,因此不多介绍),设置图标的大小务必注意与radius一致,不明白为什么的话建议尝试一下,实践出真知噢。

需要像组件传入的参数:

svg圈圈大小radius以及歌曲播放进度百分比percent,两个数据来源:

vue2.0+SVG实现音乐播放圆形进度条组件

解释:

percent通过audio标签的currentTime获取,duration为接口获取的当前歌曲总长度,相除则为当前进度百分比。

radius可根据自身开发时所需规格设置(其他布局、样式之类的也是)

父组件样式(本人使用stylus):

.control
 position absolute
 top 0.35rem
 right 1rem
 color $color-theme-d
 .icon-mini
 font-size: 0.64rem
 position: absolute
 left: 0
 top: 0

最近可以变听歌边开发了。

开发完并运用此组件,设置适当的布局、样式后的效果:

vue2.0+SVG实现音乐播放圆形进度条组件

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS是否可以跨文件同时控制多个iframe页面的应用技巧
Dec 16 Javascript
JQuery在光标位置插入内容的实现代码
Jun 18 Javascript
在jQuery ajax中按钮button和submit的区别分析
Oct 07 Javascript
jQuery实现的一个tab切换效果内部还嵌有切换
Aug 10 Javascript
jQuery实现验证年龄简单思路
Feb 24 Javascript
分享jQuery网页元素拖拽插件
Dec 01 Javascript
详解Vue路由开启keep-alive时的注意点
Jun 20 Javascript
three.js加载obj模型的实例代码
Nov 10 Javascript
vue+iview+less+echarts实战项目总结
Feb 22 Javascript
Bootstrap Paginator+PageHelper实现分页效果
Dec 29 Javascript
解决Angularjs异步操作后台请求用$q.all排列先后顺序问题
Nov 29 Javascript
Vue检测屏幕变化来改变不同的charts样式实例
Oct 26 Javascript
js+springMVC 提交数组数据到后台的实例
Sep 21 #Javascript
jquery弹窗时禁止body滚动条滚动的例子
Sep 21 #jQuery
vue实现文件上传读取及下载功能
Nov 17 #Javascript
layer弹出框确定前验证:弹出消息框的方法(弹出两个layer)
Sep 21 #Javascript
vue配置nprogress实现页面顶部进度条
Sep 21 #Javascript
Vue使用NProgress进度条的方法
Sep 21 #Javascript
NProgress显示顶部进度条效果及使用详解
Sep 21 #Javascript
You might like
JQuery 无废话系列教程(二) jquery实战篇上
2009/06/23 Javascript
javascript 页面只自动刷新一次
2009/07/10 Javascript
JQuery 小练习(实例代码)
2009/08/07 Javascript
Jquery数独游戏解析(一)-页面布局
2010/11/05 Javascript
jQuery数据缓存功能的实现思路及简单模拟
2013/05/27 Javascript
极易被忽视的javascript面试题七问七答
2016/02/15 Javascript
JS实现登录页面记住密码和enter键登录方法推荐
2016/05/10 Javascript
javascript之Boolean类型对象
2016/06/07 Javascript
浅析Nodejs npm常用命令
2016/06/14 NodeJs
JavaScript实现前端分页控件
2017/04/19 Javascript
JavaScript调试之console.log调试的一个小技巧分享
2017/08/07 Javascript
SVG动画vivus.js库使用小结(实例代码)
2017/09/14 Javascript
webpack打包node.js后端项目的方法
2018/03/10 Javascript
详解React-Router中Url参数改变页面不刷新的解决办法
2018/05/08 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
Python读取ini文件、操作mysql、发送邮件实例
2015/01/01 Python
python使用arp欺骗伪造网关的方法
2015/04/24 Python
Python3中的2to3转换工具使用示例
2015/06/12 Python
基于python3 OpenCV3实现静态图片人脸识别
2018/05/25 Python
CentOS下Python3的安装及创建虚拟环境的方法
2018/11/28 Python
Django 内置权限扩展案例详解
2019/03/04 Python
Pycharm简单使用教程(入门小结)
2019/07/04 Python
感知器基础原理及python实现过程详解
2019/09/30 Python
Python 实现Numpy中找出array中最大值所对应的行和列
2019/11/26 Python
Python连接SQLite数据库并进行增册改查操作方法详解
2020/02/18 Python
Python 如何在字符串中插入变量
2020/08/01 Python
Html5应用程序缓存(Cache manifest)
2018/06/04 HTML / CSS
GOLFINO英国官网:高尔夫服装
2020/04/11 全球购物
SQL Server面试题
2013/04/04 面试题
毕业自我评价
2014/02/05 职场文书
书香校园活动方案
2014/02/28 职场文书
初婚初育证明范本
2014/11/24 职场文书
学校2015年纠风工作总结
2015/05/15 职场文书
电影地道战观后感
2015/06/04 职场文书
Java 超详细讲解ThreadLocal类的使用
2022/04/07 Java/Android
js作用域及作用域链工作引擎
2022/07/07 Javascript