0

そこで、経過時間を画面に出力するシンプルなタイマーアプリを作ろうとしています。一時停止ボタンを組み込んでみました。一時停止ボタンが押されて x:x:1~ (min:sec:milli) の値に近づいた場合を除いて、動作しているようです。 1) x:x-1:9~ ではなく。以下の Logcat 出力。DISPLAY は表示される時間です (残り時間、常に減少している必要がありますが、そうではありません)。Elapsed time は内部の経過時間です (常に増加しているので問題ないようです)

    10-09 23:28:16.152: D/ClockView(16547): ELAPSED TIME 1728
    10-09 23:28:16.152: D/ClockView(16547): DISPLAY 0:8:272
    10-09 23:28:16.252: D/ClockView(16547): ELAPSED TIME 1829
    10-09 23:28:16.252: D/ClockView(16547): DISPLAY 0:8:171
    10-09 23:28:16.282: D/ClockView(16547): PAUSE PRESSED
    10-09 23:28:16.983: D/ClockView(16547): PAUSE PRESSED
    10-09 23:28:16.983: D/ClockView(16547): ELAPSED TIME 1868
    10-09 23:28:16.983: D/ClockView(16547): DISPLAY 0:8:132
    10-09 23:28:17.083: D/ClockView(16547): ELAPSED TIME 1968
    10-09 23:28:17.083: D/ClockView(16547): DISPLAY 0:8:32
    10-09 23:28:17.123: D/ClockView(16547): PAUSE PRESSED
    10-09 23:28:21.348: D/ClockView(16547): PAUSE PRESSED
    10-09 23:28:21.348: D/ClockView(16547): ELAPSED TIME 2010
    10-09 23:28:21.348: D/ClockView(16547): DISPLAY 0:7:990
    10-09 23:28:21.448: D/ClockView(16547): ELAPSED TIME 2110
    10-09 23:28:21.448: D/ClockView(16547): DISPLAY 0:7:890

以下のコード:

public class ClockCallable implements Callable<Long> {

    private long startTime = SystemClock.elapsedRealtime();
    private long elapsedTime = 0;
    private long pausedStartTime = 0;
    private long pausedTime = 0;        

    Object o = new Object();
    private volatile boolean paused = false;

    public void pause() {
        paused = true;
        synchronized(o) {
            pausedStartTime = SystemClock.elapsedRealtime();
        }
    }
    public void resume() {
        paused = false;
        synchronized(o) {
            pausedTime = SystemClock.elapsedRealtime() - pausedStartTime;
            startTime += pausedTime;

            o.notifyAll();              
        }
    }

    public void reset() {
        paused = false;
        synchronized(o) {
            clockCallable.startTime = SystemClock.elapsedRealtime();
            clockCallable.elapsedTime = 0;
            clockCallable.pausedStartTime = 0;
            clockCallable.pausedTime = 0;

            o.notifyAll();              
        }
    }

    @Override
    public Long call() throws Exception {

        try {               
            while (elapsedTime < maxTime && !Thread.currentThread().isInterrupted()) {

                if (!paused) {
                    elapsedTime = SystemClock.elapsedRealtime() - startTime;
                    Log.d(TAG, "ELAPSED TIME " + elapsedTime);
                    handler.post(new Runnable() { //To post to UI thread
                        @Override
                        public void run() {
                            synchronized(o) {
                                updateTextView(elapsedTime);
                            }
                        }
                    });

                    Thread.sleep(100); //Prevent too much work on its main thread
                    if (Thread.currentThread().isInterrupted()) {
                        return (long) -1; //For future.cancel() handling
                    }
                }
                else {
                    try {
                        while(paused) {
                            synchronized(o) {
                                o.wait();
                            }
                        }
                    }
                    catch (InterruptedException e) {}
                }

            }           
        }
        catch (InterruptedException e) {
            e.printStackTrace();
            return (long) -1; //For future.cancel() handling
        }

        return (long) 1;
    }

}
4

1 に答える 1

0

気にしないで、私は問題を解決しました。表示テキストのフォーマット方法に問題がありました。同期とは何の関係もありません。間違った場所を探すのに時間がかかりすぎました。

于 2013-10-12T00:51:29.423 に答える