• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > H5 canvas实现圆形动态加载进度实例

H5 canvas实现圆形动态加载进度实例

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含h5 ,canvas,圆形动态加载等相关知识,匿名希望在学习及工作中可以帮助到您
最近在逛问答的时候,遇到有人问道怎么制作动态的圆形进度功能具体效果如下:




本人的想法有两种,但是利用canvas无疑是最方便的解决办法,在此以canvas实现为例子,具体实现步骤如下:

1.建立前台显示的canvas容器,代码如下:

<span style="font-family:Courier New;font-size:18px;"><!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title>H5 canvas制作圆形动态加载进度实例</title>
		<script src="js/index.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<canvas id="loading" width="300" height="300"></canvas>
	</body>
</html></span>

2.获取canvas容器,建立绘画对象,代码如下:

<span style="font-family:Courier New;font-size:18px;">var loading=document.getElementById('loading');
var context=loading.getContext('2d');</span>


3.绘制初始灰色圆圈,圆圈实际上是由两个同心圆形叠加形成的,代码如下:

<span style="font-family:Courier New;">context.beginPath();//开始路径
context.arc(150,150,150,0,2*Math.PI);//绘制外圈圆
context.fillStyle='#ccc';//设置外圈圆填充颜色
context.fill();//填充颜色
context.beginPath();//开始路径
context.arc(150,150,130,0,2*Math.PI);//绘制内圈圆
context.fillStyle='#fff';//设置内圈圆填充颜色(最好是和背景色相同)
context.fill();//填充颜色</span>

4.加入进度百分比,代码如下:

<span style="font-family:Courier New;">context.fillStyle='#ccc';//设置字体颜色(同样为灰色)
context.font="110px 微软雅黑 ";//设置填充文本的大小和字体(顺序不可改变)</span>

5.根据进度值修改绘画空间大小,代码如下:

<span style="font-family:Courier New;">context.beginPath();//开始路径(这是指绘制空间的路径)
context.rect(0,300*(1-temp),300,300*temp);//根据进度值改变绘制空间大小
context.clip();//根据路径剪切得到新的绘制空间</span>

6.在新的绘制空间绘制进度圆环和进度百分比,代码和之前的几乎一样,只需修改填充颜色,代码如下:

<span style="font-family:Courier New;">context.beginPath();
context.arc(150,150,150,0,2*Math.PI);
context.fillStyle='aquamarine';//设置新的填充颜色
context.fill();
context.beginPath();
context.arc(150,150,130,0,2*Math.PI);
context.fillStyle='#fff';
context.fill();
context.fillStyle='aquamarine';//设置新的填充颜色
context.font="110px 微软雅黑 ";</span>

到此已经完成了静态的圆形进度效果,接下来就是利用定时器修改当前进度值反复绘制即可,但是需要注意的是在外圈圆环和进度百分比添加完后,需要用

<span style="font-family:Courier New;">context.save();</span>

来保存当前回话空间,在所有绘画完成后再利用

<span style="font-family:Courier New;">context.restore();</span>

来还原最初的绘画空间,因为修改绘画空间都是在当前绘画空间下进行剪切得到的,所以每完成一次所有绘画都需要还原到初始的绘画空间,下面是完整的js代码:

<span style="font-family:Courier New;">window.onload=function(){
	var loading=document.getElementById('loading');
	var context=loading.getContext('2d');
	var num=parseInt(Math.random()*100)/100;//模拟获取进度值
	var temp=0;//当前进度值
	var time=1000;//动画总时长
	var step=1000*0.01/num;//动画步长
	function loadanimate(){
		context.beginPath();
		context.arc(150,150,150,0,2*Math.PI);
		context.fillStyle='#ccc';
		context.fill();
		context.beginPath();
		context.arc(150,150,130,0,2*Math.PI);
		context.fillStyle='#fff';
		context.fill();
		context.fillStyle='#ccc';
		context.font="110px 微软雅黑 ";
		if(temp>0.09){//调整文本居中
			context.fillText(parseInt(temp*100)+"%",45,188);
		}else{
			context.fillText(" "+parseInt(temp*100)+"%",45,188);
		}
		context.save();
		
		context.beginPath();
		context.rect(0,300*(1-temp),300,300*temp);
		context.clip();
		
		context.beginPath();
		context.arc(150,150,150,0,2*Math.PI);
		context.fillStyle='aquamarine';
		context.fill();
		context.beginPath();
		context.arc(150,150,130,0,2*Math.PI);
		context.fillStyle='#fff';
		context.fill();
		context.fillStyle='aquamarine';
		context.font="110px 微软雅黑 ";
		if(temp>0.09){
			context.fillText(parseInt(temp*100)+"%",45,188);
		}else{
			context.fillText(" "+parseInt(temp*100)+"%",45,188);
		}
		context.restore();
		setTimeout(function(){
			if(num>temp){
				temp+=0.01;
				loadanimate();
			}
		},step);
	}
loadanimate();
};
</span>

【相关推荐】

1. 分享h5 canvas圆圈进度条的实例代码

2. html5 canvas实现圆形时钟实例代码

3. 总结HTML5中的标签

以上就是H5 canvas实现圆形动态加载进度实例的详细内容,更多请关注微课江湖其它相关文章!

您可能想查找下面的文章:

  • H5实现Tab标签切换效果
  • 分享h5 canvas圆圈进度条的实例代码
  • H5 canvas实现圆形动态加载进度实例
  • H5 的复制操作实例代码
  • H5项目开发iOS插件功能的实例代码
  • h5输入框提示语 + 正常文本框提示语的实现方法
  • 手机端H5 header定义样式

相关文章

  • 2018-12-03CSS3有关特性查询功能的讲解介绍
  • 2018-12-03html5返回音频/视频是否已结束的属性ended
  • 2017-08-06实例讲解HTML5的meta标签的一些应用
  • 2018-12-03如何通俗易懂地向初学者通解释 jQuery、CSS3 和 HTML5 的关系?
  • 2018-12-03如何用HTML5的Canvas制作3D动画效果
  • 2018-12-03HTML5用于创建表单的输入小部件 数据绑定以及数据验证
  • 2018-12-03想做一款基于HTML5的卡牌游戏,有什么好的引擎推荐么?
  • 2018-12-03想学着自己造轮子,该怎样入手?
  • 2018-12-03HTML5游戏框架cnGameJS开发实录-外部输入模块篇
  • 2018-12-03HTML5实践-使用css装饰图片画廊的代码分享(二)

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • html5使用canvas画空心圆与实心圆
    • HTML5使用drawImage()方法绘制图像
    • 有关HTML5服务器推送事件的讲解
    • HTML5每日一练之Canvas标签的应用
    • HTML5边玩边学(2)基础绘图实现方法
    • 使用css3 属性如何丰富图片样式(圆角 阴影 渐变)
    • HTML5视频播放器<video>和音频播放器<audio>用法
    • html5的setCustomValidity的详细介绍
    • 制作动态视觉差背景(h5)的方法
    • 微信内置浏览器对于 HTML5 的支持如何?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有