分享更有价值
被信任是一种快乐

怎么利用HTML5 Canvas制作键盘及鼠标动画

文章页正文上

这篇文章将为大家详细讲解有关怎么利用HTML5 Canvas制作键盘及鼠标动画,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
  键盘控制小球移动
  众所周知,我们所看到的动画实际上就是一系列静态画面快速切换,从而让肉眼因视觉残像产生了「画面在活动」的视觉效果。明白了这一点后,在canvas上绘制动画效果就显得比较简单了。我们只需要将某个静态图形先清除,然后在另外一个位置重新绘制,如此反复,让静态图形按照一定的轨迹进行移动,就可以产生动画效果了。
  下面,我们在canvas上绘制一个实心小球,然后用键盘上的方向键控制小球的移动,从而产生动态效果。示例代码如下:
  JavaScript Code复制内容到剪贴板
  html>
  html5?canvas绘制可移动的小球入门示例
  您的浏览器不支持canvas标签。
  //获取Canvas对象(画布)
  var?canvas?=?document.getElementById(“myCanvas”);
  //表示圆球的类
  function?Ball(x,?y?,radius,?speed){
  this.x?=?x?||?10;?//圆球的x坐标,默认为10
  this.y?=?y?||?10;?//圆球的y坐标,默认为10
  this.radius?=?radius?||?10;?//圆球的半径,默认为10
  this.speed?=?speed?||?5;//圆球的移动速度,默认为5
  //向上移动
  this.moveUp?=?function(){
  this.y?-=?this.speed;
  if(this.y?
  //防止超出上边界
  this.y?=?this.radius;
  }
  };
  //向右移动
  this.moveRight?=?function(){
  this.x?+=?this.speed;
  var?maxX?=?canvas.width?-?this.radius;
  if(this.x?>?maxX){
  //防止超出右边界
  this.x?=?maxX;
  }
  };
  //向左移动
  this.moveLeft?=?function(){
免费云主机、域名  this.x?-=?this.speed;
  if(this.x?
  //防止超出左边界
  this.x?=?this.radius;
  }
  };
  //向下移动
  this.moveDown?=?function(){
  this.y?+=?this.speed;
  var?maxY?=?canvas.height?-?this.radius;
  if(this.y?>?maxY){
  //防止超出下边界
  this.y?=?maxY;
  }
  };
  }
  //绘制小球
  function?drawBall(ball){
  if(typeof?ctx?!=?”undefined”){
  ctx.beginPath();
  ctx.arc(ball.x,?ball.y,?ball.radius,?0,?Math.PI?*?2,?false);
  ctx.fill();
  }
  }
  //清空canvas画布
  function?clearCanvas(){
  if(typeof?ctx?!=?”undefined”){
  ctx.clearRect(0,?0,?400,?300);
  }
  }
  var?ball?=?new?Ball();
  //简单地检测当前浏览器是否支持Canvas对象,以免在一些不支持html5的浏览器中提示语法错误
  if(canvas.getContext){
  //获取对应的CanvasRenderingContext2D对象(画笔)
  var?ctx?=?canvas.getContext(“2d”);
  drawBall(ball);
  }
  //onkeydown事件的回调处理函数
  //根据用户的按键来控制小球的移动
  function?moveBall(event){
  switch(event.keyCode){
  case?37://左方向键
  ball.moveLeft();
  break;
  case?38://上方向键
  ball.moveUp();
  break;
  case?39://右方向键
  ball.moveRight();
  break;
  case?40://下方向键
  ball.moveDown();
  break;
  default://其他按键操作不响应
  return;
  }
  clearCanvas();//先清空画布
  drawBall(ball);?//再绘制最新的小球
  }关于“怎么利用HTML5 Canvas制作键盘及鼠标动画”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

相关推荐: es6中有&符号吗

本篇内容介绍了“es6中有&符号吗”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!有&符号。在es6中,“&&”是逻辑与运算符,是…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册