关于coco2d-x 3.8版的PhysicsEditor.exe1.09版的GB2ShapeCache-x.h.cpp中有些方法更新了和容器的使用方法,还有就是头文件include "CCNS.h"  以前在cocoa包中现在在base包中。

//GB2ShapeCache-x.h.cpp

#include "GB2ShapeCache-x.h"  
#include "Box2D/Box2D.h"  
#include "base/CCNS.h"

using namespace cocos2d;

/**
* Internal class to hold the fixtures
*/
class FixtureDef {
public:
    FixtureDef()
        : next(NULL) {}

~FixtureDef() {
        delete next;
        delete fixture.shape;
    }

FixtureDef *next;
    b2FixtureDef fixture;
    int callbackData;
};

class BodyDef {
public:
    BodyDef()
        : fixtures(NULL) {}

~BodyDef() {
        if (fixtures)
            delete fixtures;
    }

FixtureDef *fixtures;
    CCPoint anchorPoint;
};

static GB2ShapeCache *_sharedGB2ShapeCache = NULL;

GB2ShapeCache* GB2ShapeCache::sharedGB2ShapeCache(void) {
    if (!_sharedGB2ShapeCache) {
        _sharedGB2ShapeCache = new GB2ShapeCache();
        _sharedGB2ShapeCache->init();
    }

return _sharedGB2ShapeCache;
}

bool GB2ShapeCache::init() {
    return true;
}

void GB2ShapeCache::reset() {
    std::map<std::string, BodyDef *>::iterator iter;
    for (iter = shapeObjects.begin(); iter != shapeObjects.end(); ++iter) {
        delete iter->second;
    }
    shapeObjects.clear();
}

void GB2ShapeCache::addFixturesToBody(b2Body *body, const std::string &shape) {
    std::map<std::string, BodyDef *>::iterator pos = shapeObjects.find(shape);
    assert(pos != shapeObjects.end());

BodyDef *so = (*pos).second;

FixtureDef *fix = so->fixtures;
    while (fix) {
        body->CreateFixture(&fix->fixture);
        fix = fix->next;
    }
}

cocos2d::CCPoint GB2ShapeCache::anchorPointForShape(const std::string &shape) {
    std::map<std::string, BodyDef *>::iterator pos = shapeObjects.find(shape);
    assert(pos != shapeObjects.end());

BodyDef *bd = (*pos).second;
    return bd->anchorPoint;
}

void GB2ShapeCache::addShapesWithFile(const std::string &plist) {

CCDictionary *dict = CCDictionary::createWithContentsOfFileThreadSafe(plist.c_str());
    CCAssert(dict != NULL, "Shape-file not found"); // not triggered - cocos2dx delivers empty dict if non was found  
    CCAssert(dict->count() != 0, "plist file empty or not existing");

CCDictionary *metadataDict = (CCDictionary *)dict->objectForKey("metadata");
    int format = static_cast<CCString *>(metadataDict->objectForKey("format"))->intValue();
    ptmRatio = static_cast<CCString *>(metadataDict->objectForKey("ptm_ratio"))->floatValue();
    CCAssert(format == 1, "Format not supported");

CCDictionary *bodyDict = (CCDictionary *)dict->objectForKey("bodies");

b2Vec2 vertices[b2_maxPolygonVertices];

DictElement* pElement = NULL;
    CCDICT_FOREACH(bodyDict, pElement)
    {
        BodyDef *bodyDef = new BodyDef();

CCString *bodyName = ccs(pElement->getStrKey());

CCDictionary *bodyData = (CCDictionary *)pElement->getObject();
        bodyDef->anchorPoint = PointFromString(static_cast<CCString *>(bodyData->objectForKey("anchorpoint"))->getCString());

CCArray *fixtureList = (CCArray *)bodyData->objectForKey("fixtures");
        FixtureDef **nextFixtureDef = &(bodyDef->fixtures);

CCObject *fixture = NULL;
        CCARRAY_FOREACH(fixtureList, fixture)
        {

b2FixtureDef basicData;
            CCDictionary *fixtureData = (CCDictionary *)fixture;
            int callbackData = 0;

basicData.filter.categoryBits = static_cast<CCString *>(fixtureData->objectForKey("filter_categoryBits"))->intValue();
            basicData.filter.maskBits = static_cast<CCString *>(fixtureData->objectForKey("filter_maskBits"))->intValue();
            basicData.filter.groupIndex = static_cast<CCString *>(fixtureData->objectForKey("filter_groupIndex"))->intValue();
            basicData.friction = static_cast<CCString *>(fixtureData->objectForKey("friction"))->floatValue();
            basicData.density = static_cast<CCString *>(fixtureData->objectForKey("density"))->floatValue();
            basicData.restitution = static_cast<CCString *>(fixtureData->objectForKey("restitution"))->floatValue();
            basicData.isSensor = (bool)static_cast<CCString *>(fixtureData->objectForKey("isSensor"))->intValue();
            if (fixtureData->objectForKey("id")){
                basicData.userData = static_cast<CCString *>(fixtureData->objectForKey("id"));
                callbackData = static_cast<CCString *>(fixtureData->objectForKey("id"))->intValue();
            }

std::string fixtureType = static_cast<CCString *>(fixtureData->objectForKey("fixture_type"))->getCString();
            //CCString *fixtureType = static_cast<CCString *>(fixtureData->objectForKey("fixture_type"))->getCString();

if (fixtureType == "POLYGON") {
                //CCDictionary *polygons = (CCDictionary *)fixtureData->objectForKey("polygons");  
                CCArray *polygons = (CCArray *)fixtureData->objectForKey("polygons");
                //CCDictElement *polygon = NULL;  
                CCObject *polygon = NULL;
                //CCDICT_FOREACH(polygons, polygon)  
                CCARRAY_FOREACH(polygons, polygon)
                {
                    FixtureDef *fix = new FixtureDef();
                    fix->fixture = basicData; // copy basic data  
                    fix->callbackData = callbackData;

b2PolygonShape *polyshape = new b2PolygonShape();
                    int vindex = 0;

//CCDictionary *polygonData = (CCDictionary *)polygon->getObject();  
                    CCArray *polygonData = (CCArray *)polygon;

assert(polygonData->count() <= b2_maxPolygonVertices);

//CCDictElement *offset = NULL;  
                    CCObject *offset = NULL;
                    //CCDICT_FOREACH(polygonData, offset)  
                    CCARRAY_FOREACH(polygonData, offset)
                    {

CCString *pStr = (CCString *)offset;
                        CCPoint p = PointFromString(pStr->getCString());

vertices[vindex].x = (p.x / ptmRatio);
                        vertices[vindex].y = (p.y / ptmRatio);
                        vindex++;

}

polyshape->Set(vertices, vindex);
                    fix->fixture.shape = polyshape;

*nextFixtureDef = fix;
                    nextFixtureDef = &(fix->next);
                }

}
            else if (fixtureType == "CIRCLE") {
                FixtureDef *fix = new FixtureDef();
                fix->fixture = basicData; // copy basic data  
                fix->callbackData = callbackData;

CCDictionary *circleData = (CCDictionary *)fixtureData->objectForKey("circle");

b2CircleShape *circleShape = new b2CircleShape();

circleShape->m_radius = static_cast<CCString *>(circleData->objectForKey("radius"))->floatValue() / ptmRatio;
                CCPoint p = PointFromString(static_cast<CCString *>(circleData->objectForKey("position"))->getCString());
                circleShape->m_p = b2Vec2(p.x / ptmRatio, p.y / ptmRatio);
                fix->fixture.shape = circleShape;

// create a list  
                *nextFixtureDef = fix;
                nextFixtureDef = &(fix->next);

}
            else {
                CCAssert(0, "Unknown fixtureType");
            }

// add the body element to the hash  
            shapeObjects[bodyName->getCString()] = bodyDef;
        }
    }
}

//GB2ShapeCache-x.h

#ifndef __CCSHAPECACHE_H__  
#define __CCSHAPECACHE_H__  
#include "cocos2d.h"  
USING_NS_CC;
class BodyDef;
class b2Body;
namespace cocos2d {
    class GB2ShapeCache : public CCObject{
    public:
        static GB2ShapeCache* sharedGB2ShapeCache(void);
    public:
        bool init();
        void addShapesWithFile(const std::string &plist);
        void addFixturesToBody(b2Body *body, const std::string &shape);
        cocos2d::CCPoint anchorPointForShape(const std::string &shape);
        void reset();
        float getPtmRatio() { return ptmRatio; }
        ~GB2ShapeCache() {}
    private:
        std::map<std::string, BodyDef *> shapeObjects;
        GB2ShapeCache(void) {}
        float ptmRatio;
    };
}
#endif /* defined(__CCSHAPECACHE_H__) */

cocos2dx 3.8版关于#include "GB2ShapeCache-x.h"的更多相关文章

  1. cocos2d-x 新建项目 Cannot open include file: ‘cocos2d.h’

    新建cocos2d-x 项目分这么几步. 1. 下载最新的cocos2d-x 2. 安装 vs2010 3. 解压cocos2d-x 压缩包,并双击"install-templates-ms ...

  2. Cocos2d-x 3.x版2048游戏开发

    Cocos2d-x 3.x版2048游戏开发 本篇博客给大家介绍怎样高速开发2048这样一款休闲游戏,理解整个2048游戏的开发流程.从本篇博客你将能够学习到下面内容: 这里注明一下,本教程来自极客学 ...

  3. (转)win7 64 安装mysql-python:_mysql.c(42) : fatal error C1083: Cannot open include file: 'config-win.h': No such file or directory

    原文地址:http://www.cnblogs.com/fnng/p/4115607.html 作者:虫师 今天想在在win7 64位环境下使用python 操作mysql 在安装MySQL-pyth ...

  4. win7 64 安装mysql-python:_mysql.c(42) : fatal error C1083: Cannot open include file: 'config-win.h': No such file or directory

    今天想在在win7 64位环境下使用python 操作mysql 在安装MySQL-python 时报错: _mysql.c _mysql.c(42) : fatal error C1083: Can ...

  5. include/asm/dma.h

    /* $Id: dma.h,v 1.7 1992/12/14 00:29:34 root Exp root $ * linux/include/asm/dma.h: Defines for using ...

  6. Winpcap安装,Cannot open include file 'pcap.h'

    VC报错 fatal error C1083: Cannot open include file: 'pcap.h': No such file or directory Winpcap是window ...

  7. /usr/include/sys/types.h:62: error: conflicting types for ‘dev_t’

    /usr/include/sys/types.h:62: error: conflicting types for ‘dev_t’/usr/include/linux/types.h:13: erro ...

  8. _mysql.c(42) : fatal error C1083: Cannot open include file: 'config-win.h':问题的解决 mysql安装python

    在win7下安装了Python后,想安装python-MySQL,使用pip安装出现如下问题: >pip install MySQL-python _mysql.c(42) : fatal er ...

  9. 用ioctl获取无线网络信息 /usr//include/linux/wireless.h

    1.UNIX Network Programming环境搭建 Unix NetWork Programming――环境搭建(解决unp.h等源码编译问题) http://blog.csdn.net/a ...

随机推荐

  1. 【Jersey】IntelliJ IDEA + Maven + Jetty + Jersey搭建RESTful服务

    本文参考以下内容: 使用Jersey实现RESTful风格的webservice(一) Starting out with Jersey & Apache Tomcat using Intel ...

  2. nginx 设置 fastcgi缓存

    #增加调试信息 add_header X-Cache-CFC "$upstream_cache_status - $upstream_response_time"; fastcgi ...

  3. flash性能优化方案整理(最全)

    性能优化的原则 1.避免过早优化:太早优化将使代码难以设计和维护,最好是针对程序的瓶颈进行优化. 2.改进性能有时需要权衡:不能一味注重改进性能,一个项目要考虑各方面的利弊,比如代码的健壮性,结构性, ...

  4. jQuery 遍历(上)

    目录: 一:定义二:遍历 DOM三:jQuery 参考手册 - 遍历 定义:什么是遍历?jQuery 遍历,意为"移动",用于根据其相对于其他元素的关系来"查找" ...

  5. Python进程、线程、协程

    进程和线程的解释 进程(process)和线程(thread)是操作系统的基本概念,计算机的核心是CPU,它承担了所有的计算任务: 单个CPU一次只能运行一个任务,代表单个CPU总是运行一个进程,其他 ...

  6. 移植linux-2.6.32.2到qq2440

    编译该版本内核使用的编译器版本:arm-linux-gcc 3.4.1 1.获取linux-2.6.32.2 2.解压内核 3.切换到刚解压的内核目录下: cd linux-2.6.32.2 4.修改 ...

  7. cocos2d学习笔记

    doxygen工具 生成cocos2d的api文档 位图字体编辑工具 Glyph Designer http://www.71squared.com/glyphdesigner  收费的 CCLabl ...

  8. C library function - freopen()

    Description The C library function FILE *freopen(const char *filename, const char *mode, FILE *strea ...

  9. ember.js学习笔记

    启动服务器 ember server 访问localhost:4200 创建新的路由:ember generate route 路由名称,运行此命令会同时创建一个/templates/.XXXhbs模 ...

  10. px和em的区别(转)

    在国内网站中,包括三大门户,以及“引领”中国网站设计潮流的蓝色理想,ChinaUI等都是使用了px作为字体单位.只有百度好歹做了个可调的表率.而 在大洋彼岸,几乎所有的主流站点都使用em作为字体单位, ...