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 相关文章推荐
基于jQuery实现的百度导航li拖放排列效果,即时更新数据库
Jul 31 Javascript
让AJAX不依赖后端接口实现方案
Dec 03 Javascript
在JavaScript中判断整型的N种方法示例介绍
Jun 18 Javascript
JavaScript如何实现对数字保留两位小数一位自动补零
Dec 18 Javascript
网页瀑布流布局jQuery实现代码
Oct 21 Javascript
react-router实现跳转传值的方法示例
May 27 Javascript
vue给input file绑定函数获取当前上传的对象完美实现方法
Dec 15 Javascript
jQuery实现基本淡入淡出效果的方法详解
Sep 05 jQuery
基于JS实现web端录音与播放功能
Apr 17 Javascript
通过JQuery,JQueryUI和Jsplumb实现拖拽模块
Jun 18 jQuery
微信小程序wx.request拦截器使用详解
Jul 09 Javascript
小程序自定义模板实现吸顶功能
Jan 08 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
php中json_encode中文编码问题分析
2011/09/13 PHP
win7下memCache的安装过程(具体操作步骤)
2013/06/28 PHP
php检索或者复制远程文件的方法
2015/03/13 PHP
php实现的网络相册图片防盗链完美破解方法
2015/07/01 PHP
thinkphp多层MVC用法分析
2015/12/30 PHP
ThinkPHP5框架实现简单的批量查询功能示例
2018/06/07 PHP
laravel框架实现去掉URL中index.php的方法
2019/10/12 PHP
幻灯片带网页设计中的20个奇妙应用示例小结
2012/05/27 Javascript
js实现文本框中输入文字页面中div层同步获取文本框内容的方法
2015/03/03 Javascript
javascript实现别踩白块儿小游戏程序
2015/11/22 Javascript
jQuery form插件的使用之处理server返回的JSON, XML,HTML数据
2016/01/26 Javascript
浅析Javascript中bind()方法的使用与实现
2016/05/30 Javascript
基于JS实现的随机数字抽签实例
2016/12/08 Javascript
Node.js读取文件内容示例
2017/03/07 Javascript
利用JavaScript缓存远程窃取Wi-Fi密码的思路详解
2018/11/05 Javascript
JavaScript显式数据类型转换详解
2019/03/18 Javascript
JavaScript创建、读取和删除cookie
2019/09/03 Javascript
JS实现电脑虚拟键盘的操作
2020/06/24 Javascript
[01:00:44]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#1COL VS Alliance第三局
2016/03/04 DOTA
[34:44]Liquid vs TNC Supermajor 胜者组 BO3 第二场 6.4
2018/06/05 DOTA
numpy向空的二维数组中添加元素的方法
2018/11/01 Python
Django处理多用户类型的方法介绍
2019/05/18 Python
python selenium登录豆瓣网过程解析
2019/08/10 Python
Python环境下安装PyGame和PyOpenGL的方法
2020/03/25 Python
opencv 查找连通区域 最大面积实例
2020/06/04 Python
美国猫狗药物和用品网站:PetCareRx
2017/01/05 全球购物
全球性的在线鞋类品牌:Public Desire
2019/04/03 全球购物
Groupon荷兰官方网站:高达70%的折扣
2019/11/01 全球购物
学期研究性学习个人的自我评价
2014/01/09 职场文书
交通事故检查书范文
2014/01/30 职场文书
信访工作经验交流材料
2014/05/23 职场文书
保卫钓鱼岛口号
2014/06/20 职场文书
敬老院献爱心活动总结
2014/07/08 职场文书
高中学生自我评价范文
2014/09/23 职场文书
认错检讨书
2014/10/02 职场文书
学校隐患排查制度
2015/08/05 职场文书