cocos2d-x 3.2 之 2048 —— 第一篇

***************************************转载请注明出处:http://blog.csdn.net/lttree******************************************

2048这款游戏,已经有一段时间了,之前一直想做一款。

可是。cocos2d-x 引擎 正在学习,并有别的事情忙。一直延到如今。

好吧。最终要做一下了~。

~

这是第一篇,主要会说明一下:

——屏幕适配

——主界面 布局及设计

前言 中。已经展示过我做的2048,

本次教程内容,将会显示,最基础的2048制作。

场景,button,神马的,自己按兴趣加入吧~

o,还有。我的环境是WIN7+VS2012+cocos2d-x 3.2

每篇文章最后。都会载入做到眼下篇章的代码。

我也是写一点。发一篇的,

若有错误,敬请指出。O(∩_∩)O谢谢!

開始,Go!

第一步,屏幕适配

之前,在  屏幕适配 一文中 也有说明。

能够用320*480的。也能够用 480*800 的,

这里。显示方便,就用了320*480的,

AppDelegate.cpp中:

 if(!glview) {
        glview = GLView::create("My Game");
        director->setOpenGLView(glview);
		glview -> setFrameSize( 320 , 480 );
    }
	glview -> setDesignResolutionSize(320,480,ResolutionPolicy::EXACT_FIT);

恩,适配问题就大体这样了,

说一下,本游戏结构:

—— 三个游戏界面 类 ( 主界面,游戏界面,游戏结束界面 )

—— 一个 宏定义 类 ( 主要放一些 游戏内容的 宏定义 )

—— 一个数字块类  ( 就是 我们须要滑动的 数字 )

没错,就仅仅有这几个类~。~

是不是感觉思路略清晰了呢?

首先,搞一下主界面,

原带的HelloworldScene 直接移除了。

右击项目->加入-> 新建项,填写类名称。并选择存在Classes目录

加入MainScene.h 和 .cpp 两个文件。

然后在MainScene.h 中 加入内容:

#ifndef __test2048_MAINSCENE_H__
#define __test2048_MAINSCENE_H__

#include "cocos2d.h"
USING_NS_CC;

class MainScene : public Layer
{
public:
	// 创建场景
    static Scene* createScene();
    // 初始化函数
	bool init();
    CREATE_FUNC(MainScene);
};

#endif 

然后在.cpp中。对.h定义的函数进行设置:

#include "MainScene.h"

USING_NS_CC;

// 创建场景
Scene* MainScene::createScene()
{
	auto scene = Scene::create();
	auto layer = MainScene::create();
	scene -> addChild( layer );
	return scene;
}

// 初始化函数
bool MainScene::init()
{
	// 父类初始化失败。则返回false
	if( !Layer::init() )
	{
		return false;
	}

	return true;
}

然后,要在这个场景中,加入一些相关内容,

比方: 游戏名称 , 開始游戏button , 退出游戏button

等下,在这些东西设置前,要先设置一些 游戏 相关宏定义,

比方。屏幕的宽高。

新建一个 GameDefine.h  :

#ifndef __test2048_GameDefine_H__
#define __test2048_GameDefine_H__

#define Game_Screen_Width 320
#define Game_Screen_Height 480

#endif

这个类。就是存游戏一些宏定义。

后面还有,滑动的上下左右(枚举类型),

设置的几行几列 及  每行每列长度等等。

当然,不定义这个宏,屏幕的大小也能够通过函数来调用:

Size visibleSize = Director::getInstance()->getVisibleSize();

言归正传,要加一些button,能够是图片button。能够是文字button,

開始游戏用 文字button,

退出 用图片button吧。

加入游戏名称。我用的 是 网上找的字体文件(.ttf )来创建的,

首先要  将ttf载入进来,然后用Label::createWithTTF来创建:

// 将ttf文件加载。并设置大小
	TTFConfig config("HelloKitty.ttf",60);
	//显示游戏名称
	auto labelGame=Label::createWithTTF( config , "2048" );
    labelGame->setPosition(Point(GAME_SCREEN_WIDTH/2,GAME_SCREEN_HEIGHT*2/3));
    this->addChild(labelGame);
    labelGame->setScale(1.5);

然后,增加退出button,这个就用原来自带的那个图片,放在右下角:

auto closeItem = MenuItemImage::create(
                                           "CloseNormal.png",
                                           "CloseSelected.png",
                                           CC_CALLBACK_1(MainScene::menuCloseCallback, this));

	closeItem->setPosition(Point( GAME_SCREEN_WIDTH - closeItem->getContentSize().width/2 , closeItem->getContentSize().height/2 ) );

    auto menu = Menu::create(closeItem, NULL);
    menu->setPosition(Vec2::ZERO);
    this->addChild(menu);

当然,要在.h文件加上,这个button的回调函数:

void menuCloseCallback( Ref* pSender );

然后,在.cpp中加上。这个函数的定义:

void MainScene::menuCloseCallback( Ref * pSender )
{
	Director::getInstance()->end();
}

PS:说一下,为什么设置这个位置,

我们要把  关闭 button放在右下角。整个屏幕  左下角是0,0点,

并且图片锚点是在0.5,0.5及中央位置,

getContentSize 是获取当前对象的大小。

酱紫就明确了吧? ~

这样,能够执行看一下效果,

在执行之前,要在AppDelegate.cpp中加上MainScene.h ,并将执行场景换成MainScene:

// create a scene. it's an autorelease object
	auto scene = MainScene::createScene();

    // run
    director->runWithScene(scene);

效果出来咯:

然后,要加上開始游戏的文字button了:

auto startItem = MenuItemFont::create(" Start ",CC_CALLBACK_1(MainScene::menuStartCallback,this));
	startItem -> setPosition( Point( GAME_SCREEN_WIDTH/2,GAME_SCREEN_HEIGHT/2));

	auto menu = Menu::create(closeItem,startItem, NULL);
    menu->setPosition(Vec2::ZERO);
    this->addChild(menu);

然后,依照之前方法,新建一个类,GameScene,

.h和.cpp仍是原来样子。

再加上startbutton的回调,

void MainScene::menuStartCallback( Ref * pSender )
{
	auto scene = GameScene::createScene();
	// 加入个动画
	Director::getInstance() -> replaceScene(TransitionFadeDown::create(0.5f,scene));
}

来,执行试一下吧:

以下有点空啊,能够随便加些什么。比方你的信息等等。

第一篇就先到这里,

第二篇主要讲述的就是游戏界面的格子绘制那些啦~

本篇代码下载:http://pan.baidu.com/s/1gdzPoFD

***************************************转载请注明出处:http://blog.csdn.net/lttree******************************************

时间: 2024-12-07 11:34:41

cocos2d-x 3.2 之 2048 —— 第一篇的相关文章

编写小游戏《贪头蛇》第一篇

小游戏<贪头蛇>设计场景有: 主菜单.游戏主场景.游戏继续.游戏设置.游戏暂停.关于 进入游戏第一场景,显示该款游戏由哪家工作室或个人开发的 代码: SnakeSceneManager类用来管理游戏所有场景的切换,包括创建新的场景,切换下一个场景,和关卡场景 OpenLayer类用来创建该场景 CCScene *SnakeSceneManager::createscene() { CCScene *Scene = CCScene::create(); //进入游戏第1个图层 OpenLayer

零基础学cocos2dx 3.0(顺带学C++)第一篇 切换场景

不会去重复一些概念性的东西,具体的内容,我在代码中已经备注出来.先看目录,这个创建完项目目录的Classes文件夹下有4个文件,我把helloworld那两个文件直接改了名字,这里我叫MainScene .切记,在改为名字之后需要到appDelegate.pp里面把对应的helloworld改过来. 废话不多说,直接上代码 1,appDelegate.h #ifndef _APP_DELEGATE_H_ #define _APP_DELEGATE_H_ #include "cocos2d.h&q

Memcached (第一篇)

Memcached是“分布式”的内存对象缓存系统,那么不需要“分布”的.不需要共享的或者干脆规模小到只有一台服务器的应用,Memcached不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源,如果只是本地级缓存,使用Memcached是非常不划算的. Memcached在很多时候都是作为数据库前端Cache使用的.因为它比数据库少了很多SQL解析.磁盘操作等开销,而且它是使用内存来管理数据的,所以它可以提供比直接读取数据库更好的性能.在大型系统中,访问同样的数据是很频繁的,Memc

CSS px, em, 和rem; float以及clear(第一篇学习)

px:相对长度,相对于屏幕分辨率: em:相对长度单位,相对于当前对象内文本的字体尺寸.如当前对行内文本的字体尺寸未被人为设置,则相对于浏览器的默认字体尺寸.  任意浏览器的默认字体高都是16px.所有未经调整的浏览器都符合: 1em=16px.那么12px=0.75em,10px=0.625em.为了简化font-size的换算,需要在css中的body选择器中声明Font-size=62.5%,这就使em值变为 16px*62.5%=10px, 这样 12px=1.2em, 10px=1em

无限互联奖学金文章连载北京总部四十九期胡梦川 第一篇

无限互联奖学金文章连载北京总部四十九期胡梦川 第一篇: 今天是来到无限互联的第四天,严格来说已经第六天了,刚来就是开班典礼,给人一种很好的氛围.老师讲了很多关于以后学习的技巧和规定,我的第一感觉是,比备战高考还要严格,不过这才能体现一个组织的负责任.正式开讲才感觉到这个班级的大神无处不在,不努力根本赶不上,就是这个学习氛围和高强度的练习很重要.多用心你才能感觉到有些事其实很简单.关于学习时间大家基本都是一天不动的在敲代码,等于给自己一个机会吧.时间飞逝,抓住机会才重要.刚来第一周,感受最深就是好

第一篇

奖学金文章连载北京总部四十九期胡梦川 第一篇: 今天是来到无限互联的第四天,严格来说已经第六天了,刚来就是开班典礼,给人一种很好的氛围.老师讲了很多关于以后学习的技巧和规定,我的第一感觉是,比备战高考还要严格,不过这才能体现一个组织的负责任.正式开讲才感觉到这个班级的大神无处不在,不努力根本赶不上,就是这个学习氛围和高强度的练习很重要.多用心你才能感觉到有些事其实很简单.关于学习时间大家基本都是一天不动的在敲代码,等于给自己一个机会吧.时间飞逝,抓住机会才重要.刚来第一周,感受最深就是好多事做了

SaltStack 入门到精通 - 第一篇: 安装SaltStack

实际环境的设定: 系统环境: centos6 或centos5 实验机器: 192.168.1.100 软件需求: salt 套件,及其需求环境 实验目的: 成功安装salt,并实现salt主从间通讯 特殊设置: 其它目的: 安装SaltStack(下面简称为salt) epel安装:salt安装需要epel源支持,所以在安装salt前需要先安装epel包 # centos5 下载下面rpm  wget -O    epel.rpm https://dl.fedoraproject.org/pu

jstl标签 core fmt fn函数使用参考(为第一篇的补充,更为实用)

JSTL标签 参考手册 前言 ========================================================================= JSTL标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实. JSTL全名为JavaServer Pages Standard Tag Library,目前最新的版本为1.1版.JSTL是由J

Python开发【第一篇】:目录

本系列博文改编自武沛齐老师的原创博文,主要包含  Python基础.前端开发.Web框架.缓存以及队列等内容 ,用于学习记录成长!!! Python开发[第一篇]:目录 Python开发[第二篇]:初识Python