jQuery+canvas实现的球体平抛及颜色动态变换效果


Posted in Javascript onJanuary 28, 2016

本文实例讲述了jQuery+canvas实现的球体平抛及颜色动态变换效果。分享给大家供大家参考,具体如下:

运行效果截图如下:

jQuery+canvas实现的球体平抛及颜色动态变换效果

具体代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>canvas平抛</title>
  <script src="jquery-1.7.1.min.js" type="text/javascript"></script>
  <script type="text/javascript" >
    var canvasHeight = 300;
    var canvasWidth = 300;
    var g = 9.8;
    //x, y, vo, r
    function HorizenCast(context, settings) {
      var _self = this;
      $.extend(_self, settings);
      _self.xo = _self.x;
      _self.yo = _self.y;
      HorizenCast.createColor = function () {
        var r = Math.round(Math.random() * 256),
          g = Math.round(Math.random() * 256),
          b = Math.round(Math.random() * 256);
        return "rgb("+r+","+g+","+b+")";
      }
      _self.cast = function () {
        if (_self.x > canvasWidth - _self.r || _self.y > canvasHeight - _self.r) {
          return;
        }
        var time = (new Date().getTime() - _self.prevTime) / 1000,
          x = _self.xo +_self.vo * time,
          y = _self.yo + 1 / 2 * g * time * time;
        context.beginPath();
        context.fillStyle = HorizenCast.createColor();
        context.arc(_self.x, _self.y, _self.r, 0, 2 * Math.PI);
        context.fill();
        context.closePath();
        _self.x = x;
        _self.y = y;
        setTimeout(function () {
          _self.cast();
        }, 30);
      }
      _self.prevTime = new Date().getTime();
      _self.cast();
    }
    $(document).ready(function () {
      var canvas = document.getElementById("canvas");
      var context = canvas.getContext('2d');
      new HorizenCast(context, { x: 0, y: 0, vo: 100, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 90, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 80, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 70, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 60, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 50, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 40, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 30, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 20, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 10, r: 5 });
      new HorizenCast(context, { x: 0, y: 0, vo: 5, r: 5 });
    });
  </script>
  <style type="text/css" >
  h2 { color:Gray; line-height:50px; }
  #canvas { background:#DDDDDD;}
  </style>
</head>
<body>
 <center>
 <h3>canvas实现平抛效果</h3>
 <hr />
 <canvas id="canvas" width="300" height="300"></canvas>
 <hr />
 </center>
</body>
</html>

希望本文所述对大家jQuery程序设计有所帮助。

Javascript 相关文章推荐
Firefox getBoxObjectFor getBoundingClientRect联系
Oct 26 Javascript
ExtJs事件机制基本代码模型和流程解析
Oct 24 Javascript
JS控制一个DIV层在指定时间内消失的方法
Feb 17 Javascript
input标签内容改变的触发事件介绍
Jun 18 Javascript
jQuery插件实现图片轮播特效
Jun 16 Javascript
详解js运算符单竖杠“|”与“||”的用法和作用介绍
Nov 04 Javascript
基于JavaScript实现活动倒计时效果
Apr 20 Javascript
Angular 2.0+ 的数据绑定的实现示例
Aug 09 Javascript
删除table表格行的实例讲解
Sep 21 Javascript
原生JS实现图片无缝滚动方法(附带封装的运动框架)
Oct 01 Javascript
详解webpack-dev-server使用方法
Sep 14 Javascript
详解用场景去理解函数柯里化(入门篇)
Apr 11 Javascript
jQuery+canvas实现简单的球体斜抛及颜色动态变换效果
Jan 28 #Javascript
基于javascript实现动态显示当前系统时间
Jan 28 #Javascript
jQuery实现div随意拖动的实例代码(通用代码)
Jan 28 #Javascript
jQuery+css实现炫目的动态块漂移效果
Jan 28 #Javascript
使用node+vue.js实现SPA应用
Jan 28 #Javascript
jQuery+css实现的tab切换标签(兼容各浏览器)
Jan 28 #Javascript
javascript实现随机显示星星特效
Jan 28 #Javascript
You might like
PHP中session跨子域的三种实现方法
2016/07/25 PHP
Laravel5.1 框架表单验证操作实例详解
2020/01/07 PHP
js prototype 格式化数字 By shawl.qiu
2007/04/02 Javascript
jQuery 对Select的操作备忘记录
2011/07/04 Javascript
javascript使用onclick事件改变选中行的颜色
2013/12/30 Javascript
JS和函数式语言的三特性
2014/03/05 Javascript
JavaScript中使用typeof运算符需要注意的几个坑
2014/11/08 Javascript
浅谈javascript中的加减时间
2016/07/12 Javascript
基于jQuery实现照片墙自动播放特效
2017/01/12 Javascript
JavaScript判断浏览器和hack滚动条的写法
2017/07/23 Javascript
JavaScript定义函数的三种实现方法
2017/09/23 Javascript
zTree 树插件实现全国五级地区点击后加载的示例
2018/02/05 Javascript
JS中touchstart事件与click事件冲突的解决方法
2018/03/12 Javascript
vue-cli脚手架-bulid下的配置文件
2018/03/27 Javascript
node puppeteer(headless chrome)实现网站登录
2018/05/09 Javascript
Vue中使用ElementUI使用第三方图标库iconfont的示例
2018/10/11 Javascript
详解如何使用微信小程序云函数发送短信验证码
2019/03/13 Javascript
Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验
2019/04/22 Javascript
使用vscode快速建立vue模板过程详解
2019/10/10 Javascript
详解React中共享组件逻辑的三种方式
2021/02/02 Javascript
Python实现批量把SVG格式转成png、pdf格式的代码分享
2014/08/21 Python
Python的Django框架中的数据库配置指南
2015/07/17 Python
Python中pillow知识点学习
2018/04/30 Python
Pandas GroupBy对象 索引与迭代方法
2018/11/16 Python
详解Python使用Plotly绘图工具,绘制甘特图
2019/04/02 Python
python如何制作英文字典
2019/06/25 Python
keras:model.compile损失函数的用法
2020/07/01 Python
美国帽子俱乐部商店:Hat Club
2019/07/05 全球购物
哈萨克斯坦最大的时装、鞋子和配饰在线商店:Lamoda.kz
2019/11/19 全球购物
上海雨人软件技术开发有限公司测试题
2015/07/14 面试题
焊接专业毕业生求职信
2013/10/01 职场文书
实习生个人的自我评价
2013/12/08 职场文书
求职面试个人自我评价
2014/02/28 职场文书
优秀本科毕业生自荐信
2014/07/04 职场文书
质监局领导班子践行群众路线整改方案
2014/10/26 职场文书
辩论会主持词
2015/07/03 职场文书