1. 音乐播放前进后退的实现   https://blog.csdn.net/weixin_40814356/article/details/80379606

2. 音乐进度条实现(单独一个组件) https://blog.csdn.net/weixin_40814356/article/details/80387804

思想: a. 播放进度条样式  定义高但是不定义宽度。 父组件computed: 当音乐不断变化的时候 它与总时间有个不断变化的百分比

子组件接收的时候 watch它的变化 不断去修改progress和小球的宽度

b. 实现拖动效果

给progress-bar定义触摸事件

在created中创建一个this.touch={}对象,用来保存函数中的一些数据

初始化touch事件 记录第一次触摸的位置,以及此时小球偏移的位置   在progressTouchMove方法中,记录触摸的距离(即拖动的距离),得出当前偏移距离(记录的小球偏移距离加上差值) 结束的时候把初始化置为false

然后实现拖动到指定位置,歌曲播放指定位置的功能    touch结束的时候,向父组件触发一个事件,获取bar的宽度,然后用progress的宽度/bar的宽度,得到百分比 通过$emit传递出去  父组件接收到事件 改变audio的播放点

最最后:实现点击的功能

c. 音乐环形进度条的实现

逻辑的实现:

3.如何获取歌词的数据,并解析jsonp的格式为json的格式

https://blog.csdn.net/weixin_40814356/article/details/80401989

4. 歌词左右滑动的实现  https://blog.csdn.net/weixin_40814356/article/details/80417580

给中间加一个touch事件 用一个currentShow保存歌词显示和隐藏的状态:是唱片页还是歌词页

touchstart的时候维护几个状态:记录x轴和y轴的坐标

touchmove:

 middleTouchMove (e) {

       if (!this.touch.init) {

         return

       }

       const touch = e.touches[0]

       const deltaX = touch.pageX - this.touch.startX

       const deltaY = touch.pageY - this.touch.startY

       // 为什么维护纵轴,当纵轴大于横轴的偏移的时候,就不应该移动

       if (Math.abs(deltaY) > Math.abs(deltaX)) {

         return

       }

       // 首先记录歌词的起始位置

       const left = this.currentShow === 'cd' ? 0 : -window.innerWidth

       // 最终就两种状态,left的值有两种状态,如果是cd,就是0

       const offsetWidth = Math.min(0, Math.max(-window.innerWidth, left + deltaX))

       // 假如是左滑,那么dalte是负的

       this.touch.percent = Math.abs(offsetWidth / window.innerWidth)

       //这个percent是维护偏移的距离,>0.1和<0.9

       this.$refs.lyricList.$el.style[transform] = `translate3d(${offsetWidth}px, 0, 0)`

       // lyricList是一个scroll组件,是一个vue组件,通过$el可以获取dom

       this.$refs.lyricList.$el.style[transitionDuration] = 0

       this.$refs.middleL.style.opacity = 1 - this.touch.percent

     },

touchend:

 middleTouchEnd () {

       let offsetWidth

       let opacity

       // 定义offset和opacity

       if (this.currentShow === 'cd') {

         // 如果在cd的情况下

         if (this.touch.percent > 0.1) {

           // 当活动距离超出0.1,做如下操作

           offsetWidth = -window.innerWidth

           opacity = 0

           this.currentShow = 'lyric'

         } else {

           offsetWidth = 0

           opacity = 1

           // 否则回复状态

         }

       } else {

         if (this.touch.percent < 0.9) {

           // 当活动距离小于0.9,做如下操作

           offsetWidth = 0

           opacity = 1

           this.currentShow = 'cd'

         } else {

           offsetWidth = -window.innerWidth

           opacity = 0

         }

       }

       const time = 300

       this.$refs.lyricList.$el.style[transform] = `translate3d(${offsetWidth}px, 0, 0)`

       // 改变他的位置

       this.$refs.lyricList.$el.style[transitionDuration] = `${time}ms`

       // 过渡的时间,在move的时候要清零

       this.$refs.middleL.style.opacity = opacity

       this.$refs.middleL.style[transitionDuration] = `${time}ms`

     },

解决歌词不断跳动:实际上就是清空lyric中的timer计时器

**if (this.currentLyric) {

        this.currentLyric.stop()

      }**

解决歌词和音乐同步播放:

this.setPlayingState(!this.playing)

      if (this.currentLyric) {

        this.currentLyric.togglePlay()

      }

解决循环播放不会到一开始的问题,在loop的代码如下:

if (this.currentLyric) {

          this.currentLyric.seek(0)

        }

拖动bar的时候,歌词跟着滚动:

播放页歌词的实现:

添加dom

  1. <div class="playing-lyric-wrapper">
  2. <div class="playing-lyric">{{playingLyric}}</div>
  3. </div>

维护一个playLric

然后:在lyric回调的时候设置playingLric

Vue音乐项目笔记(三)的更多相关文章

  1. Vue音乐项目笔记(一)

    看到一位小可爱的手记,这里记录一下自己需要注意的地方的链接 1.手写轮播图(上) https://blog.csdn.net/weixin_40814356/article/details/80298 ...

  2. Vue音乐项目笔记(二)

    1. Vuex https://blog.csdn.net/weixin_40814356/article/details/80347366 编写: 然后,在main.js中引入 在组件中改变stat ...

  3. Vue音乐项目笔记(五)

    1.搜索列表的点击删除.删除全部的交互事件 https://blog.csdn.net/weixin_40814356/article/details/80496097 seach组件中放search ...

  4. Vue音乐项目笔记(四)(搜索页面提取重写)

    1.如何通过betterScroll组件实现上拉刷新 https://blog.csdn.net/weixin_40814356/article/details/80478440 2.搜索页面跳转单曲 ...

  5. vue 自学项目笔记

    感觉小青推荐的学习网课,  利用vue 仿制一个去哪网, 学习的东西很多, 在食用之前,需要先确保js 和css 过关 js https://www.bilibili.com/video/av3009 ...

  6. [Vue音乐项目] 第一节 环境搭建

    1.Node安装 登录官网,下载最新版本并安装: 在我的电脑内,执行以下操作:右键->属性->高级->环境变量->系统变量->path 查看是否有node的安装路径,没有 ...

  7. 从无到有构建vue实战项目(三)

    四.响应式布局的实现 elemnt-ui参考bootatrap提供了响应式布局,附上地址:https://element.eleme.cn/#/zh-CN/component/layout 以下是我的 ...

  8. ASP.Net MVC OA项目笔记<三>

    1.1.1 业务层和数据层之间加一个数据会话层,封装所有数据操作类实例的创建(工厂类) 工厂类是负责对象的创建 作用:将BLL和DAL解耦了,提供一个数据访问的统一访问点 数据会话层DBSession ...

  9. cocos2dx打飞机项目笔记三:HeroLayer类和坐标系

    HeroLayer类主要是处理hero的一些相关东西,以及调用bulletLayer的一些方法,因为子弹是附属于hero的~~ HeroLayer 类的成员如下: class HeroLayer : ...

随机推荐

  1. luogu1387 最大正方形

    P1387 最大正方形 正方形O(n) 题目描述 在一个n*m的只包含0和1的矩阵里找出一个不包含0的最大正方形,输出边长. 输入输出格式 输入格式: 输入文件第一行为两个整数n,m(1<=n, ...

  2. JZ2440之GPIO篇

    买来开发板已经有一段时间了,刚接触时兴奋至极,后来跟着视频看下去发现似乎自己并没有学到太多东西,于是发现自己可能欠缺的太多以致从课程中无法提取出重要的东西来,所以并没有得到太多的营养成分.因此我个人认 ...

  3. 【ASP.NET】System.Web.Routing - HttpMethodConstraint Class

    你可以自己定义你的ASP.NET程序接收的get post put 或者delete请求. 使用这个约束的方式为: void Application_Start(object sender, Even ...

  4. Git-Flow | How it’s used and why you should

    Git-Flow | How it’s used and why you should What is Git-Flow about? Git-Flow is a workflow for using ...

  5. HDU 2612 Find a way(找条路)

    HDU 2612 Find a way(找条路) 00 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)   Problem  ...

  6. ie 支持字体大小继承

    今天需要实现字体大小继承这个效果.是这样的,在公用类里 .box 中的 .box1 的字体进行了修改.但是我的页面里不需要修改.我需要让他和 .box 一样.所以想到使用继承.但是想到继承这个属性兼容 ...

  7. RN 调用安卓的原生方法(实现Toast效果)

    首先明确一点,坑实在是是太多了-神奇呀! ok! 基本思路: 1.用AS打开一个已经存在的项目(这里可以打开项目中的android也可以是android里面的build.gradle) 2.在AS里新 ...

  8. 烽火HG220G-U E00L2.03M2000光猫改桥接教程

    烽火HG220G-U E00L2.03M2000光猫改桥接教程 P.S. 此教程同样适用于HG221G/HG260G-U/HG261G.(2016.12) 随着北京联通从原有的ONU升级到HGU之后, ...

  9. Codeforces 746 G. New Roads

    题目链接:http://codeforces.com/contest/746/problem/G mamaya,不知道YY了一个什么做法就这样过去了啊 2333 首先我显然可以随便构造出一棵树满足他所 ...

  10. hdu 6169 Senior PanⅡ Miller_Rabin素数测试+容斥

    Senior PanⅡ Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 524288/524288 K (Java/Others) Pr ...