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+iview实现分页及查询功能
Nov 17 Vue.js
vue-drawer-layout实现手势滑出菜单栏
Nov 19 Vue.js
vuex页面刷新导致数据丢失的解决方案
Dec 10 Vue.js
vue导入.md文件的步骤(markdown转HTML)
Dec 31 Vue.js
vue-video-player 断点续播的实现
Feb 01 Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 Vue.js
vue使用lodop打印控件实现浏览器兼容打印的方法
Feb 07 Vue.js
使用vue-element-admin框架从后端动态获取菜单功能的实现
Apr 29 Vue.js
Vue-Element-Admin集成自己的接口实现登录跳转
Jun 23 Vue.js
详解Vue的列表渲染
Nov 20 Vue.js
Vue的列表之渲染,排序,过滤详解
Feb 24 Vue.js
Vue.Draggable实现交换位置
Apr 07 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
使用Apache的htaccess防止图片被盗链的解决方法
2013/04/27 PHP
PHP 类相关函数的使用详解
2013/05/10 PHP
php操作xml入门之cdata区段
2015/01/23 PHP
PHP中常用的数组操作方法笔记整理
2016/05/16 PHP
php 7新特性之类型申明详解
2017/06/06 PHP
屏蔽Flash右键信息的js代码
2010/01/17 Javascript
javascript获取当前的时间戳的方法汇总
2015/07/26 Javascript
基于javascript实现文字无缝滚动效果
2016/03/22 Javascript
JS 数字转换为大写金额的简单实例
2016/08/04 Javascript
node网页分段渲染详解
2016/09/05 Javascript
DataTables+BootStrap组合使用Ajax来获取数据并且动态加载dom的方法(排序,过滤,分页等)
2016/11/09 Javascript
JS实现京东首页之页面顶部、Logo和搜索框功能
2017/01/12 Javascript
表格展示利器 Bootstrap Table实例代码
2017/09/06 Javascript
vue 计时器组件的实现代码
2017/09/14 Javascript
Nodejs下使用gm圆形裁剪并合成图片的示例
2018/02/22 NodeJs
JS前端知识点 运算符优先级,URL编码与解码,String,Math,arguments操作整理总结
2019/06/27 Javascript
ES6基础之数组和对象的拓展实例详解
2019/08/22 Javascript
浅谈layui使用模板引擎动态渲染元素要注意的问题
2019/09/14 Javascript
基于axios 的responseType类型的设置方法
2019/10/29 Javascript
Django中URLconf和include()的协同工作方法
2015/07/20 Python
python实现爬虫统计学校BBS男女比例之多线程爬虫(二)
2015/12/31 Python
python snownlp情感分析简易demo(分享)
2017/06/04 Python
OpenCV HSV颜色识别及HSV基本颜色分量范围
2019/03/22 Python
Python 50行爬虫抓取并处理图灵书目过程详解
2019/09/20 Python
tensorflow 查看梯度方式
2020/02/04 Python
英国领先的名牌服装折扣零售商:Brown Bag Clothing
2019/01/08 全球购物
CheapTickets泰国:廉价航班,查看促销价格并预订机票
2019/12/28 全球购物
护士实习鉴定范文
2013/12/22 职场文书
大一学生的职业生涯规划书范文
2014/01/19 职场文书
公司年会主持词
2014/03/22 职场文书
2014年党员公开承诺践诺书
2014/03/25 职场文书
数学系毕业生求职信
2014/05/29 职场文书
文秘应届生求职信
2014/07/05 职场文书
优秀教师先进个人事迹材料
2014/08/31 职场文书
安全温馨提示语大全
2015/07/14 职场文书
详解MySQL中的主键与事务
2021/05/27 MySQL