Box2d Cocos2d крушение круга при контакте с землей - PullRequest
2 голосов
/ 13 ноября 2011

это мой первый вопрос, поэтому извините, если я что-то делаю неправильно или это слишком долго.Я читал этот урок Рэя Вендерлиха, я изменил его, чтобы он был более плоским и постепенно спускался вниз.По сути, у меня есть мяч, катящийся по ухабистой горке, но в данный момент мяч падает только с высоты около 100 пикселей.Когда происходит прикосновение, приложение перестает работать (это приложение Mac Cocos2d Box2d).Шариковый код таков:

CGSize winSize = [CCDirector sharedDirector].winSize;
self.oeva = [CCSprite spriteWithTexture:[[CCTextureCache sharedTextureCache] addImage:@"Ball.png"]rect:CGRectMake(0, 0, 64, 64)]; 
_oeva.position = CGPointMake(68, winSize.height/2);
[self addChild:_oeva z:1];
b2BodyDef oevaBodyDef;
oevaBodyDef.type = b2_dynamicBody;
oevaBodyDef.position.Set(68/PTM_RATIO, (winSize.height/2)/PTM_RATIO);
// oevaBodyDef.userData = _oeva;
_oevaBody = world->CreateBody(&oevaBodyDef);
b2BodyDef bodyDef;
bodyDef.type = b2_dynamicBody;

bodyDef.position.Set(60/PTM_RATIO, 400/PTM_RATIO);
bodyDef.userData = _oeva;
b2Body *body = world->CreateBody(&bodyDef);

// Define another box shape for our dynamic body.
b2CircleShape dynamicBox;
dynamicBox.m_radius = 70/PTM_RATIO;//These are mid points for our 1m box

// Define the dynamic body fixture.
b2FixtureDef fixtureDef;
fixtureDef.shape = &dynamicBox; 
fixtureDef.density = 1.0f;
fixtureDef.friction = 0.3f;
body->CreateFixture(&fixtureDef);

Это отлично работает.Это код местности, он также отлично работает:

-(void)generateTerrainWithWorld: (b2World *) inputWorld: (int) hillSize;{
b2BodyDef bd;
bd.position.Set(0, 0);

body = inputWorld->CreateBody(&bd);

b2PolygonShape shape;
b2FixtureDef fixtureDef;
currentSlope = 0;

CGSize winSize = [CCDirector sharedDirector].winSize;    
float xf = 0;
float yf = (arc4random() % 10)+winSize.height/3;
int x = 200;
for(int i = 0; i < maxHillPoints; ++i) {
    hillPoints[i] = CGPointMake(xf, yf);
    xf = xf+ (arc4random() % x/2)+x/2;
    yf = ((arc4random() % 30)+winSize.height/3)-currentSlope;
    currentSlope +=10;
}

int hSegments;

for (int i=0; i<maxHillPoints-1; i++) {
    CGPoint p0 = hillPoints[i-1];
    CGPoint p1 = hillPoints[i];
    hSegments = floorf((p1.x-p0.x)/cosineSegmentWidth);
    float dx = (p1.x - p0.x) / hSegments;
    float da = M_PI / hSegments;
    float ymid = (p0.y + p1.y) / 2;
    float ampl = (p0.y - p1.y) / 2;

    CGPoint pt0, pt1;
    pt0 = p0;
    for (int j = 0; j < hSegments+1; ++j) {

        pt1.x = p0.x + j*dx;
        pt1.y = ymid + ampl * cosf(da*j);

        fullHillPoints[fullHillPointsCount++] = pt1;

        pt0 = pt1;
    }        

}

b2Vec2 p1v, p2v;
for (int i=0; i<fullHillPointsCount-1; i++) {
    p1v = b2Vec2(fullHillPoints[i].x/PTM_RATIO,fullHillPoints[i].y/PTM_RATIO);
    p2v = b2Vec2(fullHillPoints[i+1].x/PTM_RATIO,fullHillPoints[i+1].y/PTM_RATIO);
    shape.SetAsEdge(p1v, p2v);
    body->CreateFixture(&shape, 0);
}

}

Однако при столкновении двух приложений приложение вылетает.Ошибка сбоя:

Поток 6 CVDisplayLink: Программа получила сигнал: "SIGABRT"

Ошибка возникает в строке 96 файла b2ContactSolver.cpp:

b2Assert(kNormal > b2_epsilon);

Журнал ошибок:

Ошибка подтверждения: (kNormal> 1.19209290e-7F), функция b2ContactSolver, файл / Users / coooli01 / Documents / Xcode Projects / Cocos2d / Hill Slide / HillSlide / libs / Box2D / Dynamics / Contacts / b2ContactSolver.cpp, строка 96.

Извините, если я продолжал слишком долго, я застрял на этом целую вечность.

Ответы [ 2 ]

3 голосов
/ 14 ноября 2011

Это не выглядит здоровым:

for (int i=0; i<maxHillPoints-1; i++) {
    CGPoint p0 = hillPoints[i-1];//first iteration accesses hillPoints[-1]

Кроме того, у меня все работало нормально (просто угадал некоторые значения, не приведенные здесь).

0 голосов
/ 14 ноября 2011

Этот сбой обычно происходит, когда оба тела имеют нулевую массу.

[Источник]

Ваша земля не должна иметь массу, поскольку она состоит из краев, но ваше тело должно иметь массу (путем установки его плотности) Я вижу, что вы устанавливаете плотность, но убедитесь, что она не была изменена во время столкновения.

...