coco2d-html5制作弹弓射鸟第一部分---橡皮筋
一、写在前面的话
最近在学习cocos2d-html5方面的知识,一直想从事游戏方面的工作,自己也找了好多资料。网上关于cocos2d-html5的教程真的不多,也只有自己摸索,慢慢看示例代码。由于本人没有mac,所以呢就用不了cocosbuild来制作动画相关的啦,不过今天又发现一个东西就是可以采用虚拟机来转mac系统,呵呵,明天继续试试。如果你也在学习或从事cocos2d-html5方面东西,希望大家都相互交流,共同进步啊。
二、橡皮筋制作
这部分的主要内容是制作橡皮筋,石头放在弹弓上,用手拉弹弓,让石头弹出去。
需要准备的资源有弹弓、石头、背景
最终效果图:
三、详细分解
1、制作背景(制作背景的代码过于简单,没什么多说的就直接上代码了)
//背景
var BackSprite = cc.Sprite.extend({
ctor:function(){
this._super();
this.initWithFile(s_bg);
this.setAnchorPoint(cc.p(0,0));
this.setPosition(cc.p(0,0));
}
});
2、制作石头,这步比较复杂也是核心的一部分
1)首先必须把石头加载到场景中,位置设置在弹弓之间
2)事件的捕捉,当触发Touch事件的时候,判断当前位置是否在石头的矩形范围之类,当事件移动的时候,获取当前事件的
位置,并且设置石头的位置,此时有个核心的东西就是用画笔画出橡皮筋,从石头到弹弓两端点之间。
3)当事件END的时候,石头必须弹出去,给石头一个方向向量,计算石头当前位置和弹弓顶端中间点的角度。从而让石头射出去。
源代码:
//石头
var StoneSprite = cc.Sprite.extend({
mainLayer:null,
_isPullEnd:false,
_isPulling:false,
_velocity:null,
_stonePoint:null,
ctor:function(){
this._super(); //初始化
this.initWithFile(s_stone); //设置事件
cc.Director.getInstance().getTouchDispatcher().addTargetedDelegate(this,0,true); //初始向量
this._velocity = cc.p(800,800); this.scheduleUpdate();
},
onTouchBegan:function(touch,event){
if(!this.containsTouchLocation(touch)){
this.mainLayer.reset();
this._isPulling = false;
this._isPullEnd = false; return false;
}
this._isPulling = true;
this._isPullEnd = false;
return true;
},
onTouchMoved:function(touch, event){
var touchPoint = touch.getLocation();
this.setPosition(touchPoint);
this.mainLayer.drawLine();
},
onTouchEnded:function(){
this._isPullEnd = true; var hitAngle = cc.pToAngle(cc.pSub(cc.p(this.mainLayer._slingshot.getPositionX(),
FLOOR_HEIGHT+this.mainLayer._slingshot.getPositionY()),this.getPosition()));
var scalarVelocity = cc.pLength(this._velocity);
this._velocity = cc.pMult(cc.pForAngle(hitAngle),scalarVelocity); this.mainLayer.clearDrawLine();
},
containsTouchLocation:function(touch){
//获取触摸点的位置
var touchPoint = touch.getLocation(); //获取当前对象的宽度
var contentSize = this.getContentSize(); //定义拖拽的区域
var myRect = cc.rect(0,0,contentSize.width,contentSize.height);
myRect.origin.x += this.getPosition().x - this.getContentSize().width/2;
myRect.origin.y += this.getPosition().y - this.getContentSize().height/2; return cc.rectContainsPoint(myRect,touchPoint);
},
update:function(dt){
if(this._isPullEnd&&this._isPulling){
this.setPosition(cc.pAdd(this.getPosition(),cc.pMult(this._velocity,dt)));
this.check();
}
},
check:function(){
//判断是否飞出了整个区域以外,如果是则重设石头
var size = cc.Director.getInstance().getWinSize();
if(this.getPositionX()>(size.width+20)||
this.getPositionX()<-20||this.getPositionY()>(size.height+20)
||this.getPositionY()<-20){
this.setPosition(this.mainLayer._stonePoint);
this._isPullEnd = false;
this._isPulling = false;
}
}
});
最后:可能做得不是很好,但后面会慢慢完善,也会发到网上供大家参考,源码下载地址:
下载
coco2d-html5制作弹弓射鸟第一部分---橡皮筋的更多相关文章
- 程序员用HTML5制作的爱心树表白动画
体验效果:http://keleyi.com/keleyi/phtml/html5/31.htm 推荐:http://hovertree.com/texiao/css3/18/ HTML代码如下: & ...
- 使用HTML5制作loading图
昨天发了一篇使用HTML5 canvas写的时钟的文章,今天发一篇关于使用HTML5制作loading图的文章. <!DOCTYPE html> <html> <head ...
- 使用HTML5制作时钟
之前看到别人用HTML5制作时钟,自己也写了一个,这是很久以前写的了,没有注释,现在自己看都晕了(注释的重要性就体现在这边了),找时间加上注释,让自己和别人都比较好理解. <!DOCTYPE h ...
- MUI框架开发HTML5手机APP(一)--搭建第一个手机APP
前 言 JRedu 随着HTML5的不断发展,移动开发成为主流趋势!越来越多的公司开始选择使用HTML5开发手机APP,而随着手机硬件设备配置的不断提升,各种开发框架的不断优化,也使着H5开发的 ...
- MUI框架开发HTML5手机APP(一)--搭建第一个手机APP(转)
出处:http://www.cnblogs.com/jerehedu/p/7832808.html 前 言 JRedu 随着HTML5的不断发展,移动开发成为主流趋势!越来越多的公司开始选择使用H ...
- html5制作一个时钟
试着用html5写一个时钟 记得开始这个随笔是几天前,一直保存在草稿里面,一直感觉有个东西搁在在那里,所以今天熬夜也要写完这篇博客!!!哈哈...不多说来上代码和思路. --------------- ...
- jquery+html5制作超酷的圆盘时钟表
自己封装的一个用HTML5+jQuery写的时钟表 代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 ...
- 【HTML5校企公益课】第一天
1.搭建基本的开发环境.学校电脑用的是浏览器是Chrome,编辑器是HBuilder. 2.初步介绍HTML5的Web项目基本结构. css:样式表 img:存放图片 js:存放脚本文件 .html: ...
- 基于html5制作3D拳击游戏源码下载
今天给大家分享一款基于HTML5实现的3d拳王游戏源码.这款实例适用浏览器:360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗. 不支持IE8及以下浏览器. 在线预览 ...
随机推荐
- YII框架路由和URL生成
路由和URL生成 当一个YII应用开始处理一个请求的时候,它首先要做的便是将请求的URL转化成一个路由.路由的作用是用于后续实例化相应的控制器和操作,以便处理请求,整个处理过程便叫做路由.路由的逆过程 ...
- C# 导出word文档及批量导出word文档(3)
在初始化WordHelper时,要获取模板的相对路径.获取文档的相对路径多个地方要用到,比如批量导出时要先保存文件到指定路径下,再压缩打包下载,所以专门写了个关于获取文档的相对路径的类. #regio ...
- 《Linux内核分析》week1作业-分析一个简单c语言的汇编代码
1.C语言源码 #include <stdio.h> int g(int x){ ; } int f(int x){ return g(x); } int main(){ )+; } 2. ...
- 一些 CSS 框架
利用 CSS 框架,可以简化你的工作,提高工作效率.CSS 框架是一系列 CSS 文件的集合体,包含了基本的元素重置,页面排版.网格布局.表单样式.通用规则等代码块.下面给你推荐了27款优秀的CSS框 ...
- 转载:svn clean up 失败解决方法
转载网址:http://www.tuicool.com/articles/biy6na 今天svn遇到一个头疼的问题,最开始更新的时候失败了,因为有文件被锁住了.按照以往的操作,我对父目录进行clea ...
- JQUERY1.9学习笔记 之基本过滤器(四) 首元素选择器
首元素选择器:jQuery( ":first" ) <!DOCTYPE html><html lang="zh-cn"><head ...
- QQ原创表情添加
有时候与QQ好友聊天时会收到一些自己比较喜欢的原创表情,如果我们想把这些QQ不支持直接保存的原创表情保存到电脑上该怎么做呢?我们以原创表情图片为例简单介绍一下. 首先,先建立一个存放表情图片的文件夹. ...
- SQL中对日期进行模糊查询的方法
在我们通过SQL语句对数据库中的数据进行查询时,难免会遇到针对datetime的查询,但是因为一般情况下,输入的时间条件为年月日,所以,这种情况下,我们就要进行一下模糊查询,首先,摒弃一种投机取巧的方 ...
- swf上传
swfupload多文件异步上传 多文件选择异步上传的原理 传统上:多个文件逐一选.PHP开始处理,循环上 PHP+Flash上:JS调用flash控,Flash批量选取并保持选取所有文件列 swfu ...
- 创建一个MVC解决方案,添加一个控制器后,运行程序报错:”/"未找到服务器
1.创建一个MVC项目,如图