cocos2d-x3.6 连连看随机地图实现
我的博客:http://blog.csdn.net/dawn_moon
这一节来讲地图初始化实现。
连连看地图初始化有非常多实现方式,大概会有下面几种:
- 每一格的位置随机取图片放上去
- 随机取图片放到随机的位置上去
- 把图片铺满地图。随机打乱位置
我们採用第三种方式。
要注意的是。为了保证最后全部的图片都被消掉,那么全部的图片都要是偶数个。我们採用逐格绘制。每次放两张同样的图片,铺满地图以后,随机打乱。
初始例如以下:
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
---|---|---|---|---|---|---|---|---|---|
0 | 1 | 1 | 2 | 2 | 3 | 3 | 4 | 4 | 0 |
0 | 5 | 5 | 6 | 6 | 7 | 7 | 8 | 8 | 0 |
0 | 9 | 9 | 10 | 10 | 11 | 11 | 12 | 12 | 0 |
0 | 13 | 13 | 14 | 14 | 15 | 15 | 16 | 16 | 0 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
然后随机打乱就能够了,注意仅仅随机打乱非零的位置。
代码里面怎样实现呢。非常easy。
定义一个二维数组。地图每一格相应一个值。 其值为0表示是一个空格,其它数字就是图片的id。
数组初始化都是0。然后遍历一遍,四个边框还是零,里面的位置按图片id,成对赋值。
我把地图数组赋值和图片绘制分成两部分,先初始化地图数组。然后再画棋盘。看代码:
void GameScene::initMap()
{
// 这里x用来控制地图数组的每格的值,y用来控制两次反转。即每两个格标记同一个值
int x = 1;
int y = 0;
// 数组下标从0開始。这里从1開始遍历,那么最外面一圈就是0不变
for (int i = 1; i < xCount - 1; i++) {
for (int j = 1; j < yCount - 1; j++) {
// 地图数组赋值
mMap[i][j] = x;
// y控制反转。x控制每格值添加。增大到图片总数后从再1開始递增
if (y == 1) {
x++;
y = 0;
if ( x == iconCount) {
x = 1;
}
}else{
y = 1;
}
}
}
change();
drawMap();
}
上面的 change()函数就是随机打乱地图数组,drawMap()函数就是绘制棋盘,讲地图数组相应的图标绘制出来。
接下来看下change()函数:
// 随机改变一下棋局位置
void GameScene::change()
{
// 随机种子
srand((unsigned int)time(NULL));
// 暂时变量,用来交换两个位置的数据
int tempX, tempY, tempM;
// 遍历地图数组,随机交换位置
for (int x = 1; x < xCount - 1 ; x++)
for (int y = 1; y < yCount - 1; y++) {
tempX = 1 + (int)(CCRANDOM_0_1() * (xCount - 2));
tempY = 1 + (int)(CCRANDOM_0_1() * (yCount - 2));
tempM = mMap[x][y];
mMap[x][y] = mMap[tempX][tempY];
mMap[tempX][tempY] = tempM;
}
}
非常easy是吧,不说了。
接着看drawMap()函数:
void GameScene::drawMap()
{
// 绘制棋盘上精灵
for (int x = 0; x < xCount; x++) {
for (int y = 0; y < yCount; y++) {
if (mMap[x][y] > 0) {
char iconName[64] = {0};
// 格式化图片名
sprintf(iconName, "%d.png", mMap[x][y]);
auto position = indextoScreen(x, y);
// 全部图片已经加到帧缓存,这里直接用名字取一帧。创建一个精灵
auto icon = Sprite::createWithSpriteFrame(SpriteFrameCache::getInstance()->getSpriteFrameByName(iconName));
// icon->setAnchorPoint(Vec2(0, 0));
icon->setPosition(position);
// 设置一个tag,方便兴许识别点击的是那个图标
int tag = (yCount - 2) * ( x - 1 ) + y;
// 这是Z序和tag值,Z序设置大一些确保图标在其它精灵的前面
addChild(icon, 100, tag);
}
}
}
}
代码都加了非常多凝视。应该非常好理解。只是里面有一行凝视掉的代码,是设置锚点的。精灵的默认锚点是(0.5。0.5),也就是中心位置。可是我一開始想把它设为左下角,这样地图铺起来就比較直观。
做到后来做点击连线的时候发现从中间连线会非常麻烦,所以就把这行凝视掉了,直接用默认锚点。
这样做的话,后面的屏幕坐标和地图数组坐标转换就要做一下处理了。后面再讲。
好了。到这里地图就绘制完毕了。
cocos2d-x3.6 连连看随机地图实现的更多相关文章
- Unity 随机地图房间通道生成
之前的博客中已经说了随机房间生成: https://www.cnblogs.com/koshio0219/p/12604383.html 但实现房间生成只是整个地图生成最初最简单的一步.下面讨论如何随 ...
- Unity3d 随机地图生成
2D解析图: 3D地形: 嘿嘿.
- SpriteKit游戏Delve随机生成地牢地图一个Bug的修复
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) Delve是一个很有意思的地牢探险类型的游戏,其中每一关的地图 ...
- roguelike地图的随机生成算法
如果要想自己设计一个roguelike游戏,那么需要你有一个随机地图生成,我在indienova上看到一篇文章,描述了一个roguelike算法,然后自己用unity实现了一个下. 原文地址:随机生成 ...
- 《连连看》算法c语言演示(自动连连看)
(图片是游戏的示意图,来自互联网,与本文程序无关) 看题目就知道是写给初学者的,没需要的就别看了,自己都觉得怪无聊的. 很多游戏的耐玩性都来自精巧的算法,特别是人工智能的水平.比如前几天看了著名的Al ...
- cocos2d 消除类游戏简单的算法 (一)
1. 游戏视频演示 2.三消游戏我的理解 上面视频中的游戏.我做了2个星期时间,仅仅能算个简单Demo,还有bug.特效也差点儿没有.感觉三消游戏主要靠磨.越磨越精品. 市场上三消游戏已经超级多了.主 ...
- VBA随机地牢生成
无聊啊--于是,我想做一个随机地图. 但是我很懒,不想做. 但是身体很诚实. 这次是直接在Excel中制作的地图,但是,VB的执行效率很慢,我代码的效率也很慢,导致,一旦地图长宽稍大,就会出现好几分钟 ...
- unity3d 随机添加树木
开放世界随机地图才是最重要的.. 随机生成树木 Terrain.terrainData //获取地形设置 terrainData.treePrototypes {get;set;} //获取或设置树木 ...
- 18.libgdx制作预览图,背景移动循环,改变地图颜色
经过构思,游戏将分为两部分, 1,预览图,只负责展示世界形势 2,根据预览图生成的战役项 现在要记录的是我制作预览图的部分 1.预览图只有实际地图的1/4,首先生成地图(建议不要缩放以前地图,由于误差 ...
随机推荐
- c/c++与java------之JNI学习(一)
一.java 调用c/c++ 步骤: 1.在java类中创建一个native关键字声明的函数 2.使用javah生成对应的.h文件 3.在c/c++中实现对应的方法 4.使用vs2012创建一个win ...
- 各种非标232,485协议,自定义协议转modbus协议模块定制开发,各种流量计协议转modbus,
工业现场经常会碰到通过485或者232采集各类仪表数据,但是很多早期的仪表和设备不支持标准modbus协议,而是采用自定义的协议,这些协议数据由plc或者dcs系统来实现采集,不仅费时麻烦,而且不方便 ...
- WPF 路径和几何图形
原文 http://www.cnblogs.com/laoyang999/archive/2012/11/23/2783734.html 继承自Shap类的形状有:Rectangle.Ellipse. ...
- java代码收藏:获取HttpServletRequest中某一前缀的参数
public static Map getParametersStartingWith(ServletRequest request, String prefix) { Enumeration par ...
- C语言的本质(11)——指针与数组
1.指针数组和数组指针的内存布局 初学者总是分不出指针数组与数组指针的区别.其实很好理解:指针数组:首先它是一个数组,数组的元素都是指针,数组占多少个字节由数组本身决定.它是"储存指针的数组 ...
- OpenStreetMap(OSM) for developers
This article from: http://wiki.openstreetmap.org/wiki/Develop OpenStreetMap isn't just open data - i ...
- 《github一天一道算法题》:插入排序
看书.思考.写代码! /*********************************************** * copyright@hustyangju * blog: http://bl ...
- JSF简单介绍
JSF简单介绍 一. 什么是 JSF: JavaServer Faces (JSF) 是一种用于构建 Web 应用程序的新标准 Java 框架.它提供了一种以组件为中心来开发 Java Web 用户界 ...
- spoj 8222 Substrings (后缀自动机)
spoj 8222 Substrings 题意:给一个字符串S,令F(x)表示S的所有长度为x的子串中,出现次数的最大值.求F(1)..F(Length(S)) 解题思路:我们构造S的SAM,那么对于 ...
- UNIX网络编程--读书笔记
会集中这段时间写UNIX网络编程这本书的读书笔记,准备读三本,这一系类的文章会不断更新,一直会持续一个月多,每篇的前半部分是书中讲述的内容,每篇文章的后半部分是自己的心得体会,文章中的红色内容是很重要 ...