私が作成しているTic-Tac-Toeアプリでは、向きの変更を処理するための代替画面ビューを設定しました。
メインのJavaファイルのonCreate()メソッドは次のようになります。
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
mInfoTextView = (TextView) findViewById(R.id.information);
mHumanScoreTextView = (TextView) findViewById(R.id.player_score);
mComputerScoreTextView = (TextView) findViewById(R.id.computer_score);
mTieScoreTextView = (TextView) findViewById(R.id.tie_score);
mGame = new TicTacToeGame();
mBoardView = (BoardView) findViewById(R.id.board);
mBoardView.setGame(mGame);
mBoardView.setOnTouchListener(mTouchListener);
if (savedInstanceState == null)
startNewGame();
else {
mGame.setBoardState(savedInstanceState.getCharArray("board"));
mGameOver = savedInstanceState.getBoolean("mGameOver");
mInfoTextView.setText(savedInstanceState.getCharSequence("info"));
mHumanWins = savedInstanceState.getInt("mHumanWins");
mComputerWins = savedInstanceState.getInt("mComputerWins");
mTies = savedInstanceState.getInt("mTies");
mTurn = savedInstanceState.getChar("mTurn");
mFirstMove = savedInstanceState.getChar("mFirstMove");
}
displayScores();
}
次に、状態の復元と保存を処理する2つの方法があります。
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
outState.putCharArray("board", mGame.getBoardState());
outState.putBoolean("mGameOver", mGameOver);
outState.putInt("mHumanWins", Integer.valueOf(mHumanWins));
outState.putInt("mComputerWins", Integer.valueOf(mComputerWins));
outState.putInt("mTies", Integer.valueOf(mTies));
outState.putCharSequence("info", mInfoTextView.getText());
outState.putChar("mTurn", mTurn);
outState.putChar("mFirstMove", mFirstMove);
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
super.onRestoreInstanceState(savedInstanceState);
mGame.setBoardState(savedInstanceState.getCharArray("board"));
mGameOver = savedInstanceState.getBoolean("mGameOver");
mInfoTextView.setText(savedInstanceState.getCharSequence("info"));
mHumanWins = savedInstanceState.getInt("mHumanWins");
mComputerWins = savedInstanceState.getInt("mComputerWins");
mTies = savedInstanceState.getInt("mTies");
mTurn = savedInstanceState.getChar("mTurn");
mFirstMove = savedInstanceState.getChar("mFirstMove");
}
ボードにXとOの文字が表示される代わりに、XとOを表す画像が表示されるようにゲームを再プログラムするまでは、すべて問題ありませんでした。これを行うには、TouchListenerを実装する必要がありました。ゲームは垂直モードで完全に実行されますが、向きが変わるとすぐにクラッシュします。反転した画面が変化するのを見ることさえできません。layout-land main.xmlファイルで水平レイアウトを表示すると、問題なく表示されます。アプリがクラッシュせずに実際に実行されているときは、アクセスに近づくことができません。
私はまったくの初心者なので、これを引き起こしている原因や、さらに役立つ情報を投稿するための関連情報がわかりません。誰かアドバイスはありますか?
編集-これはLogCatエラーログです:実際のデバイスで向きを変更するとプログラムがクラッシュしますが、エミュレータではプログラムが実行されるとすぐにクラッシュします
03-22 00:27:31.739: E/Trace(1042): error opening trace file: No such file or directory (2)
03-22 00:27:31.739: W/Trace(1042): Unexpected value from nativeGetEnabledTags: 0
03-22 00:27:31.739: W/Trace(1042): Unexpected value from nativeGetEnabledTags: 0
03-22 00:27:31.749: W/Trace(1042): Unexpected value from nativeGetEnabledTags: 0
03-22 00:27:31.789: W/Trace(1042): Unexpected value from nativeGetEnabledTags: 0
03-22 00:27:31.789: W/Trace(1042): Unexpected value from nativeGetEnabledTags: 0
03-22 00:27:31.909: D/AndroidRuntime(1042): Shutting down VM
03-22 00:27:31.909: W/dalvikvm(1042): threadid=1: thread exiting with uncaught exception (group=0x40a70930)
03-22 00:27:31.920: E/AndroidRuntime(1042): FATAL EXCEPTION: main
03-22 00:27:31.920: E/AndroidRuntime(1042): java.lang.RuntimeException: Unable to start activity ComponentInfo{edu.joe.tictactoe/edu.joe.tictactoe.AndroidTicTacToeActivity}: java.lang.NullPointerException
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread.access$600(ActivityThread.java:141)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.os.Handler.dispatchMessage(Handler.java:99)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.os.Looper.loop(Looper.java:137)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread.main(ActivityThread.java:5039)
03-22 00:27:31.920: E/AndroidRuntime(1042): at java.lang.reflect.Method.invokeNative(Native Method)
03-22 00:27:31.920: E/AndroidRuntime(1042): at java.lang.reflect.Method.invoke(Method.java:511)
03-22 00:27:31.920: E/AndroidRuntime(1042): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
03-22 00:27:31.920: E/AndroidRuntime(1042): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
03-22 00:27:31.920: E/AndroidRuntime(1042): at dalvik.system.NativeStart.main(Native Method)
03-22 00:27:31.920: E/AndroidRuntime(1042): Caused by: java.lang.NullPointerException
03-22 00:27:31.920: E/AndroidRuntime(1042): at edu.joe.tictactoe.AndroidTicTacToeActivity.resetButtons(AndroidTicTacToeActivity.java:194)
03-22 00:27:31.920: E/AndroidRuntime(1042): at edu.joe.tictactoe.AndroidTicTacToeActivity.displayScores(AndroidTicTacToeActivity.java:311)
03-22 00:27:31.920: E/AndroidRuntime(1042): at edu.joe.tictactoe.AndroidTicTacToeActivity.onCreate(AndroidTicTacToeActivity.java:93)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.Activity.performCreate(Activity.java:5104)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
03-22 00:27:31.920: E/AndroidRuntime(1042): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
03-22 00:27:31.920: E/AndroidRuntime(1042): ... 11 more
03-22 00:27:32.211: D/dalvikvm(1042): GC_CONCURRENT freed 351K, 17% free 2438K/2908K, paused 109ms+3ms, total 288ms
編集2:displayScores()およびresetButtons()コード:
192 public void resetButtons()
193 {
194 for (int i = 0; i < mBoardButtons.length; i++)
195 {
196 mBoardButtons[i].setText("");
197 mBoardButtons[i].setEnabled(true);
198 mBoardButtons[i].setOnClickListener(new ButtonClickListener(i));
199 }
200 }
304 private void displayScores() {
305 mHumanScoreTextView.setText(Integer.toString(mHumanWins));
306 mComputerScoreTextView.setText(Integer.toString(mComputerWins));
307 mTieScoreTextView.setText(Integer.toString(mTies));
308
309
310 char [] temp = mGame.getBoardState();
311 resetButtons();
312
313 for (int i = 0; i < TicTacToeGame.BOARD_SIZE; i++)
314 if (temp [i] != TicTacToeGame.OPEN_SPOT) setMove(temp [i], i);
315 }
編集3:問題は解決されました元々、ボードは文字xまたはoのいずれかで埋められたボタンを使用していました。アイコンを使用するためにこれらを削除しましたが、resetButtons()行とコードを削除するのを忘れました。存在しなくなったものをリセットしようとしていました。