如何使用 Kotlin 在 Android 中實現 AlarmManager?


本示例演示瞭如何使用 Kotlin 在 Android 中實現 AlarmManager。

步驟 1 − 在 Android Studio 中建立一個新專案,轉到檔案 ⇒ 新建專案並填寫所有必需細節以建立一個新專案。

步驟 2 − 將以下程式碼新增到 res/layout/activity_main.xml。

<?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="2dp"
   tools:context=".MainActivity">
   <TimePicker
      android:id="@+id/timePicker"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:layout_centerHorizontal="true" />
   <Button
      android:id="@+id/buttonAlarm"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_below="@id/timePicker"
      android:layout_centerInParent="true"
      android:layout_marginTop="10dp"
      android:text="Set Alarm" />
</RelativeLayout>

步驟 3 − 將以下程式碼新增到 src/MainActivity.kt

import android.app.AlarmManager
import android.app.PendingIntent
import android.content.BroadcastReceiver
import android.content.Context
import android.content.Intent
import android.os.Build
import android.os.Bundle
import android.util.Log
import android.widget.Button
import android.widget.TimePicker
import android.widget.Toast
import androidx.appcompat.app.AppCompatActivity
import java.util.*
class MainActivity : AppCompatActivity() {
   lateinit var btnSetAlarm: Button
   lateinit var timePicker: TimePicker
   override fun onCreate(savedInstanceState: Bundle?) {
      super.onCreate(savedInstanceState)
      setContentView(R.layout.activity_main)
      title = "KotlinApp"
      timePicker = findViewById(R.id.timePicker)
      btnSetAlarm = findViewById(R.id.buttonAlarm)
      btnSetAlarm.setOnClickListener {
         val calendar: Calendar = Calendar.getInstance()
         if (Build.VERSION.SDK_INT >= 23) {
            calendar.set(
               calendar.get(Calendar.YEAR),
               calendar.get(Calendar.MONTH),
               calendar.get(Calendar.DAY_OF_MONTH),
               timePicker.hour,
               timePicker.minute,
               0
            )
         } else {
            calendar.set(
            calendar.get(Calendar.YEAR),
            calendar.get(Calendar.MONTH),
            calendar.get(Calendar.DAY_OF_MONTH),
            timePicker.currentHour,
            timePicker.currentMinute, 0
            )
         }
         setAlarm(calendar.timeInMillis)
      }
   }
   private fun setAlarm(timeInMillis: Long) {
      val alarmManager = getSystemService(Context.ALARM_SERVICE) as AlarmManager
      val intent = Intent(this, MyAlarm::class.java)
      val pendingIntent = PendingIntent.getBroadcast(this, 0, intent, 0)
      alarmManager.setRepeating(
         AlarmManager.RTC,
         timeInMillis,
         AlarmManager.INTERVAL_DAY,
         pendingIntent
      )
      Toast.makeText(this, "Alarm is set", Toast.LENGTH_SHORT).show()
   }
   private class MyAlarm : BroadcastReceiver() {
      override fun onReceive(
         context: Context,
         intent: Intent
      ) {
         Log.d("Alarm Bell", "Alarm just fired")
      }
   }
}

步驟 4 − 將以下程式碼新增到 androidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.q11">
   <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=".MainActivity">
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
      </activity>
   </application>
</manifest>

我們嘗試執行您的應用程式。我認為您已將實際的安卓移動裝置連線到您的計算機。要從安卓工作室執行應用程式,請開啟其中一個專案的活動檔案並單擊工具欄中的執行圖示 。選擇您的移動裝置作為一個選項,然後檢視您的移動裝置,它將顯示您的預設介面

更新於: 05-11-2020

4K+ 瀏覽量

開啟你的 職業

完成課程,獲得認證

開始學習
廣告