cocos2dx 3.x 拼图小游戏
.h
#define IMAGE_MAX 2 //图片的个数..
//图片结构体 属性
struct IMAGE_DATA
{
cocos2d::Sprite *m_pImage;
bool m_bOpen;
int m_iId;
};
bool onTouchBegan(cocos2d::Touch *pTouch, cocos2d::Event *pEvent);
void onTouchMoved(cocos2d::Touch *pTouch, cocos2d::Event *pEvent);
void onTouchEnded(cocos2d::Touch *pTouch, cocos2d::Event *pEvent);
//返回精灵的碰撞矩形
cocos2d::Rect GetBackRect( cocos2d::Sprite *spr );
//添加图片
void AddImage(std::string name, cocos2d::Vec2 pos, int id);
//添加背景
void AddBack(std::string name, cocos2d::Vec2 pos, int id);
//图片数组
std::vector< IMAGE_DATA > m_vSpr;
//背景数组
std::vector< IMAGE_DATA > m_vBack;
//通关判断
bool m_bWin;
//图片显示最上层
int m_iOrder;
//定时器
void update(float dt);
.cpp
//注册触摸
EventListenerTouchOneByOne *listener = EventListenerTouchOneByOne::create();
listener->onTouchBegan = CC_CALLBACK_2(HelloWorld::onTouchBegan,this);
listener->onTouchMoved = CC_CALLBACK_2(HelloWorld::onTouchMoved,this);
listener->onTouchEnded = CC_CALLBACK_2(HelloWorld::onTouchEnded,this);
listener->setSwallowTouches(true);
Size size = Director::getInstance()->getWinSize();
m_bWin = false;
m_iOrder = ;
//图片素材
std::string image_name[] = {"HelloWorld.png", "white.png"};
//图片随机出现位置
srand((unsigned ));//随机种子
std::vector< Vec2 > image_pos;
; i < IMAGE_MAX; i++)
{
);
);
image_pos.push_back(Vec2( x + size.width / , y + size.height / ));
log("x == %f, y == %f, x1 === %f, y1 === %f", image_pos[i].x, image_pos[i].y, x, y);
}
//需要拼接的背景以及位置
std::string back_name[] = {"red.png", "blue.png"};
Vec2 back_pos[] = {Vec2(size.width * .75f, size.height * .25f), Vec2(size.width * .75f, size.height * .75f)};
; i < IMAGE_MAX; i++)
{
//添加
AddImage(image_name[i], image_pos[i], i + );
AddBack(back_name[i], back_pos[i], i + );
}
//注册精灵监听
; i < m_vSpr.size(); i++)
{
)
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, m_vSpr[i].m_pImage);
else
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener->clone(), m_vSpr[i].m_pImage);
}
//开启定时器
scheduleUpdate();
void HelloWorld::AddImage(std::string name, Vec2 pos, int id){
//新建图片
IMAGE_DATA image;
image.m_pImage = Sprite::create(name.c_str());
image.m_pImage->setPosition(pos);
addChild(image.m_pImage);
image.m_bOpen = true;
image.m_iId = id;
m_vSpr.push_back(image);
}
void HelloWorld::AddBack(std::string name, Vec2 pos, int id){
//新建背景图片
IMAGE_DATA image;
image.m_pImage = Sprite::create(name.c_str());
image.m_pImage->setPosition(pos);
addChild(image.m_pImage, -);
image.m_iId = id;
m_vBack.push_back(image);
}
bool HelloWorld::onTouchBegan(cocos2d::Touch *pTouch, cocos2d::Event *pEvent){
//获取当前点击的精灵
Sprite* target = static_cast<Sprite*>(pEvent->getCurrentTarget());
if (target->getBoundingBox().containsPoint(pTouch->getLocation()))
{
; i< m_vSpr.size(); i++)
{
//点击的精灵触摸关闭 返回false
if(target == m_vSpr[i].m_pImage && !m_vSpr[i].m_bOpen)
return false;
}
m_iOrder++;
//当前点击的精灵放到最上层
target->setLocalZOrder(m_iOrder);
return true;
}
return false;
}
void HelloWorld::onTouchMoved(cocos2d::Touch *pTouch, cocos2d::Event *pEvent){
Sprite* target = static_cast<Sprite*>(pEvent->getCurrentTarget());
; i < m_vSpr.size(); i++)
{
//点击的精灵触摸关闭 退出
if(target == m_vSpr[i].m_pImage && !m_vSpr[i].m_bOpen)
return;
; j < m_vBack.size(); j++)
{
//判断图片是否碰撞到背景 ID是否相等 触摸是否关闭
if (GetBackRect( m_vBack[j].m_pImage ).containsPoint(m_vSpr[i].m_pImage->getPosition()) && m_vBack[j].m_iId == m_vSpr[i].m_iId && m_vSpr[i].m_bOpen)
{
//碰撞到 把图片移动到背景上 触摸关闭
m_vSpr[i].m_pImage->setPosition(m_vBack[j].m_pImage->getPosition());
m_vSpr[i].m_bOpen = false;
return;
}
}
}
//触摸的图片移动
target->setPosition(target->getPosition() + pTouch->getDelta());
}
void HelloWorld::update(float dt){
if (!m_bWin)
{
//全部触摸关闭..代表通关
m_bWin = true;
; i < m_vSpr.size(); i++)
{
if(m_vSpr[i].m_bOpen == true){
m_bWin = false;
}
}
}
if (m_bWin)
{
//过关
log("cheng gong");
unscheduleUpdate();
}
}
Rect HelloWorld::GetBackRect( Sprite *spr ){
//返回精灵的碰撞矩形 Vec2 origin = spr->getPosition();
Size size = spr->getContentSize();
return Rect( origin.x - size.width * .1f, origin.y - size.height * .1f, size.width * .1f, size.height * .1f );
}
cocos2dx 3.x 拼图小游戏的更多相关文章
- JavaScript版拼图小游戏
慕课网上准备开个新的jQuery教程,花了3天空闲时间写了一个Javascript版的拼图小游戏,作为新教程配套的分析案例 拼图游戏网上有不少的实现案例了,但是此源码是我自己的实现,所以不做太多的比较 ...
- 使用NGUI实现拖拽功能(拼图小游戏)
上一次用UGUI实现了拼图小游戏,这次,我们来用NGUI来实现 实现原理 NGUI中提供了拖拽的基类UIDragDropItem,所以我们要做的就是在要拖拽的图片上加一个继承于该类的脚本,并实现其中的 ...
- jQuery实现拼图小游戏
小熊维尼拼图 2017-07-23 ...
- jQuery拼图小游戏
jQuery拼图小游戏 最后样式 核心代码部分 <script type="text/javascript" > $(function () { $("td& ...
- 在HTML页面中有jQuery实现实现拼图小游戏
1.用jQuery实现拼图小游戏 2.首先获得td的点击事件.再进行交换位置 3.下面这种仅供参考 4.下面这些是HTMl标签 当这个世界变得越来越复杂的时候,内心最需保持一份简单一份纯真:
- 仿苹果电脑任务栏菜单&&拼图小游戏&&模拟表单控件
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- swift 拼图小游戏
依据这位朋友的拼图小游戏改编 http://tangchaolizi.blog.51cto.com/3126463/1571616 改编主要地方是: 原本着我仁兄的代码时支持拖动小图块来移动的,我參照 ...
- 教你用Python自制拼图小游戏,一起来制作吧
摘要: 本文主要为大家详细介绍了python实现拼图小游戏,文中还有示例代码介绍,感兴趣的小伙伴们可以参考一下. 开发工具 Python版本:3.6.4 相关模块: pygame模块: 以及一些Pyt ...
- 打造专属自己的html5拼图小游戏
最近公司刚好有个活动是要做一版 html5的拼图小游戏,于是自己心血来潮,自己先实现了一把,也算是尝尝鲜了.下面就把大体的思路介绍一下,希望大家都可以做出一款属于自己的拼图小游戏,必须是更炫酷,更好玩 ...
随机推荐
- scala的基础部分
最近接触到spark,spark又是scala编写的,所以需要学习一下scala. scala是面向对象的,一切皆为对象, 数值,函数都是对象. println("Welcome to th ...
- 安装autoit libary失败问题解决
运行环境:win7-32,python2.7安装遇到的问题:
- ZooKeeper(六)-- CAP和BASE理论、ZAB协议
一.CAP理论和BASE理论 1.CAP理论 CAP理论,指的是在一个分布式系统中,不可能同时满足Consistency(一致性). Availability(可用性).Partition toler ...
- 使用命令wsimport构建WebService客户端
原文:http://www.cnblogs.com/ningvsban/p/3760085.html wsimport命令介绍 在JDK的bin文件夹中,有一个wsimport.exe,这个工具依据w ...
- 如果程序太大而不能在DOS下运行,怎样才能使它在DOS下运行呢?
如果你的程序因太大(超过640KB)而无法在DOS下运行,有两种办法可为该程序提供更多的内存.一种办法是使用覆盖管理程序(overlay manager).覆盖管理程序用来管理程序的模块,并根据需要把 ...
- Linux获取当前目录名,shell获取当前目录名
想把当前目录名保存到一个变量中,然后用在别的地方 ${PWD##*/} 测试: cd /var/log/squid echo ${PWD##*/} 还有很多种方法,请参考这个老外写的: http:// ...
- .Net内存溢出 System.OutOfMemoryException
内存溢出常见的情况和处理方式: http://outofmemory.cn/c/dotNet-outOfMemoryException MSDN中关于processModel的文档 https://m ...
- <转>主成分分析(Principal components analysis)-最大方差解释,最小平方差解释
转自http://www.cnblogs.com/jerrylead/archive/2011/04/18/2020209.html http://www.cnblogs.com/jerrylead/ ...
- linux 下配置vncserver
vncserver是使用非常方便和广泛的远程桌面服务,配置也相对简单. 下面记录了在centos系统上进行配置vncserver的过程. 安装 查看centos下是否已经安装了vncserver rp ...
- sencha touch 入门系列 扩展篇之sencha touch 项目打包压缩
经常有新手同学抱怨说sencha touch的项目加载速度为什么这么慢,经常要10秒左右的时间甚至更多, 大家都知道,sencha touch开发的项目中引用了大量的js文件,当我们打开项目时,st的 ...