vue2.0实现音乐/视频播放进度条组件

基于vue2.0实现音乐/视频播放进度条组件的方法及代码解释,具体内容如下

需求分析:

①:进度条随着歌曲的播放延长,歌曲播放完时长度等于黑色总进度条长度;时间实时更新。

②:当滑动按钮时,实时更新播放时间,橙色进度条长度也会随着按钮的滑动而改变,当滑动结束时,橙色区域停留在滑动结束的位置,歌曲从当前进度开始播放。

③:点击进度条,橙色进度条长度变为点击处至起点的长度,并从当前点开始播放歌曲。

大概思路:

①:左边的时间可以通过audio播放时派发的timeupdate事件获取,右边的时间为接口获取的当前歌曲的总时间。

②:进度条子组件的长度通过父组件传入一个percent值计算,percent值为播放进度与总进度的比值。

③:进度条的滑动及点击结束后,需要向父组件传递一个percent值,使用this.$emit()像父组件派发事件,父组件中设置事件响应函数,接收percent参数值,用于改变audio中当前播放的音乐进度。

详细实现,关键代码已经注释:

先上组件源码:

<template>
 <div class="progress-bar" ref="progressBar" @click="progressClick">
  <div class="bar-inner">
   <div class="progress" ref="progress"></div>
   <div class="progress-btn-wrapper"ref="progressBtn"
      @touchstart.prevent = "progressTouchStart"
      @touchmove.prevent = "progressTouchMove"
      @touchend = "progressTouchEnd"
   >
    <div class="progress-btn"></div>
   </div>
  </div>
 </div>
</template> 

<script type="text/ecmascript-6">
 // 进度条按钮宽度,由于style中没有设置width,因此只能用clientWidth获取
 export default {
  data() {
   return {
    btnWidth: {
     type: Number,
     default: 0
    },
    touchInfo: {
     initiated: false
    }
   }
  },
  props: {
   percent: {
    type: Number,
    default: 0
   }
  },
  mounted() {
   this.btnWidth = document.getElementsByClassName('progress-btn')[0].clientWidth
  },
  methods: {
   // 点击按钮
   progressTouchStart(e) {
    // 记录touch事件已经初始化
    this.touchInfo.initiated = true
    // 点击位置
    this.touchInfo.startX = e.touches[0].pageX
    // 点击时进度条长度
    this.touchInfo.left = this.$refs.progress.clientWidth
   },
   // 开始移动
   progressTouchMove(e) {
    if (!this.touchInfo.initiated) {
     return
    }
    // 计算移动距离
    const moveX = e.touches[0].pageX - this.touchInfo.startX
    // 设置偏移值
    const offsetWidth = Math.min(Math.max(0, this.touchInfo.left + moveX),
     this.$refs.progressBar.clientWidth - this.btnWidth)
    this._setOffset(offsetWidth)
   },
   // 移动结束
   progressTouchEnd(e) {
    this.touchInfo.initiated = false
    // 向父组件派发事件,传递当前百分比值
    this._triggerPercent()
   },
   // 进度条点击事件
   progressClick(e) {
    console.log('clikc')
    // 设置进度条及按钮偏移
    this._setOffset(e.offsetX)
    // 通知父组件播放进度变化
    this._triggerPercent()
   },
   _triggerPercent() {
    const barWidth = this.$refs.progressBar.clientWidth - this.btnWidth
    const percent = Math.min(1, this.$refs.progress.clientWidth / barWidth)
    this.$emit('percentChange', percent)
   },
   // 设置偏移
   _setOffset(offsetWidth) {
    // 设置进度长度随着百分比变化
    this.$refs.progress.style.width = `${offsetWidth}px`
    // 设置按钮随着百分比偏移
    this.$refs.progressBtn.style.transform = `translate3d(${offsetWidth}px, 0, 0)`
   }
  },
  watch: {
   // 监听歌曲播放百分比变化
   percent(newPercent, oldPercent) {
    if (newPercent > 0 && !this.touchInfo.initiated) {
     // 进度条总长度
     const barWidth = this.$refs.progressBar.clientWidth - this.btnWidth
     const offsetWidth = barWidth * newPercent
     // 设置进度条及按钮偏移
     this._setOffset(offsetWidth)
    }
   }
  }
 }
</script> 

<style lang="stylus" rel="stylesheet/stylus">
 @import "~common/stylus/variable.styl" 

 .progress-bar
  height 0.5rem
  .bar-inner
   position relative
   top 0.2rem
   height 0.08rem
   background rgba(0, 0, 0, 0.3)
   .progress
    position absolute
    height 100%
    background $color-theme
   .progress-btn-wrapper
    position absolute
    left -0.25rem
    top -0.25rem
    width 0.5rem
    height 0.5rem
    .progress-btn
     position relative
     top 0.12rem
     left 0.12rem
     box-sizing border-box
     width 0.32rem
     height 0.32rem
     border 0.06rem solid $color-text
     border-radius 50%
     background $color-theme
</style> 

此为progerss-bar.vue组件源码,组件所需要父组件传入的值只有一个“percent”,为父组件中audio当前播放时间与总时间的比值,用于计算此组件中橙色进度条的长度。

组件的使用:

首先导入并注册组件(在此不做解释),随后使用此组件,dom:

<div class="progress-wrapper">
 <span class="time time-l">{{formatTime(currentTime)}}</span>
 <div class="progress-bar-wrapper">
  <progress-bar :percent="percent" @percentChange="setProgress"></progress-bar>
 </div>
 <span class="time time-r">{{formatTime(currentSong.duration)}}</span>
</div>

解释:两个span为左右两个时间值,progress-bar为调用的组件,需要传入percent值,用于子组件设置进度条长度
percent值来自于audio的currenTime与歌曲总长度的比值:

// 计算百分比
percent() {
 return Math.min(1, this.currentTime / this.currentSong.duration)
} 

@percentChange为子组件中派发过来的事件,详细请看子组件中源码及注释“_triggerPercent()”部分,此事件调用的方法用于接收子组件传过来的拖动按钮、点击进度条改变歌曲播放进度后的播放百分比,用于改变父组件中audio标签的currentTime,进而将歌曲播放进度设置为当前时间。

以下为父组件中,接收到子组件派发过来的事件后调用的函数。

// 设置进度
  setProgress(percent) {
   // 根据子组件传过来的百分比设置播放进度
   this.$refs.audio.currentTime = this.currentSong.duration * percent
   // 拖动后设置歌曲播放
   if (!this.playing) {
    this.togglePlaying()
   }
  }, 

样式(本人使用stylus):

.progress-wrapper
     display flex
     .time
      font-size 0.24rem
      &.time-l
       position absolute
       bottom 1.62rem
       left 1rem
      &.time-r
       position absolute
       bottom 1.62rem
       right 1rem
     .progress-bar-wrapper
      position absolute
      bottom 1.5rem
      left 1.7rem
      width 4.2rem 

至此,进度条组件的实现及使用方法均介绍完毕。

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

(0)

相关推荐

  • vue视频播放暂停代码

    vue中的视频播放 vue.js中引入video视频播放器 main.js中引入 import Video from 'video.js' import 'video.js/dist/video-js.css' Vue.prototype.$video = Video html页面 <video id="vide" class="video-js v2 ani resize" autoplay :src="视频地址" type="

  • vue实现自定义H5视频播放器的方法步骤

    前言 前段时间基于vue写了一个自定义的video播放器组件,踩了一些小坑, 这里做一下复盘分享出来,避免日后重复踩坑... 设计阶段 这里就直接放几张完成后的播放状态图吧,界面布局基本就是flex+vw适配一把梭,也比较容易. 需要实现的几个功能基本都标注出来了; 除了还有一个视频加载失败的...下面就这届上代码了;刚开始构思的时候考虑了一下功能的实现方式: 一是用原生的DOM操作,获取video元素后,用addEventListener来监听; 二是用vue的方式绑定事件监听; 最后图方便采

  • vue通过video.js解决m3u8视频播放格式的方法

    前言 今天被这个关于m3u8视频播放不了搞了一下午,这个项目所有的视频流都是m3u8格式的,后台给我们返回的都是m3u8格式的视频流,解决了好长时间,看了好多博客,只有这个博客给我点启发,去解决这个问题,请查看.会使用两种方法来解决这个问题 第一种方法 1.在vue中安装下面这些插件 cnpm install video.js --save ccnp install videojs-contrib-hls --save 网上有说video.js版本太高不能使用,不能使用7以上的版本,用5版本的,

  • vue使用video.js进行视频播放功能

    关于video.js video.js是一个拥有h5背景的网络视频播放器,同时支持h5以及Flash视频播放(可加载本地静态资源视频以及网络链接视频) 官网:videojs.com/ 安装 npm  install video.js main.js中引入 import Video from 'video.js' import 'video.js/dist/video-js.css' Vue.prototype.$video = Video 使用 <div class="demo1-vide

  • vue-dplayer 视频播放器实例代码

    官网 vue-dplayer dplayer-doc 示例 如果默认 options 中没有视频链接,之后设置视频链接时,直接通过 this.options.video.url = videoPath 是无效的 需要先获取到播放器的实例 this.$refs.player.dp ,然后通过 switchVideo() 对 url 进行修改 <template> <d-player ref="player" :options="options">

  • vue2.0实现音乐/视频播放进度条组件

    基于vue2.0实现音乐/视频播放进度条组件的方法及代码解释,具体内容如下 需求分析: ①:进度条随着歌曲的播放延长,歌曲播放完时长度等于黑色总进度条长度:时间实时更新. ②:当滑动按钮时,实时更新播放时间,橙色进度条长度也会随着按钮的滑动而改变,当滑动结束时,橙色区域停留在滑动结束的位置,歌曲从当前进度开始播放. ③:点击进度条,橙色进度条长度变为点击处至起点的长度,并从当前点开始播放歌曲. 大概思路: ①:左边的时间可以通过audio播放时派发的timeupdate事件获取,右边的时间为接口

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

    vue2.0+SVG实现音乐播放圆形进度条组件,传入实时百分比实现圆圈进度动画效果 需求分析: 类似于大多数音乐播放器中等mini播放器控制按钮,显示播放进度,实时更新进度. progress-circle.vue源码: <template> <div class="progress-circle"> <svg :width="radius" :height="radius" viewBox="0 0 10

  • Bootstrap进度条组件知识详解

    在网页中,经常见到进度条效果,如:平分系统.加载状态等,进度条组件使用了css3的transition和animation属性来完成一些特效,这些特效在IE9及IE9以下版本.Firefox的老版本中并不支持,Opera 12 不支持 animation 属性. 进度条和其他独立组件一样,开发者可以根据自己的需要选择对应的版本: LESS: progress-bars.less SASS: _progress-bars.scss 基础进度条 实现原理: 需要两个容器,外容器使用类名.progre

  • jQuery EasyUI ProgressBar进度条组件

    ProgressBar(进度条)组件,这个还是挺好玩的,我们在自己做点什么的时候经常能用到,比如上传下载文件.导入导出文档啊.载入网页等等. 应用场景很多,使用起来还很简单. 示例: <!DOCTYPE html> <html> <head> <title>jQuery Easy UI</title> <meta charset="UTF-8" /> <script type="text/javas

  • Vue的事件响应式进度条组件实例详解

    写在前面 找了很多vue进度条组件,都不包含拖拽和点击事件,input range倒是原生包含input和change事件,但是直接基于input range做进度条的话,样式部分需要做大量调整和兼容性处理.即使做好了,将来需要修改外观,又是一番折腾. 基于以上两个原因,做了一个可以响应input和change事件(即一个是拖动进度条到某处,一个是在进度条某位置点击使其值变为该位置)的div实现的Vue组件,这样既满足了对进度条事件的需求,也带来了如有需求变动,样式修改很方便的好处. 效果图 以

  • vue 页面加载进度条组件实例

    页面加载进度条最初我是在youtube上看到的,后面几乎在各大网站上都能见到它的身影,可以让用户在加载页面的时候不会对着完全空白的页面发呆,提升用户体验 但是从开发角度讲,这种进度条在真实性上确实很难把握,因为在逻辑代码加载完成之前,我们都不能统计到进度,而逻辑代码自身的进度也无法统计.另外,我们不可能监控到所有资源的加载情况. 事实上,用户并不是在乎你的页面究竟加载了百分之几,而真正关心的是离加载完还有多久,以及这个空白页面是没有加载完,还是加载完就是空白的.所以没我们需要去"模拟"

  • vue环形进度条组件实例应用

    在做项目的时候,最好只使用一套组件库,但是很多时候我们的组件库里面没有我们需要的组件,这个时候我们还是需要自己写组件了,vux里面就没有环形进度条组件,所以需要自己写一个. 查找资料后发现了一个很好的实现方式,通过svg来实现,以前的时候学过一点svg但是没有怎么深入了解过...现在看来真是罪过,给出参考链接 https://segmentfault.com/a/1190000008149403 可以看出原作者使用了两种方式,我们选择了第二种,简单,而且好扩展.可以看到svg就想是canvas一

  • Android实现音乐播放进度条传递信息的两种方式(在service和activity中)

    实现播放时的进度条显示,或是定时从service获取某些信息,是我们日常开发中经常遇到的需求,下面介绍当音乐再service中运行时,activity如果获取音乐进度信息的两种方式: 一.在activity中建立消息接收机制 我们需要在activity中建立一个用于接收信息的handler(handler简单的说是在android中可以发送消息和也可以处理消息的一种机制,当然它的用途更加强大,有时间可以去自己了解) 我们需要在onCreate方法之前添加handler,这样才能保证当我们的act

  • vue圆环百分比进度条组件功能的实现

    有需要的人可以参考一下,如果试用过,发现问题,欢迎留言告知,不胜感激. 功能介绍: 1.若页面无刷新,且第一次传值小于第二次传值或者圆环初始化时执行的是递增动画 2.若页面无刷新,且第一次传值大于第二次传值则为执行递减动画 3.中间展示的百分比数字有缓动动画(速度同圆环进度动画一直) 4.动画完成时会触发动画完成回调 5.外部传值为圆环进度百分比(整数),圆环动画速度(整数) 效果如图所示: <template> <div class="percentloop">

  • vue视频时间进度条组件使用方法详解

    本文实例为大家分享了vue视频时间进度条组件的使用方法,供大家参考,具体内容如下 有些视频是以视频流的形式进行渲染的,没有视频滚动条,所以就写了24h的时间组件 实现思路: 1.24h的时间刻度线总宽度为12960px2.点击24h线的某一点,获取这一点离左侧原点的距离(使用dom元素layerX和offsetLeft综合判断)3.计算点击时线段的占比比率4.每天的时间是86400000毫秒5.占比比率乘以86400000就是获取的你点击的时间 代码如下: <template>   <d

随机推荐