логика остановки слежения

20

Я хочу разработать простую логику секундомера в android.

При нажатии на просмотр списка должен начинаться таймер, а при нажатии кнопки таймер должен остановиться. Кто-нибудь может направить меня. Любой пример кода будет очень полезен

    
задан Rahul Varma 17.09.2010 в 10:46
источник

4 ответа

34

Используйте Секундомер Класс (для более высокой точности используйте System.nanoTime() )

Добавить событие Start () и событие Stop () при нажатии кнопки. Вам нужно будет обновить интерфейс, чтобы использовать комбинацию Thread / Handler.

Это должно помочь вам начать.

EDIT: Добавлен код. (Nice Упражнение! :))

Используйте Refresh_Rate , чтобы настроить, как часто обновляется пользовательский интерфейс.

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

public class Main extends Activity implements OnClickListener{

    final int MSG_START_TIMER = 0;
    final int MSG_STOP_TIMER = 1;
    final int MSG_UPDATE_TIMER = 2;

    Stopwatch timer = new Stopwatch();
    final int REFRESH_RATE = 100;

    Handler mHandler = new Handler()
    {
        @Override
        public void handleMessage(Message msg) {
            super.handleMessage(msg);
            switch (msg.what) {
            case MSG_START_TIMER:
                timer.start(); //start timer
                mHandler.sendEmptyMessage(MSG_UPDATE_TIMER);
                break;

            case MSG_UPDATE_TIMER:
                tvTextView.setText(""+ timer.getElapsedTime());
                mHandler.sendEmptyMessageDelayed(MSG_UPDATE_TIMER,REFRESH_RATE); //text view is updated every second, 
                break;                                  //though the timer is still running
            case MSG_STOP_TIMER:
                mHandler.removeMessages(MSG_UPDATE_TIMER); // no more updates.
                timer.stop();//stop timer
                tvTextView.setText(""+ timer.getElapsedTime());
                break;

            default:
                break;
            }
        }
    };

    TextView tvTextView;
    Button btnStart,btnStop;

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        tvTextView = (TextView)findViewById(R.id.TextView01);

        btnStart = (Button)findViewById(R.id.Button01);
        btnStop= (Button)findViewById(R.id.Button02);
        btnStart.setOnClickListener(this);
        btnStop.setOnClickListener(this);

    }

    public void onClick(View v) {
        if(btnStart == v)
        {
            mHandler.sendEmptyMessage(MSG_START_TIMER);
        }else
        if(btnStop == v){
            mHandler.sendEmptyMessage(MSG_STOP_TIMER);
        }
    }
}
    
ответ дан st0le 17.09.2010 в 11:22
источник
  • Извините за продолжение вопроса ... На самом деле я застрял в обновлении пользовательского интерфейса в Android. Я использовал этот класс в java. Но, как я могу обновить, скажем, ярлык с показом времени ... ??? –  Rahul Varma 17.09.2010 в 11:38
  • @Rahul, напишите, что у вас есть, я опишу это ... –  st0le 17.09.2010 в 11:44
  • У меня простой макет. Метка и две кнопки. При нажатии на запуск должен начинаться таймер и при нажатии на остановку таймер должен останавливаться ... Это все. Ничего сложного. Просто нужно, как запустить таймер и обновить ярлык со временем ... –  Rahul Varma 17.09.2010 в 12:32
  • Конечно, существует стандартный класс хронометров: developer.android.com/reference/android/widget/Chronometer.html –  tbm 17.09.2014 в 21:12
  • ваша ссылка секундомера мертва –  Xitcod13 02.06.2015 в 10:10
Показать остальные комментарии
13

Поскольку st0le дал отличный пример, используя Секундомер . Я немного изменил этот класс и добавил несколько методов к нему.

/*
Copyright (c) 2005, Corey Goldberg

StopWatch.java is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.

Modified: Bilal Rabbani [email protected] (Nov 2013)
*/

package bilalrabbani1.at.live.com;

public class Stopwatch {
private long startTime = 0;
private boolean running = false;
private long currentTime = 0;

public void start() {
    this.startTime = System.currentTimeMillis();
    this.running = true;
}

public void stop() {
    this.running = false;
}

public void pause() {
    this.running = false;
    currentTime = System.currentTimeMillis() - startTime;
}
public void resume() {
    this.running = true;
    this.startTime = System.currentTimeMillis() - currentTime;
}

//elaspsed time in milliseconds
public long getElapsedTimeMili() {
    long elapsed = 0;
    if (running) {
         elapsed =((System.currentTimeMillis() - startTime)/100) % 1000 ;
    }
    return elapsed;
}

//elaspsed time in seconds
public long getElapsedTimeSecs() {
    long elapsed = 0;
    if (running) {
        elapsed = ((System.currentTimeMillis() - startTime) / 1000) % 60;
    }
    return elapsed;
}

  //elaspsed time in minutes
public long getElapsedTimeMin() {
    long elapsed = 0;
    if (running) {
        elapsed = (((System.currentTimeMillis() - startTime) / 1000) / 60 ) % 60;
    }
    return elapsed;
}

//elaspsed time in hours
public long getElapsedTimeHour() {
    long elapsed = 0;
    if (running) {
        elapsed = ((((System.currentTimeMillis() - startTime) / 1000) / 60 ) / 60);
    }
    return elapsed;
}

public String toString() {
    return getElapsedTimeHour() + ":" + getElapsedTimeMin() + ":"
            + getElapsedTimeSecs() + "." + getElapsedTimeMili();
}
}

Привет     

ответ дан Bilal Rabbani 12.03.2014 в 17:22
источник
  • Именно то, что я хочу. Благодаря!!! –  Ganesh Katikar 17.01.2018 в 13:19
0

Хороший пример, на всякий случай, если кто-то хочет, чтобы этот файл макета шел с этим (довольно просто).

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" >

<TextView
    android:id="@+id/textView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="@string/hello_world" />

<EditText
    android:id="@+id/TextView01"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignLeft="@+id/textView1"
    android:layout_below="@+id/textView1"
    android:layout_marginLeft="18dp"
    android:layout_marginTop="49dp"
    android:ems="10" >

    <requestFocus />
</EditText>

<Button
    android:id="@+id/Button01"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/TextView01"
    android:layout_marginTop="42dp"
    android:layout_toRightOf="@+id/textView1"
    android:text="Start" />

<Button
    android:id="@+id/Button02"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/Button01"
    android:layout_marginTop="14dp"
    android:layout_toRightOf="@+id/textView1"
    android:text="Stop" />

    
ответ дан Waqas 06.03.2014 в 14:21
источник
0

На основе IntentService, без зависимостей от SDK и от одного файла :

import android.app.Activity;
import android.app.IntentService;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.content.LocalBroadcastManager;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.TextView;

public class Main extends Activity {
    static final String BROADCAST_ACTION = "com.cirosantilli.android_cheat.intent_service_text_view.BROADCAST";
    static final String EXTENDED_DATA_STATUS = "com.cirosantilli.android_cheat.intent_service_text_view.BROADCAST";
    static final String TAG = "com.cirosantilli";

    private int i = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        Log.d(TAG, "onCreate");
        super.onCreate(savedInstanceState);
        final LinearLayout linearLayout = new LinearLayout(this);
        Button button;
        final Intent intent = new Intent(Main.this, MyService.class);

        button = new Button(this);
        button.setText("start service");
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.d(TAG, "start button");
                Main.this.startService(intent.putExtra(Main.EXTENDED_DATA_STATUS, Main.this.i));
            }
        });
        linearLayout.addView(button);

        button = new Button(this);
        button.setText("stop service");
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Log.d(TAG, "stop button");
                Main.this.stopService(intent);
            }
        });
        linearLayout.addView(button);

        final TextView textView = new TextView(this);
        textView.setText(Integer.toString(i));
        linearLayout.addView(textView);
        this.setContentView(linearLayout);

        LocalBroadcastManager.getInstance(this).registerReceiver(
                new BroadcastReceiver() {
                    @Override
                    public void onReceive(Context context, Intent intent) {
                        Main.this.i = intent.getIntExtra(Main.EXTENDED_DATA_STATUS, 0);
                        textView.setText(Integer.toString(Main.this.i));
                    }
                }, new IntentFilter(Main.BROADCAST_ACTION)
        );
    }

    public static class MyService extends IntentService {
        private Handler mHandler;
        private int i = 1;
        private boolean done;
        public MyService() {
            super("MyService");
        }
        @Override
        protected void onHandleIntent(Intent intent) {
            Log.d(TAG, "onHandleIntent");
            this.i = intent.getIntExtra(Main.EXTENDED_DATA_STATUS, 0);
            this.done = false;
            while(!done) {
                Log.d(TAG, "while true");
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    Thread.currentThread().interrupt();
                }
                LocalBroadcastManager.getInstance(this).sendBroadcast(
                        new Intent(Main.BROADCAST_ACTION)
                        .putExtra(Main.EXTENDED_DATA_STATUS, MyService.this.i));
                this.i++;
            }
        }
        @Override
        public void onDestroy() {
            Log.d(TAG, "onDestroy");
            this.done = true;
            super.onDestroy();
        }
    }
}

Только для низкой точности. Мы могли бы получить повышенную точность, используя System.currentTimeMillis внутри onHandleIntent вместо использования целочисленного значения и уменьшая время ожидания, чтобы уменьшить задержку.

Протестировано на Android 22. Стандартный шаблон сборки здесь .

    
ответ дан Ciro Santilli 新疆改造中心 六四事件 法轮功 14.02.2016 в 14:08
источник