Android通過AlarmManager類實(shí)現(xiàn)簡單鬧鐘功能
Android通過AlarmManager類實(shí)現(xiàn)鬧鐘,供大家參考,具體內(nèi)容如下
簡介
鬧鐘是生活中最常用的功能了,很多App都可以加入該功能,提醒用戶某個(gè)時(shí)刻要做的事情。在Android系統(tǒng)中可以通過AlarmManager類實(shí)現(xiàn)鬧鐘,AlarmManager類是專門用來設(shè)定在某個(gè)指定的時(shí)間去完成指定的事件。AlarmManager提供了訪問系統(tǒng)警報(bào)的服務(wù),只要在程序中設(shè)置了警報(bào)服務(wù),AlarmManager就會(huì)通過onReceive()方法去還行這些事件,就算系統(tǒng)處于待機(jī)狀態(tài),同樣不會(huì)影響運(yùn)行。可以通過Context.getSystemService方法來獲取該服務(wù)。接下來我們將使用AlarmManager來制作一個(gè)最簡單的鬧鐘。
讓我們來看一下AlarmManager都為我們提供了哪些方法,如下:
要實(shí)現(xiàn)鬧鐘,首先需要?jiǎng)?chuàng)建一個(gè)繼承自BroadcastReceiver的類,實(shí)現(xiàn)onReceive方法來接收這個(gè)Alarm服務(wù),然后通過建立Intent和PendingIntent連接來調(diào)用Alarm組件,并通過TimePickerDialog來設(shè)置時(shí)間,當(dāng)時(shí)間到我們指定的時(shí)間后onReceive方法接收到Alarm服務(wù)后即可進(jìn)行提示。
讓我們實(shí)現(xiàn)主界面布局,效果如下:
接下來讓我們實(shí)現(xiàn)接收Alarm服務(wù)的AlarmReceiver類,該類比較簡單,在收到消息后用一個(gè)Toast來提示用戶,具體實(shí)現(xiàn)代碼如下:
public class AlarmReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { Toast.makeText(context, "您設(shè)置的時(shí)間到了!", Toast.LENGTH_SHORT).show(); } }
由于使用了BroadcastReceiver,因此我們需要在AndroidManifest.xml文件中對(duì)其進(jìn)行聲明,如下:
<receiver android:name=".AlarmReceiver" android:process=":remote" />
接下來,在MainActivity中我們實(shí)現(xiàn)“設(shè)置鬧鐘”和“取消鬧鐘”的事件監(jiān)聽,讓我們來看一下具體實(shí)現(xiàn)代碼:
public class MainActivity extends Activity { private Button btnSet, btnCancel; private TextView info; private Calendar calendar; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnSet = (Button) findViewById(R.id.setalarm); btnCancel = (Button) findViewById(R.id.cancelalarm); info = (TextView) findViewById(R.id.info); calendar = Calendar.getInstance(); btnSet.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub calendar.setTimeInMillis(System.currentTimeMillis()); int mHour = calendar.get(Calendar.HOUR_OF_DAY); int mMinute = calendar.get(Calendar.MINUTE); new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener() { @Override public void onTimeSet(TimePicker view, int hourOfDay, int minute) { // TODO Auto-generated method stub calendar.setTimeInMillis(System.currentTimeMillis()); calendar.set(Calendar.HOUR_OF_DAY, hourOfDay); calendar.set(Calendar.MINUTE, minute); calendar.set(Calendar.SECOND, 0); calendar.set(Calendar.MILLISECOND, 0); // 建立Intent和PendingIntent來調(diào)用目標(biāo)組件 Intent intent = new Intent(MainActivity.this, AlarmReceiver.class); PendingIntent pendingIntent = PendingIntent.getBroadcast(MainActivity.this, 0, intent, 0); // 獲取鬧鐘管理的實(shí)例 AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE); // 設(shè)置鬧鐘 am.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), pendingIntent); // 設(shè)置周期鬧鐘 am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis() + (10 * 1000), (24 * 60 * 60 * 1000), pendingIntent); String tmpS = "設(shè)置鬧鐘時(shí)間為" + format(hourOfDay) + ":" + format(minute); info.setText(tmpS); } }, mHour, mMinute, true).show(); } }); btnCancel.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Intent intent = new Intent(MainActivity.this, AlarmReceiver.class); PendingIntent pendingIntent = PendingIntent.getBroadcast( MainActivity.this, 0, intent, 0); // 獲取鬧鐘管理實(shí)例 AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE); // 取消 am.cancel(pendingIntent); info.setText("鬧鐘已經(jīng)取消"); } }); } // 格式化字符串7:3-->07:03 private String format(int x) { String s = "" + x; if (s.length() == 1) { s = "0" + s; } return s; } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.activity_main, menu); return true; } }
在上述代碼中我們使用了PendingIntent,PendingIntent這個(gè)類用于處理即將發(fā)生的事情,PendingIntent可以看作是對(duì)Intent的包裝,通常通過getActivity、getBroadcast、getService來得到PendingIntent的實(shí)例,當(dāng)前Activity并不能馬上啟動(dòng)它所包含的Intent,而是在外部執(zhí)行PendingIntent時(shí),調(diào)用Intent。正是由于PendingIntent中保存有當(dāng)前App的context,使它賦予外部App一種能力,使得外部App可以如同當(dāng)前App一樣的執(zhí)行PendingIntent里的Intent,就算在執(zhí)行時(shí)當(dāng)前App已經(jīng)不存在了,也能通過保存在PendingIntent里的Context照樣執(zhí)行Intent,另外還可以處理Intent執(zhí)行后的操作。常和AlarmManager和NotificationManager一起使用。
至此,一個(gè)簡單的功能就實(shí)現(xiàn)了。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android Studio設(shè)置繪制布局時(shí)的視圖
這篇文章介紹了Android Studio設(shè)置繪制布局時(shí)視圖的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-11-11Kotlin協(xié)程操作之創(chuàng)建啟動(dòng)掛起恢復(fù)詳解
本文的定位是協(xié)程的創(chuàng)建、啟動(dòng)、掛起、恢復(fù),也會(huì)示例一些簡單的使用,這里不對(duì)suspend講解,,也不對(duì)協(xié)程的高級(jí)用法做闡述(熱數(shù)據(jù)通道Channel、冷數(shù)據(jù)流Flow...),本文主要講協(xié)程稍微深入的全面知識(shí)2022-08-08Android自定義ViewGroup之FlowLayout(三)
這篇文章主要為大家詳細(xì)介紹了Android自定義ViewGroup之FlowLayout,常用于關(guān)鍵字標(biāo)簽,搜索熱詞列表等功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09一款A(yù)ndroid APK的結(jié)構(gòu)構(gòu)成解析
本篇文章介紹了我在學(xué)習(xí)過程中對(duì)于Android 程序的理解總結(jié),刨析了apk的組成與產(chǎn)生過程,通讀本篇對(duì)大家的學(xué)習(xí)或工作具有一定的價(jià)值,需要的朋友可以參考下2021-10-10kotlin中EditText賦值Type mismatch方式
這篇文章主要介紹了kotlin中EditText賦值Type mismatch方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03android基于SwipeRefreshLayout實(shí)現(xiàn)類QQ的側(cè)滑刪除
本篇文章主要介紹了android基于SwipeRefreshLayout實(shí)現(xiàn)類QQ的側(cè)滑刪除,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-10-10