Android应用的屏幕旋转不断崩溃

时间:2018-03-01 20:23:01

标签: java android tic-tac-toe screen-rotation

我做了一个tic tac toe应用程序,我想能够允许应用程序旋转而不重新启动应用程序。我学会了如何在课堂上进行屏幕旋转,并且我编写了一个OnSaveInstanceState方法,但是我的应用程序一直在崩溃。它运行时没有这种方法,所以我知道它有问题但是不确定。

package com.example.johnavan.tictactoeassingment2;
import android.graphics.Color;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

    private static final String TAG = "TicTacToeGame";
    private static String GAME_INDEX = "game_index";
    private TicTacToeGame mGame;

    private Button mBoardButtons[];

    private TextView mInfoTextView;
    private TextView mHumanCount;
    private TextView mTieCount;
    private TextView mAndroidCount;

    private int mHumanCounter = 0;
    private int mTieCounter = 0;
    private int mAndroidCounter = 0;

    private boolean mHumanFirst = true;
    private boolean mGameOver = false;

    @Override
    public void onSaveInstanceState(Bundle savedInstanceState) {

        // Always call the superclass so it can save the view hierarchy state
        super.onSaveInstanceState(savedInstanceState);
        savedInstanceState.putInt(GAME_INDEX, mHumanCounter);
        savedInstanceState.putInt(GAME_INDEX, mTieCounter);
        savedInstanceState.putInt(GAME_INDEX, mAndroidCounter);
        Log.i(TAG, "onSaveInstanceState(Bundle)");
    }


    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);


        if(savedInstanceState != null)
            mHumanCounter = savedInstanceState.getInt(GAME_INDEX, 0);
            mTieCounter = savedInstanceState.getInt(GAME_INDEX, 0);
            mAndroidCounter = savedInstanceState.getInt(GAME_INDEX, 0);

        mBoardButtons = new Button[mGame.getBoardSize()];
        mBoardButtons[0] = (Button) findViewById(R.id.one);
        mBoardButtons[1] = (Button) findViewById(R.id.two);
        mBoardButtons[2] = (Button) findViewById(R.id.three);
        mBoardButtons[3] = (Button) findViewById(R.id.four);
        mBoardButtons[4] = (Button) findViewById(R.id.five);
        mBoardButtons[5] = (Button) findViewById(R.id.six);
        mBoardButtons[6] = (Button) findViewById(R.id.seven);
        mBoardButtons[7] = (Button) findViewById(R.id.eight);
        mBoardButtons[8] = (Button) findViewById(R.id.nine);

        mInfoTextView = (TextView) findViewById(R.id.information);
        mHumanCount = (TextView) findViewById(R.id.humanCount);
        mTieCount = (TextView) findViewById(R.id.tiesCount);
        mAndroidCount = (TextView) findViewById(R.id.androidCount);

        mHumanCount.setText(Integer.toString(mHumanCounter));
        mTieCount.setText(Integer.toString(mTieCounter));
        mAndroidCount.setText(Integer.toString(mAndroidCounter));


        mGame = new TicTacToeGame();

        startNewGame();

    }



private void startNewGame()
{
    mGame.clearBoard();

    for (int i = 0; i < mBoardButtons.length; i++)
    {
        mBoardButtons[i].setText("");
        mBoardButtons[i].setEnabled(true);
        mBoardButtons[i].setOnClickListener(new ButtonClickListener(i));
    }

    if (mHumanFirst)
    {
        mInfoTextView.setText(R.string.first_human);
        mHumanFirst = false;}
    else
    {
        mInfoTextView.setText(R.string.turn_computer);
        int move = mGame.getComputerMove();
        setMove(mGame.COMP_PLAYER, move);
        mHumanFirst = true;
    }
}

private class ButtonClickListener implements View.OnClickListener
{
    int location;

    public ButtonClickListener(int location)
    {
        this.location = location;
    }

    public void onClick(View view)
    {
        if (!mGameOver)
        {
            if (mBoardButtons[location].isEnabled())
            {
                setMove(mGame.HUMAN_PLAYER, location);

                int winner = mGame.checkForWinner();

                if (winner == 0)
                {
                    mInfoTextView.setText(R.string.turn_computer);
                    int move = mGame.getComputerMove();
                    setMove(mGame.COMP_PLAYER, move);
                    winner = mGame.checkForWinner();

                }

                if (winner == 0)
                    mInfoTextView.setText(R.string.turn_human);
                else if (winner == 1)
                {
                    mInfoTextView.setText(R.string.result_tie);
                    mTieCounter++;
                    mTieCount.setText(Integer.toString(mTieCounter));
                    mGameOver = true;
                    startNewGame();
                    mGameOver = false;

                }
                else if (winner == 2)
                {
                    mInfoTextView.setText(R.string.result_human_wins);
                    mHumanCounter++;
                    mHumanCount.setText(Integer.toString(mHumanCounter));
                    mGameOver = true;
                    startNewGame();
                    mGameOver = false;
                }
                else
                {
                    mInfoTextView.setText(R.string.result_android_wins);
                    mAndroidCounter++;
                    mAndroidCount.setText(Integer.toString(mAndroidCounter));
                    mGameOver = true;
                    startNewGame();
                    mGameOver = false;

                }
            }
        }
    }
}

private void setMove(char player, int location)
{
    mGame.setMove(player, location);
    mBoardButtons[location].setEnabled(false);
    mBoardButtons[location].setText(String.valueOf(player));
    if (player == mGame.HUMAN_PLAYER)
        mBoardButtons[location].setTextColor(Color.GREEN);
    else
        mBoardButtons[location].setTextColor(Color.RED);
}
}

2 个答案:

答案 0 :(得分:0)

尝试

 if(savedInstanceState != null){
        mHumanCounter = savedInstanceState.getInt(GAME_INDEX, 0);
        mTieCounter = savedInstanceState.getInt(GAME_INDEX, 0);
        mAndroidCounter = savedInstanceState.getInt(GAME_INDEX, 0);
  }

你应该总是在你的陈述中加上括号,即使它是一个衬垫。这是一个很好的做法。

答案 1 :(得分:0)

删除

    @Override
    public void onSaveInstanceState(Bundle savedInstanceState) {
    // Always call the superclass so it can save the view hierarchy 
       state
    super.onSaveInstanceState(savedInstanceState);
    savedInstanceState.putInt(GAME_INDEX, mHumanCounter);
    savedInstanceState.putInt(GAME_INDEX, mTieCounter);
    savedInstanceState.putInt(GAME_INDEX, mAndroidCounter);
    Log.i(TAG, "onSaveInstanceState(Bundle)");
}

 if(savedInstanceState != null)
        mHumanCounter = savedInstanceState.getInt(GAME_INDEX, 0);
        mTieCounter = savedInstanceState.getInt(GAME_INDEX, 0);
        mAndroidCounter = savedInstanceState.getInt(GAME_INDEX, 0);

只需在您的清单上添加此内容

 <activity
        android:name=".MainActivity"
        android:configChanges="orientation|screenSize"/>

它应该有用。