通过使用HTML5游戏开发的引擎CreatJS,创建HTML5 Canvas上的更好交互。

1、认识CreateJS

CreateJS是一个外部库,用它可以比Canvas更方便的绘制图形。

官网:http://createjs.com/

 <html>
 <head>
     <title></title>
     <script src="easeljs-0.8.2.min.js"></script>
 </head>
 <body>
     <canvas id="canvas" width="500" height="500"></canvas>
     <script src="app.js"></script>
 </body>
 </html>

其中用到的app.js:

 var canvas;
 var stage;
 var txt;
 var count=0;
 window.onload = function() {
     canvas = document.getElementById("canvas");
     stage = new createjs.Stage(canvas);

     txt = new createjs.Text("number->","20px Arial","#ff7700");
     stage.addChild(txt);

     createjs.Ticker.setFPS(30);
     createjs.Ticker.addEventListener("tick",tick);
 }
 function tick(e){
     count++;
     txt.text="number->"+count+"!";
     stage.update();
 }

工程中添加了CreatJS中的easeljs-0.8.2.min.js。

2、使用Canvas制作炫酷的效果

 <!DOCTYPE html>
 <html>
 <head lang="en">
     <meta charset="UTF-8">
     <title></title>
     <script src="easeljs-0.8.2.min.js"></script>
 </head>
 <body>
 <canvas id="canvas" width="1000px" height="500px"></canvas>
 <script src="app.js"></script>
 </body>
 </html>

其中用到的app.js

 /**
  * Created by wwtliu on 14/8/11.
  */
 var canvas;
 var stage;
 var img = new Image();
 var sprite;

 window.onload = function(){
     canvas = document.getElementById("canvas");
     stage = new createjs.Stage(canvas);

     stage.addEventListener("stagemousedown",clickCanvas);
     stage.addEventListener("stagemousemove",moveCanvas);

     var data={
         images:["2.png"],
         frames:{width:20,height:20,regX:10,regY:10}
     }

     sprite  = new createjs.Sprite(new createjs.SpriteSheet(data));
     createjs.Ticker.setFPS(20);
     createjs.Ticker.addEventListener("tick",tick);
 }
 function tick(e){
     var t = stage.getNumChildren();
     for(var i = t-1;i>0;i--){
         var s = stage.getChildAt(i);

         s.vY +=2;
         s.vX +=1;
         s.x += s.vX;
         s.y += s.vY;

         s.scaleX = s.scaleY =s.scaleX+ s.vS;
         s.alpha += s.vA;

         if(s.alpha <= 0 || s.y >canvas.height){
             stage.removeChildAt(i);
         }
     }
     stage.update(e);
 }

 function clickCanvas(e){
     addS(Math.random()*200 + 100,stage.mouseX,stage.mouseY,2);
 }

 function moveCanvas(e){
     addS(Math.random()*2 + 1,stage.mouseX,stage.mouseY,1);
 }

 function addS(count,x,y,speed){
     for(var i = 0;i<count;i++){
         var s = sprite.clone();
         s.x = x;
         s.y = y;
         s.alpha = Math.random()*0.5 + 0.5;
         s.scaleX = s.scaleY = Math.random() +0.3;

         var a = Math.PI * 2 *Math.random();
         var v = (Math.random() - 0.5) *30 *speed;
         s.vX = Math.cos(a) *v;
         s.vY = Math.sin(a) *v;
         s.vS = (Math.random() - 0.5) *0.2; // scale
         s.vA = -Math.random() *0.05 -0.01; // alpha
         stage.addChild(s);
     }
 }

工程中添加了CreatJS中的easeljs-0.8.2.min.js。

[html5] 学习笔记-Canvas应用的更多相关文章

  1. [html5] 学习笔记-Canvas 绘制渐变图形与绘制变形图形

    在 HTML5 中,使用 Canvas API 绘制图形的知识,可以对绘制图形进行处理,包含使用 Canvas API 绘制渐变图形,使用 Canvas API 的坐标轴变换处理功能绘制变形图形.其中 ...

  2. [html5] 学习笔记-Canvas标签的使用

    Canvas通过JavaScript来绘制2D图形.Canvas是逐像素渲染的.在Canvas中,一旦图形被绘制完成,它就不会继续得到浏览器的关注.如果其位置发生变化,那么整个场景也需要重新绘制,包括 ...

  3. HTML5学习总结——canvas绘制象棋(canvas绘图)

    一.HTML5学习总结——canvas绘制象棋 1.第一次:canvas绘制象棋(笨方法)示例代码: <!DOCTYPE html> <html> <head> & ...

  4. html5学习笔记一

    HTML5学习笔记 <video>标记:定义视频,Ogg.MPEG4.WebM三种格式 <video src=”movie.ogg”  controls=”controls”> ...

  5. Html5学习笔记1 元素 标签 属性

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. HTML5学习笔记之表格标签

    HTML5学习笔记之表格标签 其他HTML5相关文章 HTML5学习笔记之HTML5基本介绍 HTML5学习笔记之基础标签 HTML5学习笔记之表格标签 HTML5学习笔记之表单标签 HTML5学习笔 ...

  7. HTML5 学习笔记(一)——HTML5概要与新增标签

    目录 一.HTML5概要 1.1.为什么需要HTML5 1.2.什么是HTML5 1.3.HTML5现状及浏览器支持 1.4.HTML5特性 1.5.HTML5优点与缺点 1.5.1.优点 1.5.2 ...

  8. HTML5 学习笔记--------》HTML5概要与新增标签!

      一.HTML5概要 1.1.为什么需要HTML5 HTML4陈旧不能满足日益发展的互联网需要,特别是移动互联网.为了增强浏览器功能Flash被广泛使用,但安全与稳定堪忧,不适合在移动端使用(耗电. ...

  9. HTML5学习笔记(一):HTML简介

    Web前端涵盖的内容较多且杂,主要由3个部分组成:HTML标记语言.CSS样式语言和JavaScript脚本语言组成,而下面我们将先学习最新的标记语言HTML5. <!DOCTYPE>标记 ...

随机推荐

  1. (简单) FZU 1686 神龙的难题 , DLX+可重复覆盖。

    Description 这是个剑与魔法的世界.英雄和魔物同在,动荡和安定并存.但总的来说,库尔特王国是个安宁的国家,人民安居乐业,魔物也比较少.但是.总有一些魔物不时会进入城市附近,干扰人民的生活.就 ...

  2. linux shell命令之 xargs

    1  简介 xargs是一条Unix和类Unix操作系统的常用命令.它的作用是将参数列表转换成小块分段传递给其他命令,以避免参数列表过长的问题. 2 特点 (1) 处理文件/目录名中的空格 find ...

  3. 一个苹果证书怎么多次使用——导出p12文件

    http://blog.csdn.net/jjiss318/article/details/41812243 原文:http://my.oschina.net/u/1245365/blog/19636 ...

  4. FZU 1397 保送

    网络流入门题. 源点到每一个学生连一条边,容量为1 每个学校到汇点连一条边,容量为L 符合要求的学生和学校之间连边,容量为1. 从源点到汇点的最大流就是答案. #include<cstdio&g ...

  5. CSS重设(reset)

    在当今网页设计/开发实践中,使用CSS来为语义化的(X)HTML标记添加样式风格是重要的关键.在设计师们的梦想中都存在着这样的一个完美世界:所有的浏览器都能够理解和适用多有CSS规则,并且呈现相同的视 ...

  6. struts2拦截器-自定义拦截器,放行某些方法(web.xml配置)

    一.web.xml配置 <filter> <filter-name>encodingFilter</filter-name> <filter-class> ...

  7. html&&css 基础知识笔记

    diV有 Class.Style.title.ID 等属性. 1.margin 空出边缘 margin:上 下 左 右(按顺时针顺序,缺少某一方向则对称) 2.border 边框(三要素:像素 形状 ...

  8. p4factory 解决“g++: internal compiler error: Killed (program cc1plus)” make error问题

    参考:解决: g++: internal compiler error: Killed (program cc1plus) 在安装p4factory的时候,执行: ./install_deps.sh ...

  9. UVa 10653 - Bombs! NO they are Mines!!

    题目大意:给你一个二维迷宫,给定入口和出口,找出最短路径. 无权图上的单源最短路,用BFS解决. #include <cstdio> #include <queue> #inc ...

  10. jdk8 之 java.time包AND DateUtils

    package com.jansh.comm.util; import java.time.Clock; import java.time.LocalDate; import java.time.Lo ...