如何用 Kotlin 在 Android 手机开发一个小闹钟、计时器、秒表

以下是在 Android 上用 Kotlin 开发小闹钟、计时器和秒表的方法,分为核心功能实现和界面设计两部分:


闹钟功能实现

AlarmManager 和 BroadcastReceiver

kotlin 复制代码
// 设置闹钟
val alarmManager = getSystemService(Context.ALARM_SERVICE) as AlarmManager
val intent = Intent(this, AlarmReceiver::class.java)
val pendingIntent = PendingIntent.getBroadcast(this, 0, intent, PendingIntent.FLAG_IMMUTABLE)

val calendar = Calendar.getInstance().apply {
    set(Calendar.HOUR_OF_DAY, hour)
    set(Calendar.MINUTE, minute)
    set(Calendar.SECOND, 0)
}

alarmManager.setExact(
    AlarmManager.RTC_WAKEUP,
    calendar.timeInMillis,
    pendingIntent
)

// 接收广播
class AlarmReceiver : BroadcastReceiver() {
    override fun onReceive(context: Context, intent: Intent) {
        val notification = NotificationCompat.Builder(context, "alarm_channel")
            .setContentTitle("闹钟")
            .setSmallIcon(R.drawable.ic_alarm)
            .build()
        
        val manager = context.getSystemService(NOTIFICATION_SERVICE) as NotificationManager
        manager.notify(1, notification)
    }
}

计时器功能实现

CountDownTimer 使用

kotlin 复制代码
val timer = object : CountDownTimer(30000, 1000) { // 30秒倒计时,间隔1秒
    override fun onTick(millisUntilFinished: Long) {
        val seconds = millisUntilFinished / 1000
        binding.timerText.text = "$seconds秒"
    }

    override fun onFinish() {
        binding.timerText.text = "时间到!"
    }
}.start()

秒表功能实现

Handler 延迟消息

kotlin 复制代码
var seconds = 0
val handler = Handler(Looper.getMainLooper())
val runnable = object : Runnable {
    override fun run() {
        seconds++
        binding.stopwatchText.text = "$seconds秒"
        handler.postDelayed(this, 1000)
    }
}

// 开始秒表
handler.post(runnable)

// 暂停秒表
handler.removeCallbacks(runnable)

界面布局要点

  1. 闹钟界面

    • TimePicker 组件用于选择时间
    • ToggleButton 控制闹钟开关
  2. 计时器界面

    • NumberPicker 或 EditText 输入分钟/秒数
    • 环形进度条显示剩余时间比例
  3. 秒表界面

    • 大字号数字显示
    • 悬浮按钮控制开始/暂停/重置
XML 复制代码
<!-- 示例:计时器按钮布局 -->
<Button
    android:id="@+id/startButton"
    android:text="开始"
    android:onClick="@{() -> viewModel.startTimer()}" />

<Button
    android:id="@+id/resetButton"
    android:text="重置"
    android:onClick="@{() -> viewModel.resetTimer()}" />

数据持久化

  1. 使用 SharedPreferences 存储闹钟设置:
kotlin 复制代码
val prefs = getSharedPreferences("AlarmPrefs", MODE_PRIVATE)
prefs.edit().putInt("alarm_hour", hour).apply()
  1. 计时器状态恢复建议用 ViewModel
kotlin 复制代码
class TimerViewModel : ViewModel() {
    val remainingTime = MutableLiveData<Long>()
}

注意事项

  • Android 8.0+ 需设置前台服务并创建通知渠道
  • 使用 WorkManager 处理设备重启后的闹钟恢复
  • 测试时注意屏幕关闭后的后台行为
  • 计时精度要求高时改用 SystemClock.elapsedRealtime()

完整项目可参考 GitHub 上的开源实现如 AlarmClockTimerX

相关推荐
wanhengidc5 小时前
BGP高防服务器具体是指什么
运维·服务器·网络·安全·游戏·智能手机
补补234566 小时前
解决漫步者H180Plus(TypeC)耳机连接三星手机后每次播放音频出现滴滴声
android·音视频·三星·typec·edifier·h180plus·滴滴声
wanhengidc6 小时前
云手机性能会受到哪些因素的影响?
运维·服务器·网络·游戏·智能手机
AIminminHu6 小时前
实战项目(十二:《AI画质增强与LED驱动控制:一场关于‘创造’与‘还原’的对话》):从LED冬奥会、奥运会及春晚等大屏,到手机小屏,快来挖一挖里面都有什么
人工智能·智能手机
X01动力装甲6 小时前
@scqilin/phone-ui 手机外观组件库
前端·javascript·ui·智能手机·数据可视化
木易 士心7 小时前
Android Jetpack Compose 从入门到精通
android·android jetpack
alexhilton9 小时前
如何构建Android应用:深入探讨原则而非规则
android·kotlin·android jetpack
2501_9160137410 小时前
苹果应用上架全流程指南 iOS 应用发布步骤、App Store 审核流程、ipa 文件上传与 uni-app 打包实战经验
android·ios·小程序·uni-app·cocoa·iphone·webview
芦半山12 小时前
快速应用「幽灵调用」的正式修复
android·gradle
向阳花开_miemie13 小时前
Android音频学习(二十)——高通HAL
android·学习·音视频