2012-01-22 10 views
17

私はJavaで書かれたCocos2DでAndroidで2Dゲームを作っています。ここでは主なもののための私のコードは次のとおりです。InvocationTargetExceptionが表示されるのはなぜですか? Android 2Dゲーム

public void gameLoop(float dt) { 
    //Player Gravity 
    if(canExecuteMovement(0, 6)) { 
     guy.moveY(6); 
    } 

    //Player Movement 
    if(direction == 1) { 
     if(canExecuteMovement(-3, 0)) 
      guy.moveX(-3); 
    } else if(direction == 2) { 
     if(canExecuteMovement(3, 0)) 
      guy.moveX(3); 
    } 
} 

private boolean canExecuteMovement(int xChange, int yChange) { 
    int projectedX = guy.getBounds().left + xChange; 
    int projectedY = guy.getBounds().top + yChange; 
    Log.i("DD", "guy:" + guy.getBounds().toString()); 
    Rect projectedBounds = new Rect(projectedX, projectedY, projectedX + guy.getWidth(), projectedY + guy.getHeight()); 
    Log.i("DD", "guy:" + projectedBounds.toString()); 
    for (int i = 0; i < platformCount; i++) { 
     if (Rect.intersects(projectedBounds, platform[i].getBounds())) { 
      return false; 
     } 
    } 

    return true; 
} 

ご覧のとおり、この機能だけで罰金に見える、とcanExecuteMovementで長方形がしかし、このラインでは、あまりにも完全に罰金です:

LINE 107: if (Rect.intersects(projectedBounds, platform[i].getBounds())) { 

私はInvocationTargetExceptionを取得します。ここにlogcatがあります:

01-21 23:10:12.601: W/System.err(13118): java.lang.reflect.InvocationTargetException 
01-21 23:10:12.601: W/System.err(13118): at java.lang.reflect.Method.invokeNative(Native Method) 
01-21 23:10:12.605: W/System.err(13118): at java.lang.reflect.Method.invoke(Method.java:511) 
01-21 23:10:12.605: W/System.err(13118): at org.cocos2d.actions.CCTimer.update(CCTimer.java:82) 
01-21 23:10:12.605: W/System.err(13118): at org.cocos2d.actions.CCScheduler.tick(CCScheduler.java:253) 
01-21 23:10:12.605: W/System.err(13118): at org.cocos2d.nodes.CCDirector.drawCCScene(CCDirector.java:679) 
01-21 23:10:12.605: W/System.err(13118): at org.cocos2d.nodes.CCDirector.onDrawFrame(CCDirector.java:649) 
01-21 23:10:12.605: W/System.err(13118): at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1462) 
01-21 23:10:12.605: W/System.err(13118): at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1216) 
01-21 23:10:12.605: W/System.err(13118): Caused by: java.lang.NullPointerException 
01-21 23:10:12.608: W/System.err(13118): at com.qasim.platformer.GameLayer.canExecuteMovement(GameLayer.java:107) 
01-21 23:10:12.608: W/System.err(13118): at com.qasim.platformer.GameLayer.gameLoop(GameLayer.java:86) 
01-21 23:10:12.608: W/System.err(13118): ... 8 more 
01-21 23:10:12.620: D/dalvikvm(13118): GC_CONCURRENT freed 460K, 6% free 9279K/9863K, paused 2ms+3ms 
01-21 23:10:12.624: I/DD(13118): guy:Rect(252, 63 - 300, 111) 

何が問題なのですか?男でのgetBounds()クラスはこれです:

public Rect getBounds() { 
    return new Rect(x, y, x+width, y+height); 
} 
+1

GameLayer.javaプログラムの107行目は何ですか? – kosa

答えて

45

InvocationTargetExceptionは、動的呼び出し中にスローされます例外の単なるラッパーです。

Caused by: java.lang.NullPointerException 
    at com.qasim.platformer.GameLayer.canExecuteMovement(GameLayer.java:107) 
    at com.qasim.platformer.GameLayer.gameLoop(GameLayer.java:86) 

をあなたが指摘してきたように、これは問題のある行です::真の問題は、それがラップだということNullPointerExceptionある

if (Rect.intersects(projectedBounds, platform[i].getBounds())) { 

NULLポインタがこの回線で起きてできる唯一の場所ですplatform[i].getBounds()platform自体はnull、またはplatform[i]の要素はです。

+3

あなたが通過している人のために、あなたは 'e.getCause()'によってこれの_cause_を見ることができます。 – djthoms

関連する問題