Canvas 的进度条操作及代码

news/2024/11/15 0:29:02/

canvas需要进度条么?答案显然是肯定的。我们的页面如果放到服务器上,图片的下载将是相当漫长的一个过程。如果我们不进行预加载就开始执行动画的话,那么用户肯定看不到理想的效果。

今天和大家探讨canvas动画框架之图片预加载,如上图的进度条,这可不是假的进度条,是真正能够实时获取图片加载进度的进度条

为什么想要做这个进度条呢?canvas需要进度条么?答案显然是肯定的。我们的页面如果放到服务器上,图片的下载将是相当漫长的一个过程。如果我们不进行预加载就开始执行动画的话,那么用户肯定看不到理想的效果。

那么我们就来看看canvas图片预加载的实现

/*star  *loading模块  *实现图片的预加载,并显示进度条  *参数:图片数组对象,加载完成的回调函数  */  
function loadImages(sources,callback){      var loadedImages = 0;      var numImages = 0;    ctx.font='14px bold';  ctx.lineWidth=5;  var clearWidth=canvas.width;  var clearHeight=canvas.height;  // get num of sources      for (var src in sources) {      numImages++;      }      for (var src in sources) {      images[src] = new Image();  //当一张图片加载完成时执行      images[src].onload = function(){   //重绘一个进度条  ctx.clearRect(0,0,clearWidth,clearHeight);  ctx.fillText('Loading:'+loadedImages+'/'+numImages,200,280);  ctx.save();  ctx.strokeStyle='#555';  ctx.beginPath();  ctx.moveTo(200,300);  ctx.lineTo(600,300);  ctx.stroke();  ctx.beginPath();  ctx.restore();  ctx.moveTo(200,300);  ctx.lineTo(loadedImages/numImages*400+200,300);    ctx.stroke();  //当所有图片加载完成时,执行回调函数callback  if (++loadedImages >= numImages) {      callback();      }      };    //把sources中的图片信息导入images数组    images[src].src = sources[src];      }      
}      
//定义预加载图片数组对象,执行loading模块  
window.onload = function(){      var sources = {      PaperBoy1: "images/run/PaperBoy1.png",      PaperBoy2: "images/run/PaperBoy2.png",   PaperBoy3: "images/run/PaperBoy3.png",      PaperBoy4: "images/run/PaperBoy4.png",    PaperBoy5: "images/run/PaperBoy5.png",      PaperBoy6: "images/run/PaperBoy6.png",    PaperBoy7: "images/run/PaperBoy7.png",      PaperBoy8: "images/run/PaperBoy8.png",    PaperBoy9: "images/run/PaperBoy9.png",      PaperBoy10: "images/run/PaperBoy10.png",    PaperBoy11: "images/run/PaperBoy11.png",      PaperBoy12: "images/run/PaperBoy12.png",     PaperBoy13: "images/run/PaperBoy13.png",      PaperBoy14: "images/run/PaperBoy14.png",   PaperBoy15: "images/run/PaperBoy15.png",      PaperBoy16: "images/run/PaperBoy16.png",    PaperBoy17: "images/run/PaperBoy17.png",      PaperBoy18: "images/run/PaperBoy18.png",    PaperBoy19: "images/run/PaperBoy19.png",      PaperBoy20: "images/run/PaperBoy20.png",    PaperBoy21: "images/run/PaperBoy21.png",      PaperBoy22: "images/run/PaperBoy22.png",    PaperBoy23: "images/run/PaperBoy23.png",      PaperBoy24: "images/run/PaperBoy24.png",   _Street:'images/_Street.png',  AD:'images/AD.png',  building:'images/building.png',  cloud:'images/cloud.png'  };      //执行图片预加载,加载完成后执行main  loadImages(sources,main);      
};     
/*end*/ 

当windows.onload发生后,我们定义一个存储着所有图片信息的对象sources,然后把它传入loadImages这个方法里。

重点是看看loadImages这个方法,它有两个参数,一个是存储的图片信息的sources,一个是回调函数callback(一旦图片加载完毕,即执行callback。我们这里执行的是main函数,意味着动画开始初始化)

总图片数我们存在numImages里面:

// 首先遍历数组,计算出总图片数      for (var src in sources) {      numImages++;      }     

其实这个方法的核心就是给每张图片添加一个onload事件。

当每张图片加载完成后,我们做了三件事:

1.计算出加载完成图片与总图片的百分比;

2.然后画出一个用户可见的进度条,告诉用户加载的进度;

3.做判断看图片是否加载完,如加载完了就执行callback,否则返回error。

结构如下:

//当一张图片加载完成时执行  images[src].onload = function(){  //计算出加载图片数,并根据总图片数,算出百分比  //画出进度条  //if图片加载完毕,则执行callback
} 

http://www.ppmy.cn/news/1501407.html

相关文章

【音视频】RTSP、RTMP与流式传输

文章目录 前言RTSP与RTMPRTSP(Real-Time Streaming Protocol)RTMP(Real-Time Messaging Protocol)主要差异 什么是流式传输?流式传输的特点流式传输与传统下载的区别 使用VLC播放RTSP监控 总结 前言 在现代网络环境中…

【解决方案】华普微汽车智能钥匙解决方案

一、方案概述 1.什么是被动式无钥匙进入 "被动式无钥匙进入"(Passive Keyless Entry)是一种用于车辆、建筑物或其他设施的访问控制系统。它利用无线射频技术自动判断用户是否接近,并进行身份识别以执行开锁或落锁动作&#xff0c…

VSCode 命令行使用 git commit 无法输入中文

1. 问题描述 在使用 VSCode 的集成终端(Terminal)进行 git commit -m feat:xxx 操作时,发现 xxx 的位置只能编写英文,无法输入中文或者输入中文后出现问题。 这通常与终端编码设置、VSCode 的配置或者操作系统设置有…

InternLM-L0 Python作业

任务类型 任务内容 闯关任务 Python实现wordcount 闯关任务 Vscode连接InternStudio debug笔记 1. Python实现wordcount 基于作业 InternLM-L0 linux作业 ,创建Python文件输入如下代码,并用Python 脚本运行: text """ Go…

BCH码误码率ber性能仿真(MATLAB)

BCH码 不同于奇偶校验码只能检验数据传输是否出错,BCH码可以实现对数据的检验和纠错 BCH(n,k)中的n代表总码元,k代表有效码元,相应的n-k即代表纠错码元 本文着重比较分析BCH(255,207),BCH(255,131),BCH(255…

【redis】一致性hash算法和hash槽

普通hash取模 直接hash(key)%N , N为机器的数量,但不利于集器扩容或者缩容 一致性hash算法和hash槽 一致性hash算法是在redis 分片中使用,hash槽在redis cluster(集群)中使用 Redis一致性hash:Redis一致性hash是为…

福昕高级PDF编辑器专业版 v2024 授权版

福昕高级PDF编辑器是一款功能强大的PDF文件编辑软件,提供多种实用的编辑功能。 软件功能: 1. PDF文档编辑:用户可编辑PDF文档内容,包括文字、图片、表格、图形等,且不会对原有文本内容造成影响。 2. 批注工具&#x…

免费【2024】springboot 宠物救助管理系统的设计与实现

博主介绍:✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流✌ 技术范围:SpringBoot、Vue、SSM、HTML、Jsp、PHP、Nodejs、Python、爬虫、数据可视化…