-1

AndEngine を使用してゲームを作成していますが、このエラーが発生する理由がわかりません。以前は機能していたようで、どのコードの変更がエラーの原因なのかわかりません。誰にもアイデアはありますか?

    07-02 01:34:44.747: E/AndroidRuntime(19252): java.lang.ArrayIndexOutOfBoundsException
07-02 01:34:44.747: E/AndroidRuntime(19252):    at com.prattia.webs.testgfx5.TestGFX5Activity$2.onAreaTouched(TestGFX5Activity.java:249)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.entity.scene.Scene.onAreaTouchEvent(Scene.java:409)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.entity.scene.Scene.onSceneTouchEvent(Scene.java:328)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.engine.Engine.onTouchScene(Engine.java:452)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.engine.Engine.onTouchEvent(Engine.java:438)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.input.touch.controller.BaseTouchController$TouchEventRunnablePoolItem.run(BaseTouchController.java:102)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.util.adt.pool.RunnablePoolUpdateHandler.onHandlePoolItem(RunnablePoolUpdateHandler.java:54)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.util.adt.pool.RunnablePoolUpdateHandler.onHandlePoolItem(RunnablePoolUpdateHandler.java:1)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.util.adt.pool.PoolUpdateHandler.onUpdate(PoolUpdateHandler.java:88)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.input.touch.controller.BaseTouchController.onUpdate(BaseTouchController.java:62)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.engine.Engine.onUpdate(Engine.java:584)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.engine.Engine.onTickUpdate(Engine.java:548)
07-02 01:34:44.747: E/AndroidRuntime(19252):    at org.andengine.engine.Engine$UpdateThread.run(Engine.java:820)

そして、私のコードのそのセクション:

private void createFiller(float x, float y) {
        fillerNum++;
        Log.e("Creating Filler",Integer.toString(fillerNum));
        filler[fillerNum].active=true;
        filler[fillerNum].sprite = new Sprite(x-fillerTR.getWidth()/2,y - fillerTR.getHeight()/2,fillerTR,getVertexBufferObjectManager())
        {
            @Override
            public boolean onAreaTouched(TouchEvent pSceneTouchEvent, float pTouchAreaLocalX, float pTouchAreaLocalY){
                if(pSceneTouchEvent.isActionMove()){
                    setPosition(pSceneTouchEvent.getX() - getWidth() / 2, pSceneTouchEvent.getY() - getHeight() / 2);
                }
                if(pSceneTouchEvent.isActionUp()){
                    Log.e("Action Up",Integer.toString(fillerNum));
                    if(!filler[fillerNum].body.getUserData().equals("destroyed"))//Line 249
                        createStationaryFiller();
                }
                return true;
            }
        };

        scene.registerTouchArea(filler[fillerNum].sprite);

        filler[fillerNum].body = PhysicsFactory.createCircleBody(mPhysicsWorld, filler[fillerNum].sprite, BodyType.DynamicBody, FIXTURE_DEF);
        filler[fillerNum].body.setUserData("fill");
        mPhysicsWorld.registerPhysicsConnector(new PhysicsConnector(filler[fillerNum].sprite, filler[fillerNum].body, true, true));
        scene.attachChild(filler[fillerNum].sprite);
    }

他に説明やコードが必要な場合はお知らせください。投稿できます。私は困惑しています!

4

1 に答える 1

0

行番号はいいでしょうが、fillerNum がフィラー配列のサイズよりも大きいと思われます。とにかく、スタック トレースは、249 行目で例外がスローされたことを示しているため、その行を見つけて問題を見つけることができます :)

于 2012-07-02T08:46:12.957 に答える