热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

canvas动画科技园_Canvas动画

1:Canvas动画原理快速切换的静态画面。2:基本步骤绘制-清空-绘制-清空-绘制3:控制函数setTimeoutsetInter

1:Canvas动画原理

快速切换的静态画面。

2:基本步骤

绘制 - 清空 - 绘制 - 清空 - 绘制 ...

3:控制函数

setTimeout

setInterval

requestAnimationFrame

4:四种运动

线性运动

const canvas = document.getElementById('canvas');

/* 获得 2d 上下文对象 */

const ctx = canvas.getContext('2d');

let radialGradient;

let distance = -50;

const speed = 5;

const draw = (axisX) => {

/* 清空画布(或部分清空) */

ctx.clearRect(0, 0, 600, 600);

radialGradient = ctx.createRadialGradient(distance, 300, 10, distance, 300, 50);

radialGradient.addColorStop(0, "#FFFFFF");

radialGradient.addColorStop(1, "#EA7F26");

ctx.fillStyle = radialGradient;

ctx.beginPath();

ctx.moveTo(distance, 300);

ctx.arc(distance, 300, 50, 0, 2 * Math.PI, false);

ctx.fill();

distance = distance + speed;

if (distance > 650) distance = -50;

requestAnimationFrame(draw);

}

requestAnimationFrame(draw);ctx.clearRect(0, 0, 600, 600);

ctx.beginPath();

ctx.moveTo(distance, 300);

ctx.arc(distance, 300, 50, 0, 2 * Math.PI, false);

ctx.fill();

distance = distance + speed;

1562828132710.png

从左到右匀速运动

变速运动

const canvas = document.getElementById('canvas');

/* 获得 2d 上下文对象 */

const ctx = canvas.getContext('2d');

let radialGradient;

let distance = 50;

const speed = 5;

let count = 1;

/*

* h = 9.8 * (Math.pow(t, 2)) / 2

*/

const draw = (axisX) => {

/* 清空画布(或部分清空) */

ctx.clearRect(0, 0, 600, 600);

radialGradient = ctx.createRadialGradient(300, distance, 10, 300, distance, 50);

radialGradient.addColorStop(0, "#FFFFFF");

radialGradient.addColorStop(1, "#EA7F26");

ctx.fillStyle = radialGradient;

ctx.beginPath();

ctx.moveTo(300, distance);

ctx.arc(300, distance, 50, 0, 2 * Math.PI, false);

ctx.fill();

count += 1;

distance = 9.8 * (Math.pow(count, 2)) / 100;

if (distance > 650) {

distance = -50;

count = 1;

}

requestAnimationFrame(draw);

}

requestAnimationFrame(draw);

1562828262986.png

从上到下模拟自由落体运动

函数运动(正弦)

const canvas = document.getElementById('canvas');

/* 获得 2d 上下文对象 */

const ctx = canvas.getContext('2d');

let radialGradient;

let distance = 0;

let axis = 300;

const speed = 5;

const range = 200;

let angle = 0;

const draw = (axisX) => {

/* 清空画布(或部分清空) */

// ctx.clearRect(0, 0, 600, 600);

radialGradient = ctx.createRadialGradient(distance, axis, 10, distance, axis, 50);

radialGradient.addColorStop(0, "#FFFFFF");

radialGradient.addColorStop(1, "#EA7F26");

ctx.fillStyle = radialGradient;

ctx.beginPath();

ctx.moveTo(distance, axis);

ctx.arc(distance, axis, 50, 0, 2 * Math.PI, false);

ctx.fill();

axis = 300 + Math.sin(angle) * range;

distance = distance + speed;

if (distance > 650) {

distance = 0;

angle = -.1;

}

angle += .1;

requestAnimationFrame(draw);

}

requestAnimationFrame(draw);

1562828002904.png

环形运动

const canvas = document.getElementById('canvas');

/* 获得 2d 上下文对象 */

const ctx = canvas.getContext('2d');

let radialGradient;

let angle = 0.1;

var scope = 20;

let x = 300;

let y = 100;

const draw = (axisX) => {

/* 清空画布(或部分清空) */

ctx.clearRect(0, 0, 600, 600);

radialGradient = ctx.createRadialGradient(x, y, 10, x, y, 50);

radialGradient.addColorStop(0, "#FFFFFF");

radialGradient.addColorStop(1, "#EA7F26");

ctx.fillStyle = radialGradient;

ctx.beginPath();

ctx.moveTo(x, y);

ctx.arc(x, y, 50, 0, 2 * Math.PI, false);

ctx.fill();

x = x + Math.cos(angle) * scope;

y = y + Math.sin(angle) * scope;

angle = angle + .1;

requestAnimationFrame(draw);

ctx.closePath();

ctx.beginPath();

ctx.arc(300, 300, 200, 0, 2 * Math.PI, false);

ctx.stroke();

}

requestAnimationFrame(draw);

1562827970399.png



推荐阅读
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
author-avatar
圊渘湜壞亾
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有