"[AppName] остановлено" на моем физическом устройстве. ОШИБКА в logcat: java.lang.NullPointerException

Я работал над игрой в Android Studio и libgdx, и всякий раз, когда я запускаю ее на своем физическом устройстве, он говорит: "[AppName] остановился".

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

Это ошибка, которую я получил в logcat:

10-06 12:01:51.055 21591-21627/com.jpfalmazan.ninjaassault E/AndroidRuntime: FATAL EXCEPTION: GLThread 2891
                                                                             java.lang.NullPointerException
                                                                                 at com.jpfalmazan.ninjaassault.GameScreens.MenuScreen.<init>(MenuScreen.java:23)
                                                                                 at com.jpfalmazan.ninjaassault.NinjaAssault.create(NinjaAssault.java:19)
                                                                                 at com.badlogic.gdx.backends.android.AndroidGraphics.onSurfaceChanged(AndroidGraphics.java:275)
                                                                                 at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1505)
                                                                                 at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1240)

Вот мой код для игры:

package com.jpfalmazan.ninjaassault;

import com.badlogic.gdx.Game;

import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.graphics.GL20;
import com.badlogic.gdx.graphics.Texture;
import com.badlogic.gdx.graphics.g2d.SpriteBatch;
import com.jpfalmazan.ninjaassault.GameScreens.MenuScreen;


public class NinjaAssault extends Game {
    public SpriteBatch batch;
    Texture img;

    @Override
    public void create () {
        batch = new SpriteBatch();
        this.setScreen(new MenuScreen(this));   ////This is the "NinjaAssault.java:19 " error shown in logcat 
    }

    @Override
    public void render () {
        super.render();
        Gdx.gl.glClearColor(1,0,0,1);
        Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
        batch.begin();
    }

    @Override
    public void dispose () {
        batch.dispose();
        img.dispose();
    }
}

А вот мой код в классе MenuScreen:

package com.jpfalmazan.ninjaassault.GameScreens;

import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.Screen;
import com.badlogic.gdx.graphics.GL20;
import com.badlogic.gdx.graphics.Texture;
import com.badlogic.gdx.graphics.g2d.SpriteBatch;
import com.jpfalmazan.ninjaassault.NinjaAssault;

public class MenuScreen implements Screen{
    NinjaAssault game;
    public MenuScreen (NinjaAssault game){
        this.game = game;
    }
    public SpriteBatch batch;
    public Texture background;
    public Texture title;
    public Texture playButtonINACTIVE;
    public Texture playButtonACTIVE;

    public float screenWidth = Gdx.graphics.getWidth();
    public float screenHeight = Gdx.graphics.getHeight();
    public float titleWidth = title.getWidth();  //This is the "MenuScreen.java:23" error shown in logcat 
    public float titleHeight = title.getHeight();
    public float xLimit1 = (float) ((screenWidth/2)-(titleWidth/2));
    public float xLimit2 = (float) ((screenWidth/2)+(titleWidth/2));
    public float yLimit1 = (float) ((screenHeight*.35));
    public float yLimit2 = (float) ((screenHeight*.35)+titleHeight);



    @Override
    public void show() {
        batch = new SpriteBatch();
        background = new Texture("BGYELL.png");
        title = new Texture ("BGASTRO.png");
        playButtonINACTIVE = new Texture("BTPLAY.png");
        playButtonACTIVE = new Texture("BTPLAYON.png");

    }

    @Override
    public void render(float delta) {
        Gdx.gl.glClearColor(1,0,0,1);
        Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
        game.batch.begin();
        game.batch.draw(background,0,0,screenWidth,screenHeight);
        if((Gdx.input.getX()> xLimit1 && Gdx.input.getX() < xLimit2) && (Gdx.input.getY() < yLimit2 && Gdx.input.getY() > yLimit1 ) ){
            game.batch.draw(playButtonACTIVE,(screenWidth/2)-(playButtonACTIVE.getWidth()/2), (float) (screenHeight*.35));
        }else  game.batch.draw(playButtonINACTIVE,(screenWidth/2)-(playButtonINACTIVE.getWidth()/2), (float) (screenHeight*.35));
        game.batch.draw(title,(screenWidth/2)-((float)(screenWidth*.8)/2), (float) (screenHeight*.65),(float)(screenWidth*.8) , (float) ((screenWidth*.8)*(titleHeight/titleWidth)));




        game.batch.end();
    }

    @Override
    public void resize(int width, int height) {

    }

    @Override
    public void pause() {

    }

    @Override
    public void resume() {

    }

    @Override
    public void hide() {

    }

    @Override
    public void dispose() {

    }
}

1 ответ

Решение

Вы еще не установили "заголовок". Вы только объявили, что это существует. title устанавливается в show(), которая вызывается после конструктора. Вам нужно сделать

title = new Texture ("BGASTRO.png");

ДО того, как вы попытаетесь получить высоту текстуры. Это относится и ко всем другим переменным, убедитесь, что они установлены на что-то перед использованием.

Кроме того, вы должны удалить

 Gdx.gl.glClearColor(1,0,0,1);
 Gdx.gl.glClear(GL20.GL_COLOR_BUFFER_BIT);
 batch.begin();

от вас рендер () в классе NinjaAssault. Это не нужно, и если вы звоните

batch.begin()

тебе нужно позвонить

batch.end()

тоже, но в этом случае его никогда не использовали, так что не нужно вообще.

Другие вопросы по тегам