@felix
Для создания секундомера с использованием Handler
в Kotlin, вы можете использовать следующий код:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 |
class Stopwatch { private var startTime: Long = 0 private var elapsedTime: Long = 0 private var isRunning: Boolean = false private val handler = Handler() private val tick = object : Runnable { override fun run() { val now = System.currentTimeMillis() elapsedTime += now - startTime startTime = now val minutes = (elapsedTime / 1000) / 60 val seconds = (elapsedTime / 1000) % 60 val milliseconds = elapsedTime % 1000 val time = String.format("%02d:%02d:%03d", minutes, seconds, milliseconds) onTickListener?.onTick(time) handler.postDelayed(this, INTERVAL) } } private var onTickListener: OnTickListener? = null fun start() { if (!isRunning) { startTime = System.currentTimeMillis() handler.post(tick) isRunning = true } } fun stop() { if (isRunning) { handler.removeCallbacks(tick) isRunning = false } } fun reset() { elapsedTime = 0 onTickListener?.onTick("00:00:000") } fun setOnTickListener(listener: OnTickListener) { onTickListener = listener } interface OnTickListener { fun onTick(time: String) } companion object { private const val INTERVAL = 10L // update interval in milliseconds } } |
Этот класс предоставляет методы start()
, stop()
и reset()
, чтобы запускать, останавливать и сбрасывать секундомер. Он также определяет интерфейс OnTickListener
, который позволяет уведомлять слушателей о прошедшем времени в определенные моменты времени.
Чтобы использовать класс Stopwatch
, создайте экземпляр класса и установите слушатель для обработки событий тика:
1 2 3 4 5 6 7 8 |
val stopwatch = Stopwatch() stopwatch.setOnTickListener(object : Stopwatch.OnTickListener { override fun onTick(time: String) { // обновлять UI с текущим временем } }) stopwatch.start() // запуск секундомера |
Этот код запустит секундомер и обновляет UI каждые 10 миллисекунд с текущим временем, используя метод onTick()
слушателя. Вы можете настроить интервал обновления, изменив значение константы INTERVAL
в классе Stopwatch
.
@felix
Вот пример того, как можно использовать класс Stopwatch для создания секундомера и отображения времени в TextView:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
class MainActivity : AppCompatActivity() { private lateinit var stopwatch: Stopwatch private lateinit var timeTextView: TextView override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) timeTextView = findViewById(R.id.timeTextView) stopwatch = Stopwatch() stopwatch.setOnTickListener(object : Stopwatch.OnTickListener { override fun onTick(time: String) { runOnUiThread { timeTextView.text = time } } }) findViewById<Button>(R.id.startButton).setOnClickListener { stopwatch.start() } findViewById<Button>(R.id.stopButton).setOnClickListener { stopwatch.stop() } findViewById<Button>(R.id.resetButton).setOnClickListener { stopwatch.reset() } } } |
В этом коде создается MainActivity, в котором инициализируется класс Stopwatch и устанавливается слушатель для обновления текстового поля timeTextView с текущим временем. Также добавлены кнопки для запуска, остановки и сброса секундомера.
Не забудьте добавить разметку для activity_main.xml:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
<?xml version="1.0" encoding="utf-8"?> <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:padding="16dp" tools:context=".MainActivity"> <TextView android:id="@+id/timeTextView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="24sp" android:text="00:00:000" android:layout_centerHorizontal="true" android:layout_marginBottom="16dp"/> <Button android:id="@+id/startButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Start" android:layout_below="@id/timeTextView" android:layout_marginTop="16dp"/> <Button android:id="@+id/stopButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Stop" android:layout_toEndOf="@id/startButton" android:layout_marginStart="16dp" android:layout_below="@id/timeTextView" android:layout_marginTop="16dp"/> <Button android:id="@+id/resetButton" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Reset" android:layout_toEndOf="@id/stopButton" android:layout_marginStart="16dp" android:layout_below="@id/timeTextView" android:layout_marginTop="16dp"/> </RelativeLayout> |
Этот код позволит вам создать секундомер с handler на Kotlin в вашем Android-приложении.