質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.92%

アプリを再度開くと、タイマーが止まってしまう。

受付中

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 826

tsoT561T

score 13

制限時間付きのアプリを作りたい

現在、制限時間付きのゲームを作っています。カウントダウンしてその時間を表示させ、制限時間になると次の画面に遷移するというものです。
http://hakoniwadesign.com/?p=10770
http://hakoniwadesign.com/?p=10775
http://hakoniwadesign.com/?p=10833
上記のサイトを参考に制作しました。

発生している問題→アプリを再度開くと、カウントダウンが止まってしまう(原因がわからない)

Android StudioでRunボタンを押し実機でアプリを立ち上げると、正常に作動しカウントダウンが始まります。0秒になると次の画面へ遷移します。しかし、カウントダウンの途中でホームボタンを押し、履歴から再度アプリを開くと時間が止まっており、それ以上カウントダウンしなくなってしまいます。また、その状態からさらにホームボタンを押すと強制終了してしまいます。

該当のソースコード

ソースコードが長く、質問が投稿できないので、制限時間の部分だけをピックアップさせていただきました。

MainActivity.java
強制終了した時、onPause()のcountDownTimer.cancel()の部分でエラーが出ていました。

  protected void onPause(){
        super.onPause();
        countDownTimer.cancel();
        countDownTimer = null;
    }

    //時間制限を設ける
    protected void onResume(final int back_number) {
        super.onResume();
        countDownTimer = new CountDownTimer(alltime,100) {
            @Override
            public void onTick(long millisUntilFinished) {
                alltime = millisUntilFinished;
                int time = (int)millisUntilFinished/1000;
                ((TextView)findViewById(R.id.tv)).setText("あと" + time + "秒");
            }

            @Override
            public void onFinish() {
                //画面遷移
                Intent intent = new Intent(getApplication(), Main2Activity.class);
                intent.putExtra("back_number",back_number);
                intent.putExtra("image_syugou",imageDrawable_back);
                startActivity(intent);
            }
        }.start();
    }

MainActivity2.java

public class Main2Activity extends AppCompatActivity {

    RadioGroup radioGroup_;
    String[] s = {"フクロウ","イヌ","イルカ", "ジャガー","カモメ","シロクマ", "ネコ","オランウータン","パンダ","ペンギン","ライオン","リス", "サル","シカ","チーター", "ウマ","ウサギ","クジラ","ウシ","ゾウ"};
    int RadioButtonId[] = {R.id.RadioButton1,R.id.RadioButton2,R.id.RadioButton3,R.id.RadioButton4};

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        radioGroup_ = (RadioGroup)findViewById(R.id.RadioGroup);

        Intent intent = getIntent();

        //正解の選択肢のテキスト
        final int true_data = intent.getIntExtra("back_number",0);
        final int imageDrawable_back[] = intent.getIntArrayExtra("image_syugou");

  }
}


AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.students.pelmanism3">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".Main0Activity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".MainActivity"></activity>
        <activity android:name=".Main2Activity"></activity>
        <activity android:name=".Main3Activity"></activity>
    </application>

</manifest>

試したこと

onPause()のcountDownTimer=nullを消してみました。

protected void onPause(){
        super.onPause();
        countDownTimer.cancel();
    }


上記のようにしても変化はありませんでした。

補足情報(言語/FW/ツール等のバージョンなど)

言語はjava
Android studio 2.3.1
実機はNEXUS7

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

0

このように挙動がおかしい場合は質問者自身がデバッグをした方が効率的です。

下記のログ出力を行なってください。
・onResumeの先頭でallTimeをログ出力
・onTickの先頭でmillisUntilFinishedをログ出力
・onFinishの先頭に適当なログ出力

また、強制終了したのであればエラーログを質問に記載すべきです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/05/26 21:50 編集

    正常に動いた場合(ホームボタンを押さない場合)のログ出力
    onResume() → alltime=30000
    onTick() → millisUtilFinished=22816
    onFinish() → alltime=0
    でした。

    異常が起きた時(ホームボタンを押してアプリに戻った時)のログ出力
    onResume() → alltime=30000
    onTick() → millisUtilFinished=11391
    onPause() → alltime=11391
    countDownTimer={MainActivity$1@3997}
    でした。
    異常が起きたとき、これ以上デバックができませんでした。

    キャンセル

  • 2017/05/26 21:57

    1回目のホームボタンを押すとき、上記のようなログが出ました。そして、デバックができなくなりました(Resume Programボタンが押せない)。再びアプリに戻ったところ同じログ出力が得られました(Resume Programボタンが押せるようになった)。2回目のホームボタンを押すとき、アプリが強制終了してしまいました。。

    キャンセル

  • 2017/05/26 22:04 編集

    ログを出力する場所は次の通りです。
    protected void onPause(){
    Log.v(TAG, String.valueOf(alltime));
    Log.v(TAG, String.valueOf(countDownTimer));
    super.onPause();
    countDownTimer.cancel();
    countDownTimer = null;
    }

    protected void onResume(final int back_number) {
    Log.v(TAG, String.valueOf(alltime));
    super.onResume();

    public void onTick(long millisUntilFinished) {
    Log.v(TAG, String.valueOf(millisUntilFinished));

    public void onFinish() {
    Log.v(TAG, String.valueOf(alltime));

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る