用cocos2d-html5做的消除类游戏《英雄爱消除》(2)——Block设计实现
Block可以说是这个游戏的核心类,它除了包含自身的一些属性和方法外还添加了对触摸事件的响应。
/**
* Power by html5中文网(html5china.com)
* author: jackyWHJ
*/
var Block = cc.Sprite.extend({
id:0,
name:"",
active:true,
pointX:0,
pointY:0,
beginPoint:null,
flash:false,
ctor:function (arg) {
this._super();
if(!arg)return;
this.initWithSpriteFrameName(arg);
this.name = arg;
// cc.registerTargetedDelegate(0,true,this);
cc.Director.getInstance().getTouchDispatcher().addTargetedDelegate(this, 0, true);
},
//销毁隐藏
destroy:function () {
var explosion =Explosion.getOrCreateExplosion();
explosion.setPosition(this.getPosition());
// SparkEffect.getOrCreateSparkEffect(this.getPosition());
if(LLK.SOUND){
cc.AudioEngine.getInstance().setMusicVolume(0.7);
cc.AudioEngine.getInstance().playEffect(s_explodeEffect_mp3);
}
this.setVisible(false);
this.active = false;
LLK.COUNT --;
if(LLK.COUNT <= 0/* || 1*/){
g_sharedGameLayer.onGameOver();
}
}, //判断触摸点是否在图片的区域上
containsTouchLocation:function (touch) {
//获取触摸点位置
var getPoint = touch.getLocation(); //物体当前区域所在的位置
var contentSize = this.getContentSize();
var myRect = cc.rect(0, 0, contentSize.width, contentSize.height);
myRect.origin.x += this.getPosition().x;
myRect.origin.y += this.getPosition().y;
//判断点击是否在区域上
return cc.rectContainsPoint(myRect,getPoint);
},
//刚触摸瞬间
onTouchBegan:function (touch, event) {
if (!this.containsTouchLocation(touch)) return false;
this.beginPoint = touch.getLocation();
// this.setZIndex(100);
this.flash = true;
this.setScale(1.2);
return true;
},
//触摸移动
onTouchMoved:function (touch, event) {
if (!this.containsTouchLocation(touch)) return false;
var touchPoint = touch.getLocation();
var xDist = touchPoint.x - this.beginPoint.x,yDist = touchPoint.y - this.beginPoint.y;
//移动距离超过10个像素位才有效
if((Math.abs(xDist) >= 10 || Math.abs(yDist) >= 10)&&this.flash){
this.flash = false;
var block = this;
if(Math.abs(xDist) > Math.abs(yDist)){
if(xDist > 0){this.moveRight(block);}
else{this.moveLeft(block);}
}
else{
if(yDist > 0){this.moveUp(block);}
else{this.moveDown(block);}
}
return false;
}
},
onTouchEnded:function(touch,event){
this.setScale(1);
this.flash = true;
}, moveLeft:function(block){
if(block.pointX == 0)return;
var leftBlock = Block.getBlock(block.pointX - 1,block.pointY);
if(leftBlock){
leftBlock.pointX = block.pointX;
leftBlock.setPosition(block.pointX*60,block.pointY*60+30);
leftBlock.checkTheSame();
}
block.pointX --;
block.setPosition(block.pointX*60,block.pointY*60+30);
block.checkTheSame();
},
moveRight:function(block){
if(block.pointX == LLK.LEVEL.x - 1)return;
var rightBlock = Block.getBlock(block.pointX + 1,block.pointY);
if(rightBlock){
rightBlock.pointX = block.pointX;
rightBlock.setPosition(block.pointX*60,block.pointY*60+30);
rightBlock.checkTheSame();
}
block.pointX ++;
block.setPosition(block.pointX*60,block.pointY*60+30);
block.checkTheSame();
},
moveUp:function(block){
if(block.pointY == LLK.LEVEL.y - 1)return;
var upBlock = Block.getBlock(block.pointX,block.pointY+1);
if(upBlock){
upBlock.pointY = block.pointY;
upBlock.setAnchorPoint(cc.p(0, 0));
upBlock.setPosition(block.pointX*60,block.pointY*60+30);
upBlock.checkTheSame();
}
block.pointY ++;
block.setPosition(block.pointX*60,block.pointY*60+30);
block.checkTheSame();
},
moveDown:function(block){
if(block.pointY == 0)return;
var downBlock = Block.getBlock(block.pointX,block.pointY - 1);
if(downBlock){
downBlock.pointY = block.pointY;
downBlock.setPosition(block.pointX*60,block.pointY*60+30);
downBlock.checkTheSame();
}
block.pointY --;
// block.setAnchorPoint(cc.p(0, 0));
block.setPosition(block.pointX*60,block.pointY*60+30);
block.checkTheSame();
},
checkTheSame:function(){
this.checkLeft() || this.checkUp()||this.checkRight()||this.checkDown();
},
checkLeft:function(){
if(this.pointX == 0)return false;
var leftBlock = Block.getBlock(this.pointX - 1,this.pointY);
if(leftBlock && leftBlock.name == this.name){
this.destroy();
leftBlock.destroy();
return true;
}
return false;
},
checkRight:function(){
if(this.pointX == LLK.LEVEL.x - 1)return false;
var rightBlock = Block.getBlock(this.pointX + 1,this.pointY);
if(rightBlock && rightBlock.name == this.name){
this.destroy();
rightBlock.destroy();
return true;
}
return false;
},
checkUp:function(){
if(this.pointY == LLK.LEVEL.y - 1)return false;
var upBlock = Block.getBlock(this.pointX,this.pointY+1);
if(upBlock && upBlock.name == this.name){
this.destroy();
upBlock.destroy();
return true;
}
return false;
},
checkDown:function(){
if(this.pointY == 0)return false;
var downBlock = Block.getBlock(this.pointX,this.pointY - 1);
if(downBlock && downBlock.name == this.name){
this.destroy();
downBlock.destroy();
return true;
}
return false;
} }); Block.getBlock = function(pointX,pointY) {
for (var j = 0,len = LLK.map.length; j < len; j++) {
if (LLK.map[j].active && pointX == LLK.map[j].pointX && pointY == LLK.map[j].pointY)
{
return LLK.map[j];
}
}
return null;
};
ctor:function (arg) {
this._super();
if(!arg)return;
this.initWithSpriteFrameName(arg);
this.name = arg;
// cc.registerTargetedDelegate(0,true,this);
cc.Director.getInstance().getTouchDispatcher().addTargetedDelegate(this, 0, true);
},
构造方法中,使用initWithSpriteFrameName方法根据传进来的参数初始化sprite,同时,给sprite的name属性赋值,之后添加该sprite的触摸监听事件。
Block.getBlock = function(pointX,pointY) {
for (var j = 0,len = LLK.map.length; j < len; j++) {
if (LLK.map[j].active && pointX == LLK.map[j].pointX && pointY == LLK.map[j].pointY)
{
return LLK.map[j];
}
}
return null;
};
//判断触摸点是否在图片的区域上
containsTouchLocation:function (touch) {
//获取触摸点位置
var getPoint = touch.getLocation(); //物体当前区域所在的位置
var contentSize = this.getContentSize();
var myRect = cc.rect(0, 0, contentSize.width, contentSize.height);
myRect.origin.x += this.getPosition().x;
myRect.origin.y += this.getPosition().y;
//判断点击是否在区域上
return cc.rectContainsPoint(myRect,getPoint);
},
//刚触摸瞬间
onTouchBegan:function (touch, event) {
if (!this.containsTouchLocation(touch)) return false;
this.beginPoint = touch.getLocation();
// this.setZIndex(100);
this.flash = true;
this.setScale(1.2);
return true;
},
//触摸移动
onTouchMoved:function (touch, event) {
if (!this.containsTouchLocation(touch)) return false;
var touchPoint = touch.getLocation();
var xDist = touchPoint.x - this.beginPoint.x,yDist = touchPoint.y - this.beginPoint.y;
//移动距离超过10个像素位才有效
if((Math.abs(xDist) >= 10 || Math.abs(yDist) >= 10)&&this.flash){
this.flash = false;
var block = this;
if(Math.abs(xDist) > Math.abs(yDist)){
if(xDist > 0){this.moveRight(block);}
else{this.moveLeft(block);}
}
else{
if(yDist > 0){this.moveUp(block);}
else{this.moveDown(block);}
}
return false;
}
},
onTouchEnded:function(touch,event){
this.setScale(1);
this.flash = true;
},
checkTheSame:function(){
this.checkLeft() || this.checkUp()||this.checkRight()||this.checkDown();
},
//销毁隐藏
destroy:function () {
var explosion =Explosion.getOrCreateExplosion();
explosion.setPosition(this.getPosition());
// SparkEffect.getOrCreateSparkEffect(this.getPosition());
if(LLK.SOUND){
cc.AudioEngine.getInstance().setMusicVolume(0.7);
cc.AudioEngine.getInstance().playEffect(s_explodeEffect_mp3);
}
this.setVisible(false);
this.active = false;
LLK.COUNT --;
if(LLK.COUNT <= 0/* || 1*/){
g_sharedGameLayer.onGameOver();
}
},
下面是几个主要功能的教程
用cocos2d-html5做的消除类游戏《英雄爱消除》——概述
用cocos2d-html5做的消除类游戏《英雄爱消除》(1)——系统主菜单
用cocos2d-html5做的消除类游戏《英雄爱消除》(2)——Block设计实现
用cocos2d-html5做的消除类游戏《英雄爱消除》(3)——游戏主界面
用cocos2d-html5做的消除类游戏《英雄爱消除》(4)——游戏结束
ps:概述中有完整的源码链接
用cocos2d-html5做的消除类游戏《英雄爱消除》(2)——Block设计实现的更多相关文章
- 用cocos2d-html5做的消除类游戏《英雄爱消除》(1)——系统主菜单
系统主菜单如下图所示: 首先,介绍下这个主菜单,它包含了一个动画logo以及一个按钮选项,动画logo每隔1秒钟切换一张图片,点击相应的按钮选项会切换不同的游戏场景. 下面看下这个界面的源码: /** ...
- 用cocos2d-html5做的消除类游戏《英雄爱消除》(3)——游戏主界面
游戏主界面,同时也是主程序,包括sprite的生成加入以及游戏状态的控制. 下面同样贴下源码再讲解; /** * Power by html5中文网(html5china.com) * author: ...
- 用cocos2d-html5做的消除类游戏《英雄爱消除》——概述
在bbs.html5china.com论坛学习了MV和老马的小熊蘑菇后我也自己模仿他们做了这样子一个游戏,权当技术交流学习,现在附上游戏截图和源码. 游戏截图: 1.系统菜单界面: 2.游戏界面 3. ...
- 用cocos2d-html5做的消除类游戏《英雄爱消除》(4)——游戏结束
游戏结束界面: 在前面几个教程中,这个界面的创作所需要的知识点基本我们都讲过了,这里就说下用户数据的缓存吧,也是先来看下源码 /** * Power by html5中文网(html5china.co ...
- 消除类游戏(js版)
最近一直在玩一款消灭星星的消除类游戏,周末无聊就用js也写了一遍,感觉玩比写还困难一直玩不到10000分.废话不多说直接上源码. 效果图(ps 页面有点难看木有美工) 代码总共456行,未经过严格测试 ...
- ccf题库中2015年12月2号消除类游戏
题目如下: 问题描述 消除类游戏是深受大众欢迎的一种游戏,游戏在一个包含有n行m列的游戏棋盘上进行,棋盘的每一行每一列的方格上放着一个有颜色的棋子,当一行或一列上有连续三个或更多的相同颜色的棋子时,这 ...
- CCF2015122消除类游戏(C语言版)
问题描述 消除类游戏是深受大众欢迎的一种游戏,游戏在一个包含有n行m列的游戏棋盘上进行,棋盘的每一行每一列的方格上放着一个有颜色的棋子,当一行或一列上有连续三个或更多的相同颜色的棋子时,这些棋子都被消 ...
- ccf消除类游戏
问题描述 消除类游戏是深受大众欢迎的一种游戏,游戏在一个包含有n行m列的游戏棋盘上进行,棋盘的每一行每一列的方格上放着一个有颜色的棋子,当一行或一列上有连续三个或更多的相同颜色的棋子时,这些棋子都被消 ...
- CCF CSP 201512-2 消除类游戏
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201512-2 消除类游戏 问题描述 消除类游戏是深受大众欢迎的一种游戏,游戏在一个包含有n行 ...
随机推荐
- d3.js封装文本实现自动换行和旋转平移等功能
我们下面话不多说,本文主要介绍的是利用D3.js封装文本实现自动换行功能的步骤,下面来一起看看吧. 一.引用 multext.js 文件 multext.js function appendMulti ...
- NSDate 类的总结,全面基础
<span style="font-size:24px;"><span style="font-size:18px;">//1.创建日期 ...
- chrome浏览器提取网页视频
http://blog.csdn.net/pipisorry/article/details/37728839 在我们平时上网看视频听音乐时都会产生缓存,可是我们非常难通过一些软件把当中的视频和音乐文 ...
- [linux]netstat命令详解-显示linux中各种网络相关信息
1.功能与说明 netstat 用于显示linux中各种网络相关信息.如网络链接 路由表 接口状态链接 多播成员等等. 2.参数含义介绍 -a (all)显示所有选项,默认不显示LISTEN相关-t ...
- Snail—UI学习之UITextField
简单看一下UITextField的属性 - (void)createTextField{ UITextField * textField = [[UITextField alloc] initWith ...
- synchronized加static区别
在多线程中,在synchronise方法上加上static 表示的是类锁,锁住的是整个类.而synchroinized 锁住的是当前方法,当前对象.
- git设置全局和单个仓库账号和密码
Git全局配置和单个仓库的用户名邮箱配置 配置全局仓库的账号和密码 git config --global user.name "userName" //你的用户名 git con ...
- [译]GLUT教程(目录)
http://www.lighthouse3d.com/tutorials/glut-tutorial/ GLUT是OpenGL Utility Toolkit的意思.作者Mark J. Kilgar ...
- Error in as.POSIXlt.character(x, tz, ...) :
> sqlFetch(channel,"user")Error in as.POSIXlt.character(x, tz, ...) : character strin ...
- Eclipse中Copy Qualified Name复制类全名解决办法
Eclipse中用Copy Qualified Name复制类全名时总是这样的/struts1/src/me/edu/HelloAction.java很不方便可以这样解决下载下边插件解压到Eclips ...