基本动画的步骤 Basic animation steps

用canvas画一帧动画,通常需要以下四个步骤:

1.  清空 canvas

除非接下来要画的内容会完全充满 canvas (例如背景图),否则你需要清空所有。最简单的做法就是用 clearRect 方法。

2. 保存 canvas 状态

如果你要改变一些会改变 canvas 状态的设置(样式,变形之类的),又要在每画一帧之时都是原始状态的话,你需要先保存一下。

3. 绘制动画图形(animated shapes)

这一步才是重绘动画帧。

4. 恢复 canvas 状态

如果已经保存了 canvas 的状态,可以先恢复它,然后重绘下一帧。

在操作动画过程中,我们需要一些可以定时执行重绘的方法。有两种方法可以实现这样的动画操控:

第一种方法:可以通过 setInterval 和 setTimeout 方法来控制在设定的时间点上执行重绘。

第二种方法:我们可以利用用户输入来实现操控。如果需要做一个游戏,我们可以通过监听用户交互过程中触发的事件(如 keyboard,mouse)来控制动画效果。

下面是用第一种方法实现的一个时钟动画:

It's a clock here

效果图如下:

html画布时钟添加背景图,用HTML5 Canvas 实现的 时钟相关推荐

  1. ps怎么把图片背景变透明_ps怎么添加背景?ps怎么添加背景图?

    PS添加背景图的教程: 1.打开Adobe Photoshop.这是一个蓝色应用图标,其中包含字母" Ps". 2.单击文件.它位于屏幕顶部菜单栏的左侧. 3.点击打开....它在 ...

  2. echarts添加背景图

    echarts添加背景图 来源:https://www.liuyjuan.com/295.html 1)简单的方法 直接给到外层的div元素上 /*比如说这段css样式*/ .TheStatistic ...

  3. MFC 对话框添加背景图

    // 给对话框添加背景图 BOOL CEditCtrlMultilineDlg::OnEraseBkgnd(CDC* pDC) {// TODO: 在此添加消息处理程序代码和/或调用默认值CDC Me ...

  4. 如何在eclipse制作的APP中添加背景图

    如何在eclipse制作的APP中添加背景图 1.首先把图片拉入drawable-hdpi中,a1.jpg(注:图片名不可为中文) 2.在.xml文件中加入android:background=&qu ...

  5. Android studio -添加背景图

    一. 新建工程 二. 选择Empty Activity 三. 填写项目名称并选择Android系统版本 四. 这样一个工程就建好了 五. 接下来找到一张图片复制(相片名称要英文字母开头) 六. 然后粘 ...

  6. Qt中代码添加背景图

    第一步 选择一张背景图下到本地 第二步 在qt中点击添加新文件选择图中位置 随便起个名字,点击下一步 这时项目中多出一个目录 选择打开资源编辑器 底部添加前缀:注意该前缀是在内部使用图的路径 点击添加 ...

  7. cesium: 设置skybox透明并添加背景图 ( 003 )

    第003个 点击查看专栏目录 本示例的目的是介绍如何在vue+cesium中设置skybox透明并添加背景图. 我们不想要黑乎乎的背景,想自定义一个背景图,然后前面显示地球. 直接复制下面的 vue+ ...

  8. 在php中怎么给表格加背景,怎么在表格中添加背景图

    看别人的表格添加了背景图片是不是特别好看,那么你想不想学会这项技能呢?下面有两种方法让你快速对表格添加背景图,让我们一起学习一下吧! 1.改良背景法为表格添加背景图 做完一个表格,有时我们会觉得其比较 ...

  9. Android 高德地图在地图上面添加背景图和设置滑动范围

    高德地图:在地图上面添加背景图和设置滑动范围 因为我这边开发的是景区,所以在地图上面景区的位置就添加了一个景区的背景图,代码如下: if (!mMapBgImg.contains("http ...

最新文章

  1. matlab inviter,水中石
  2. 美颜算法之自动祛斑算法实现 | 案例分享
  3. python函数拟合不规则曲线_python 对任意数据和曲线进行拟合并求出函数表达式的三种解决方案...
  4. 商品领域ddd_DDD领域驱动实战 - 限界上下文(bounded context)
  5. exec 执行结果_php执行系统外部命令的4种方法
  6. 开发辅助 | 阿里图标库iconfont入门使用
  7. jdbc连接oracle的几种格式
  8. python可以计算复杂积分吗_python – Scipy:加快2D复数积分的计算
  9. 基于mysql的springmvcjar_糊涂jar_SpringMVC+Spring+Mybatis项目实战[SSM/MySQL/AJAX/IDEA]_Java视频-51CTO学院...
  10. 1月29日云栖精选夜读 | 拿下两个世界第一,阿里人机对话模型成人工智能国际通用标准...
  11. 开源日志系统log4cplus(三)
  12. 图像处理六:预处理方法
  13. 【语音识别】基于matlab GUI MFCC+VQ说话人识别系统【含Matlab源码 1153期】
  14. 高校后勤管理系统java代码_java毕业设计_springboot框架的高校后勤信息管理系统...
  15. Flutter 旋转动画
  16. 汇编程序——根据开关状态在7段数码管上显示数字或者字符
  17. 7.基本数据类型详细讲解-int/bool/str
  18. 如何从Gitlab上拉取代码
  19. 苹果mac系统下浏览器video无法自动播放问题
  20. itunes下载的软件怎么安装到手机

热门文章

  1. 课堂笔记_ 光线跟踪加速
  2. 例题5.23 蚂蚁 LA4043
  3. 踢球骨折在家day7
  4. MyBatis学习(二)--利用MyBatis实现CRUD操作
  5. Power BI+Power Apps联动初尝试
  6. 双复合摆的动力学【牛顿法---拉格朗日法】两种方式
  7. 通过身份证号得到年龄、性别和出生日期
  8. 客户体验模型|客户体验分析的四个关键要素
  9. 优雅地使用eruda在移动端上调试网页
  10. sql查询包含某个字符_MySQL DBA基本知识点梳理和查询优化