vue实现轮播图帧率播放


Posted in Vue.js onJanuary 26, 2021

本文实例为大家分享了vue实现轮播图帧率播放的具体代码,供大家参考,具体内容如下

需求

传入一个数组,数组中放的是目录名称,通过本目录名称,读取文件目录下的所有图片,并循环播放,形成一个每1s播放多少张图片的效果,最后目录播放完毕后,在跳到第一个目录循环播放。

核心: 用 webpack的一个API require.contex读取目录下的文件名,具体想了解的可以查一查。

代码

HTML

<template>
 <div id="imgPlay" ref="container" :style="[style]">
 <img :src="imgsrc" :style="[{height:style.height,width:style.width}]">
 <div id="but">
  <button @click="start()">开始</button>
  <button @click="stop()">停止</button>
 </div>
 </div>
</template>

javascript

<script>
export default {
 name: 'ZxImgPlay',
 data () {
 return {
  style:[
 width:"50px",
 height:"50px"
 ],
  interval: null, // 定时器id
  flag: true, // 定时器的开关
  setIntervalNumber: 0, // 当前展示的图片下标
  imgsrc: "", // 要展示的图片路径
  imgUrls: [], // 所有的图片路径
  frameRate: 0 // 帧率
 }
 },
 computed: {},
 watch: {},
 created () { },
 mounted () {
 this.zxInit()
 },
 beforeDestroy () { },

 methods: {
 zxInit () {
 // 这里的 this.DisplayParam 是公司内部的一套东西,混入的对象
 // this.DisplayParam.frameRate 是一个数组["目录名1","目录名2"]
 // this.DisplayParam.imgUrls 是死图当没有目录的时候就用死图
 // this.DisplayParam.frameRate 是传入的帧率
  this.frameRate = this.DisplayParam.frameRate && (1000 / this.DisplayParam.frameRate)
  this.imgUrls = this.DisplayParam.imgUrls
  this.DisplayParam.imageFileName != 0 ? this.readdir(this.DisplayParam.imageFileName) : this.showImages(true)
 },

 start () {
  if (this.flag) return
  this.showImages()
  this.flag = true
 },

 stop () {
  this.flag = false
  clearInterval(this.interval)
 },

 readImages (imageFileName, _A) {
  this.stop()
  let req = require.context("@/../static/images", true, /\.(?:bmp|jpg|gif|jpeg|png)$/).keys();
  let path = new RegExp(imageFileName[_A])
  req.forEach(item => {
  if (path.test(item)) {
   this.imgUrls.push({ img: "@/../static/images/" + imageFileName[_A] + item.substring(item.lastIndexOf('/')) })
  }
  })
  this.showImages()
 },
 readdir (imageFileName) {
  this.imgUrls = []
  for (let i = 0; i < imageFileName.length; i++) {
  this.readImages(imageFileName, i)
  }
 },

 showImages (_B) {
  if (_B) this.imgUrls = this.imgUrlsSort(this.imgUrls, 'sort')
  console.log(this.imgUrls)
  this.interval = setInterval(this.setIntervalFun, this.frameRate)
 },

 imgUrlsSort (ary, key) {
  return ary.sort((a, b) => {
  let x = a[key];
  let y = b[key];
  return ((x < y) ? -1 : (x > y) ? 1 : 0)
  })
 },

 setIntervalFun () {
  if (this.setIntervalNumber >= this.imgUrls.length) {
  this.setIntervalNumber = 0
  }
  this.imgsrc = this.imgUrls[this.setIntervalNumber++].img || ''
 }
 }
}
</script>

问题

上述这么做已经实现了功能,但是目前来说是发现了两个问题

1、require.context() 这个API它的第一个参数不能用一个可变的值,比如变量,会有警告。
2、上述代码一直更换图片的src实现的,也就是说每次换src时都会发送http请求获取图片,导致了内存不会被释放一直增加。

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

Vue.js 相关文章推荐
vue使用exif获取图片经纬度的示例代码
Dec 11 Vue.js
vue 数据操作相关总结
Dec 17 Vue.js
Vue实现随机验证码功能
Dec 29 Vue.js
vue-cli4.0多环境配置变量与模式详解
Dec 30 Vue.js
vue3自定义dialog、modal组件的方法
Jan 04 Vue.js
详解为什么Vue中的v-if和v-for不建议一起用
Jan 13 Vue.js
Vue中的nextTick作用和几个简单的使用场景
Jan 25 Vue.js
vue-video-player 断点续播的实现
Feb 01 Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 Vue.js
如何在 Vue 中使用 JSX
Feb 14 Vue.js
vue 动态添加的路由页面刷新时失效的原因及解决方案
Feb 26 Vue.js
vue组件vue-esign实现电子签名
Apr 21 Vue.js
vue 组件基础知识总结
Jan 26 #Vue.js
深入了解Vue动态组件和异步组件
Jan 26 #Vue.js
如何在 Vue 表单中处理图片
Jan 26 #Vue.js
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 #Vue.js
Vue中的nextTick作用和几个简单的使用场景
Jan 25 #Vue.js
Vue使用Ref跨层级获取组件的步骤
Jan 25 #Vue.js
如何在Vue项目中添加接口监听遮罩
Jan 25 #Vue.js
You might like
从零开始的异世界生活:第二季延期后,B站上架了第二部剧场版
2020/05/06 日漫
PHP开发的一些注意点总结
2010/10/12 PHP
php数组(array)输出的三种形式详解
2013/06/05 PHP
深入php list()函数的详解
2013/06/05 PHP
PHP中session变量的销毁
2014/02/27 PHP
PHP的CURL方法curl_setopt()函数案例介绍(抓取网页,POST数据)
2016/12/14 PHP
PHP基于imagick扩展实现合成图片的两种方法【附imagick扩展下载】
2017/11/14 PHP
laravel 出现command not found问题的解决方案
2019/10/23 PHP
浅析PHP中json_encode与json_decode的区别
2020/07/15 PHP
基于php伪静态的实现方法解析
2020/07/31 PHP
javascript使用activex控件的代码
2011/01/27 Javascript
详解Bootstrap按钮
2016/01/04 Javascript
浅谈JS函数定义方式的区别
2016/10/30 Javascript
jQuery EasyUI中的日期控件DateBox修改方法
2016/11/09 Javascript
laravel5.4+vue+element简单搭建的示例代码
2017/08/29 Javascript
Node.js使用cookie保持登录的方法
2018/05/11 Javascript
ng-events类似ionic中Events的angular全局事件
2018/09/05 Javascript
微信小程序日历弹窗选择器代码实例
2019/05/09 Javascript
vue请求数据的三种方式
2020/03/04 Javascript
vue监听dom大小改变案例
2020/07/29 Javascript
Python中实现参数类型检查的简单方法
2015/04/21 Python
python列表操作之extend和append的区别实例分析
2015/07/28 Python
Python实现视频下载功能
2017/03/14 Python
Python使用回溯法子集树模板解决迷宫问题示例
2017/09/01 Python
详解pandas如何去掉、过滤数据集中的某些值或者某些行?
2019/05/15 Python
html5自动播放mov格式视频的实例代码
2020/01/14 HTML / CSS
俄罗斯电子产品、计算机和家用电器购物网站:OLDI
2019/10/27 全球购物
信息技术专业大学生个人的自我评价
2013/10/05 职场文书
护士思想汇报
2014/01/12 职场文书
精神文明建设先进工作者事迹材料
2014/05/02 职场文书
大学自主招生推荐信
2014/05/10 职场文书
奥巴马获胜演讲稿
2014/05/15 职场文书
2014机关干部学习“焦裕禄精神”思想汇报
2014/09/19 职场文书
歌舞青春观后感
2015/06/10 职场文书
居安思危观后感
2015/06/11 职场文书
python爬不同图片分别保存在不同文件夹中的实现
2021/04/02 Python