保卫萝卜~场景的思路以及数据的存储。

     学习要写笔记,记录自己的步骤。
一、场景构建Tiled
     关于Tiled网上有一大堆的教程,这个比较好用,特别是构建塔防类的游戏极其简单,我也是爽了一把。
场景的资源目录结构比较好做,根据场景id进行区分目录。
场景对应目录:
 
  然后使用Tiled构建基本的场景
 
 
     这里有
     1、两个图块层(底图层、路径层)       2、三个对象层(可行路径对象格、障碍对象格、建筑对象格)
格子使用80X80,跟资源的大小刚好合适……导出.tmx文件,加入舞台就能看到成果了,顿时觉得比较爽。
Cocos2dx已经封装的 TMXTiledMap类使用起来也是顺手至极啊。
 
     TMXTiledMap::create(tmxUrl)
 
创建一个TMXTiledMap对象直接addChild至场景就可以看到效果,如果要获得对象层的数据,通过name就能获得。通过处理对象层的数据(坐标,宽高,类型、等属性)就可以搞定场景建筑搭建,怪物行走路径,鼠标可点击区域等,通过格子矩形的判断就能实现场景逻辑部分。
 
  对Tiled的了解不是很多,但是够用就行……
 
二、数据管理SQLite
 
     数据大概是游戏的命脉啊,可惜自己的数值功力有限,只能设计个自己能用的数据库了,借助于SQLite实现对数据的管理。
SQLite是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。
 
下载sqlite文件
下载网址:http://www.sqlite.org/download.html
 
 
 
  这是最新版本。如下图把解压后的三个文件导入项目中就可以开心的使用了。
 
 
ok,关于创建SQLite数据库的工具也有一大堆,不过我还是喜欢使用   Navicat_Premium_9.1.11 用的爽就行~
 
 
OK,这样创建好数据库DB文件就好啦,下面使用辅助类就可以完美的 增、删、查、改!
 
三、自封装DB数据类
 
     关于封装SQLite的类也是有很多的,但是适用自己的才是最好的,封装起来也是比较简单的,不过鉴于自己的c++水平有限……(拿来主义)……在以前在网上找了个工具类,
后来自己也修改了下,改成自己适用的,贡献下自己修改后的DBUtil类。

#ifndef __DBUtil__
#define __DBUtil__
#include <string>
#include "cocos2d.h"
#include "sqlite3.h" using namespace std;
USING_NS_CC;
class DBUtil{
public: /************************************************************
封装 sqlite3操作
************************************************************/
//用来创建一个db数据库 db为数据库的名字
// 打开数据库
static void initDB(const char *url); //用来判断表格是否存在
// name:表示表名
static bool tableIsExist(string table_name); //用来创建一个表名为name的表格,创建时会先匹配时否有该表的存在如果存在则不创建
//创建表
static void createTable(string sql,string table_name); //用来删除一张表名为name的表格,删除时会先匹配是否有该表的存在如果不存在则不执行删除操作
//删除表名
static void deleteTable(string sql,string table_name); //用来向表中插入一条数据
//插入一条数据
static void insertData(string sql); //用来向表中删除一条数据
//删除一条数据
static void deleteData(string sql); //用来向表中修改一条数据
// 修改一条数据
static void updateData(string sql); //获取表的全部数据
// 返回记录的条数
static int getAllData(string table_name,std::function<void(std::map<string,string>)> callback); //读取一条记录的信息
/*
* 此方法是查询方法,pSender()
*/
static void getDataInfo(string sql,std::function<void(std::map<string,string>)> callback); //关闭打开的数据库
static void closeDB();
}; #endif

DBUtil.h

#include "DBUtil.h"

sqlite3 *pDB = NULL;//数据库指针
char * errMsg = NULL;//错误信息
std::string sqlstr;//SQL指令
int result;//sqlite3_exec返回值
unsigned int _count=;
std::map<unsigned int,std::function<void(std::map<string,string>)>> _keyMap; void DBUtil::initDB(const char *db)
{
//打开一个数据库,如果该数据库不存在,则创建一个数据库文件
result = sqlite3_open(db, &pDB);
if( result != SQLITE_OK )
log( "打开数据库失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //tableIsExist的回调函数
int isExisted( void * para, int n_column, char ** column_value, char ** column_name )
{
bool *isExisted_=(bool*)para;
*isExisted_=(**column_value)!='';
return ;
} bool DBUtil::tableIsExist( string table_name )
{
if (pDB!=NULL)
{
//判断表是否存在
bool tableIsExisted;
sqlstr = "select count(type) from sqlite_master where type='table' and name ='"+table_name+"'";
result =sqlite3_exec(pDB,sqlstr.c_str(),isExisted,&tableIsExisted,&errMsg);
return tableIsExisted;
}
return false;
} void DBUtil::createTable( string sql,string table_name )
{
if (!tableIsExist(table_name))
{
//创建表,设置ID为主键,且自动增加
result = sqlite3_exec(pDB,sql.c_str(),NULL,NULL,&errMsg);
if( result != SQLITE_OK )
log( "创建表失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} } void DBUtil::deleteTable( string sql,string table_name )
{
if (tableIsExist(table_name))
{
result = sqlite3_exec(pDB,sql.c_str(),NULL,NULL,&errMsg);
if( result != SQLITE_OK )
log( "创建表失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
}
} //@示例语句sqlstr=" insert into MyTable_1( name ) values ( 'data',..... ) ";
void DBUtil::insertData( string sql ){
result = sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //@示例语句sqlstr="delete from MyTable_1 where ID = 2";
void DBUtil::deleteData( string sql )
{
result=sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //@示例语句 sqlstr="update MyTable_1 set name='data' where ID = 3";
void DBUtil::updateData( string sql )
{
result = sqlite3_exec( pDB, sql.c_str() , NULL, NULL, &errMsg );
if(result != SQLITE_OK )
log( "插入记录失败,错误码:%d ,错误原因:%s\n" , result, errMsg );
} //getDataCount的回调函数
int loadRecordCount( void *para, int n_column, char ** column_value, char ** column_name )
{
std::map<string,string> data;
int index;
for( index = ; index < n_column; index ++ )
{
data.insert(std::pair<string,string>( column_name[index], column_value[index] ));
}
auto num = *(unsigned int *)para;
auto callback = _keyMap.at(num);
if( callback != nullptr )
{
callback(data);
}
return ;
} int DBUtil::getAllData(string table_name,std::function<void(std::map<string,string>)> callback)
{
string sql = "select * from "+table_name;
_count++;
_keyMap.insert(std::pair<unsigned int,std::function<void(std::map<string,string>)>>(_count,callback));
int count=sqlite3_exec( pDB, sql.c_str() , loadRecordCount, &_count, &errMsg );
return count;
} //getDataInfo的回调函数
int loadRecord( void * para, int n_column, char ** column_value, char ** column_name )
{
std::map<string,string> data;
int index;
for( index = ; index < n_column; index ++ )
{
string str1 = column_name[index];
if( column_value[index] == NULL )
{
log("DBUtil Get Data Value Failure! Table Name Is '%s'",str1.c_str());
continue;
}
string str2 = column_value[index];
data.insert(std::pair<string,string>(str1,str2));
}
auto num = *(unsigned int *)para;
auto callback = _keyMap.at(num);
if( callback != nullptr )
{
_keyMap.erase(num);
callback(data);
}
return ;
} void DBUtil::getDataInfo( string sql,std::function<void(std::map<string,string>)> callback )
{
_count++;
_keyMap.insert(std::pair<unsigned int,std::function<void(std::map<string,string>)>>(_count,callback));
sqlite3_exec( pDB, sql.c_str() , loadRecord, &_count, &errMsg );
} void DBUtil::closeDB()
{
sqlite3_close(pDB);
}

DBUtil.cpp

  这样在数据初始化的时候就可以直接传入表中怪物ID 直接初始化数据
 
四、总结
 
     有场景编辑器,有数据库,我觉得我终于可以完成我想要的效果了~~开心一把。哈哈哈,不过自己空闲时间也不多啊 惆怅……。
好想做*******,可惜C++懂得不多……
 

Cocos2d-x 3.2 学习笔记(十五)保卫萝卜 场景与数据的更多相关文章

  1. python3.4学习笔记(十五) 字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、分割等)

    python3.4学习笔记(十五) 字符串操作(string替换.删除.截取.复制.连接.比较.查找.包含.大小写转换.分割等) python print 不换行(在后面加上,end=''),prin ...

  2. (转载)西门子PLC学习笔记十五-(数据块及数据访问方式)

    一.数据块 数据块是在S7 CPU的存储器中定义的,用户可以定义多了数据块,但是CPU对数据块数量及数据总量是有限制的. 数据块与临时数据不同,当逻辑块执行结束或数据块关闭,数据块中的数据是会保留住的 ...

  3. (C/C++学习笔记) 十五. 构造数据类型

    十五. 构造数据类型 ● 构造数据类型概念 Structured data types 构造数据类型 结构体(structure), 联合体/共用体 (union), 枚举类型(enumeration ...

  4. MySQL学习笔记十五:优化(2)

    一.数据库性能评测关键指标 1.IOPS:每秒处理的IO请求次数,这跟磁盘硬件相关,DBA不能左右,但推荐使用SSD. 2.QPS:每秒查询次数,可以使用show status或mysqladmin ...

  5. Java基础学习笔记十五 集合、迭代器、泛型

    Collection 集合,集合是java中提供的一种容器,可以用来存储多个数据. 在前面的学习中,我们知道数据多了,可以使用数组存放或者使用ArrayList集合进行存放数据.那么,集合和数组既然都 ...

  6. angular学习笔记(十五)-module里的'服务'

    本篇介绍angular中的模块:module 在笔记(二)http://www.cnblogs.com/liulangmao/p/3711047.html里已经讲到过模块,这篇主要讲模块的 '服务' ...

  7. Java学习笔记十五:Java中的成员变量和局部变量

    Java中的成员变量和局部变量 一:成员变量: 成员变量在类中定义,用来描述对象将要有什么 成员变量可以被本类的方法使用,也可以被其他类的方法使用,成员变量的作用域在整个类内部都是可见的 二:局部变量 ...

  8. MYSQL进阶学习笔记十五:MySQL 的账号权限赋予!(视频序号:进阶_33,34)

    知识点十六:MySQL的账号权限赋予(33) 一.MySQL权限简介 关于mysql的权限简单的理解就是mysql允许你做你全力以内的事情,不可以越界.比如只允许你执行select操作,那么你就不能执 ...

  9. 数据结构和算法学习笔记十五:多路查找树(B树)

    一.概念 1.多路查找树(multi-way search tree):所谓多路,即是指每个节点中存储的数据可以是多个,每个节点的子节点数也可以多于两个.使用多路查找树的意义在于有效降低树的深度,从而 ...

  10. JavaScript权威设计--JavaScript脚本化文档Document与CSS(简要学习笔记十五)

    1.Document与Element和TEXT是Node的子类. Document:树形的根部节点 Element:HTML元素的节点 TEXT:文本节点   >>HtmlElement与 ...

随机推荐

  1. WordPress访问打开速度很慢的几种解决方法

    最近WordPress网站访问特别的慢,有时间要加载一分钟才能完全打开,最初怀疑是服务器的问题,经过多方测试,还是没找到原因.后来,通过工具测出浏览器一直在加载fonts.googleapis.com ...

  2. AngularJs 与Jquery的对比分析,超详细!

    闲来无事,在网上发现了一篇对比AngularJs和Jquery的文章.恰好最近自己也在研究AngularJs.特此收藏.需要的朋友可以参考. 原问题:假如我熟悉利用jQuery去开发客户端应用,那么我 ...

  3. word-wrap&&word-break,奇偶行、列设置样式

    1.word-wrap和word-break区分. 来源场景:机械租赁mvc驾驶员信息查看: 当备注的文字多的时候,第一列的值成这模样: 解决方案:设置table 的td可自动换行.首先table设置 ...

  4. C++ 非阻塞套接字的使用 (1)

    在维护代码的过程中,发现软件运行的CPU占用率居高不下,在4核的电脑上占用了25%的CPU.查阅资料的得知,这是可能是由于软件中出现了死循环. 经过对软件的一些测试,最终确定了死循环出现的位置——通讯 ...

  5. (转) silverlight 样式学习

    原文地址:http://www.cnblogs.com/Joetao/articles/2074727.html <UserControl x:Class="StyleDemo.Mai ...

  6. Oracle EBS进化史

    https://blogs.oracle.com/ptian/entry/oracle_ebs%E8%BF%9B%E5%8C%96%E5%8F%B2 通过图表总结了下Oracle EBS的进化历史,回 ...

  7. Highcharts 饼图 文字颜色设置

    设置饼图对应的提示文字的颜色与饼图块状一样,demo如下: $(function () { $('#container').highcharts({ chart: { plotBackgroundCo ...

  8. 苹果全新 Mac OS X 系统开放下载

    在今天的发布会上,苹果除了发布多款硬件产品之外,还更新了Mac OS X Mavericks(小牛)系统,作为重大改变,这一Mac系统将从今天起开始免费升级. 升级后的Mavericks系统将进一步与 ...

  9. 【转载】关于.NET里的内存泄漏

    所谓内存泄露就是指一个不再被程序使用的对象或变量一直被占据在内存中..Net 中有垃圾回收机制,它可以保证一对象不再被引用的时候,即对象编程了孤儿的时候,对象将自动被垃圾回收器从内存中清除掉.虽然.N ...

  10. Yii2中的入口文件环境配置

    默认的Debug配置 在入口文件中 defined ( 'YII_DEBUG' ) or define ( 'YII_DEBUG', true ); defined ( 'YII_ENV' ) or ...