2010-12-09 175 views
0

我在閱讀'學習iPhone和iPad Cocos2D遊戲開發',並在第4章中介紹了一個使用加速度計的簡單示例。如果我僅將x軸用作書籍,但使用y軸,則精靈的運動效果很好,如果它位於屏幕邊緣,則精靈的運動不平滑。iPhone,cocos2d和加速度計

+ (id)scene 
{ 
    CCScene* scene = [CCScene node]; 
    CCLayer* layer = [GameScene node]; 
    [scene addChild:layer]; 
    return scene; 
} 

- (id)init 
{ 
    if ((self = [super init])) 
    { 
     CCLOG(@"%@: %@", NSStringFromSelector(_cmd), self); 

     self.isAccelerometerEnabled = YES; 

     player = [CCSprite spriteWithFile:@"alien.png"]; 
     [self addChild:player z:0 tag:1]; 

     CGSize screenSize = [[CCDirector sharedDirector] winSize]; 
     float imageHeight = [player texture].contentSize.height; 
     player.position = CGPointMake(screenSize.width/2, imageHeight/2); 

     [self scheduleUpdate]; 
    } 

    return self; 
} 

- (void)dealloc 
{ 
    CCLOG(@"%@: %@", NSStringFromSelector(_cmd), self); 

    [super dealloc]; 
} 

- (void)accelerometer:(UIAccelerometer *)accelerometer didAccelerate:(UIAcceleration *)acceleration 
{ 
    float deceleration = 0.4f; 
    float sensitivity  = 6.0f; 
    float maxVelocity  = 100; 

    playerVelocity.x = playerVelocity.x * deceleration + acceleration.x * sensitivity; 
    playerVelocity.y = playerVelocity.y * deceleration + acceleration.y * sensitivity; 

    if (playerVelocity.x > maxVelocity) 
    { 
     playerVelocity.x = maxVelocity; 
    } 
    else if (playerVelocity.x < -maxVelocity) 
    { 
     playerVelocity.x = -maxVelocity; 
    } 

    if (playerVelocity.y > maxVelocity) 
    { 
     playerVelocity.y = maxVelocity; 
    } 
    else if (playerVelocity.y < -maxVelocity) 
    { 
     playerVelocity.y = -maxVelocity; 
    } 
} 

- (void)update:(ccTime)delta 
{ 
    CGPoint pos = player.position; 
    pos.x += playerVelocity.x; 
    pos.y += playerVelocity.y; 

    CGSize screenSize = [[CCDirector sharedDirector] winSize]; 
    float imageWidthHalved = [player texture].contentSize.width * 0.5f; 
    float leftBorderLimit  = imageWidthHalved; 
    float rightBorderLimit = screenSize.width - imageWidthHalved; 

    if (pos.x < leftBorderLimit) 
    { 
     pos.x = leftBorderLimit; 
     playerVelocity = CGPointZero; 
    } 
    else if (pos.x > rightBorderLimit) 
    { 
     pos.x = rightBorderLimit; 
     playerVelocity = CGPointZero; 
    } 

    float imageHeightHalved = [player texture].contentSize.height * 0.5f; 
    float topBorderLimit  = screenSize.height - imageHeightHalved; 
    float bottomBorderLimit = imageHeightHalved; 

    if (pos.y < bottomBorderLimit) 
    { 
     pos.y = bottomBorderLimit; 
     playerVelocity = CGPointZero; 
    } 
    else if (pos.y > topBorderLimit) 
    { 
     pos.y = topBorderLimit; 
     playerVelocity = CGPointZero; 
    } 

    player.position = pos; 
} 

什麼問題?

+0

Huhh〜,如果我刪除playerVelocity = CGPointZero;行(4行)更新方法,這個工作很好。什麼...... :( – 2010-12-14 05:07:45

回答

2

如果你願意,你可以嘗試我在我的遊戲做的:

#define SIGN(x) ((x < 0.0f) ? -1.0f : 1.0f) 


- (void)accelerometer:(UIAccelerometer*)accelerometer didAccelerate:(UIAcceleration*)acceleration { 

    float kFilteringFactor = 0.01; 

    accels[0] = acceleration.x * kFilteringFactor + accels[0] * (1.0f - kFilteringFactor); 
    accels[1] = acceleration.y * kFilteringFactor + accels[1] * (1.0f - kFilteringFactor); 
    accels[2] = acceleration.z * kFilteringFactor + accels[2] * (1.0f - kFilteringFactor); 

    float xx; 
    float yy; 

    // extract the acceleration components 
    xx = -[acceleration x]; 
    yy = [acceleration y]; 

    // Has the direction changed? 
    float accelDirX = SIGN(xvelocity) * -1.0f; 
    float newDirX = SIGN(xx); 
    float accelDirY = SIGN(yvelocity) * -1.0f; 
    float newDirY = SIGN(yy); 

    // Accelerate. To increase viscosity, lower the values below 1.0f 
    if (accelDirX == newDirX) 
     xaccel = (abs(xaccel) + 0.99f) * SIGN(xaccel); 
    if (accelDirY == newDirY) 
     yaccel = (abs(yaccel) + 0.99f) * SIGN(yaccel); 

    // Apply acceleration changes to the current velocity 
    xvelocity = -xaccel * xx; 
    yvelocity = -yaccel * yy; 

    [sprite moveByAccelerometerX:yvelocity Y:xvelocity];   
} 
0

一切,感謝首先閱讀我的書! :)

你可以找到一個改進的過濾方法(易於指數),I'm using in this article,它還包含加速度計如何工作的基本信息。

您可以瞭解更多關於加速度計輸入from the Tilt to Live developers及其方法,附帶示例項目。

+0

加上我的評論,這4條線的目的是什麼? – 2010-12-14 05:20:28

0

我買了這本書,發現屏幕碰撞檢測的邊緣不能正常工作,除非您有與示例中相同的尺寸精靈。要麼讓你的精靈具有相同的尺寸,要麼讓精靈環繞屏幕而不是停止,這就是我所做的。