步步為營_Android開發課[33]_使用者介面之AlarmManager(全域定時器)

來源:互聯網
上載者:User

標籤:alarmmanag   定時器   使用者介面   android   開發   

Focus on technology, enjoy life!—— QQ:804212028
瀏覽連結:http://blog.csdn.net/y18334702058/article/details/44624305

  • 主題:使用者介面之AlarmManager(全域定時器)
    -

AlarmManager的作用:

AlarmManager對象配合Intent使用,可以定時的開啟一個Activity,發送一個BroadCast,或者開啟一個Service.

AlarmManager的常用方法有三個:

(1)set(int type,long startTime,PendingIntent pi);

該方法用於設定一次性鬧鐘,第一個參數表示鬧鐘類型,第二個參數表示鬧鐘執行時間,第三個參數表示鬧鐘響應動作。

(2)setRepeating(int type,long startTime,long
intervalTime,PendingIntent pi);

該方法用於設定重複鬧鐘,第一個參數表示鬧鐘類型,第二個參數表示鬧鐘首次執行時間,第三個參數表示鬧鐘兩次執行的間隔時間,第三個參數表示鬧鐘響應動作。

(3)setInexactRepeating(int type,long startTime,long
intervalTime,PendingIntent pi);

該方法也用於設定重複鬧鐘,與第二個方法相似,不過其兩個鬧鐘執行的間隔時間不是固定的而已。

三個方法各個參數詳悉:

(1)int type: 鬧鐘的類型,常用的有5個值:AlarmManager.ELAPSED_REALTIME、
AlarmManager.ELAPSED_REALTIME_WAKEUP、AlarmManager.RTC、
AlarmManager.RTC_WAKEUP、AlarmManager.POWER_OFF_WAKEUP。

AlarmManager.ELAPSED_REALTIME表示鬧鐘在手機睡眠狀態下不可用,該狀態下鬧鐘使用相對時間(相對於系統啟動開始),狀態值為3;

AlarmManager.ELAPSED_REALTIME_WAKEUP表示鬧鐘在睡眠狀態下會喚醒系統並執行提示功能,該狀態下鬧鐘也使用相對時間,狀態值為2;

AlarmManager.RTC表示鬧鐘在睡眠狀態下不可用,該狀態下鬧鐘使用絕對時間,即當前系統時間,狀態值為1;

AlarmManager.RTC_WAKEUP表示鬧鐘在睡眠狀態下會喚醒系統並執行提示功能,該狀態下鬧鐘使用絕對時間,狀態值為0;

AlarmManager.POWER_OFF_WAKEUP表示鬧鐘在手機關機狀態下也能正常進行提示功能,所以是5個狀態中用的最多的狀態之一,該狀態下鬧鐘也是用絕對時間,狀態值為4;不過本狀態好像受SDK版本影響,某些版本並不支援;

(2)long startTime:
鬧鐘的第一次執行時間,以毫秒為單位,可以自訂時間,不過一般使用目前時間。需要注意的是,本屬性與第一個屬性(type)密切相關,如果第一個參數對
應的鬧鐘使用的是相對時間(ELAPSED_REALTIME和ELAPSED_REALTIME_WAKEUP),那麼本屬性就得使用相對時間(相對於
系統啟動時間來說),比如目前時間就表示為:SystemClock.elapsedRealtime();如果第一個參數對應的鬧鐘使用的是絕對時間
(RTC、RTC_WAKEUP、POWER_OFF_WAKEUP),那麼本屬性就得使用絕對時間,比如目前時間就表示
為:System.currentTimeMillis()。

(3)long intervalTime:對於後兩個方法來說,存在本屬性,表示兩次鬧鐘執行的間隔時間,也是以毫秒為單位。

(4)PendingIntent pi:
綁定了鬧鐘的執行動作,比如發送一個廣播、給出提示等等。PendingIntent是Intent的封裝類。需要注意的是,如果是通過啟動服務來實現鬧鐘提
示的話,PendingIntent對象的擷取就應該採用Pending.getService(Context c,int i,Intent
intent,int j)方法;如果是通過廣播來實現鬧鐘提示的話,PendingIntent對象的擷取就應該採用
PendingIntent.getBroadcast(Context c,int i,Intent intent,int
j)方法;如果是採用Activity的方式來實現鬧鐘提示的話,PendingIntent對象的擷取就應該採用
PendingIntent.getActivity(Context c,int i,Intent intent,int
j)方法。如果這三種方法錯用了的話,雖然不會報錯,但是看不到鬧鐘提示效果。

AlarmManager全域定時器(執行個體):

實現效果:AlarmManager定時的開啟一個Activity,發送一個BroadCast和開啟一個Service.
AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"    package="com.yfz"    android:versionCode="1"    android:versionName="1.0" >    <uses-sdk android:minSdkVersion="7" />    <application        android:icon="@drawable/ic_launcher"        android:label="@string/app_name" >        <activity            android:label="@string/app_name"            android:name=".MainActivity" >            <intent-filter >                <action android:name="android.intent.action.MAIN" />                <category android:name="android.intent.category.LAUNCHER" />            </intent-filter>        </activity>        <receiver            android:name="ActionBroadCast">        </receiver>        <service android:name="ActionService"></service>        <activity android:name="ActionActivity"></activity>    </application></manifest>

main.xml:

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical" >    <Button        android:id="@+id/id_btn1"        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:text="廣播BroadCast" />    <Button        android:id="@+id/id_btn2"        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:text="服務Service" />    <Button        android:id="@+id/id_btn3"        android:layout_width="fill_parent"        android:layout_height="wrap_content"        android:text="活動Activity" /></LinearLayout>

MainActivity.java:

import android.app.Activity;import android.app.AlarmManager;import android.app.PendingIntent;import android.content.Intent;import android.os.Bundle;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;public class MainActivity extends Activity {     AlarmManager am ;    @Override    public void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main);        am = (AlarmManager)getSystemService(ALARM_SERVICE);        Button btn1 = (Button)findViewById(R.id.id_btn1);        Button btn2 = (Button)findViewById(R.id.id_btn2);        Button btn3 = (Button)findViewById(R.id.id_btn3);        btn1.setOnClickListener(onclick);        btn2.setOnClickListener(onclick);        btn3.setOnClickListener(onclick);    }    OnClickListener onclick = new OnClickListener() {        @Override        public void onClick(View v) {            long now = System.currentTimeMillis();            PendingIntent pi = null;            switch (v.getId()) {                case R.id.id_btn1:                    pi = PendingIntent.getBroadcast(MainActivity.this, 0, new Intent(MainActivity.this, ActionBroadCast.class), Intent.FLAG_ACTIVITY_NEW_TASK);                    break;                case R.id.id_btn2:                    pi = PendingIntent.getService(MainActivity.this, 0, new Intent(MainActivity.this, ActionService.class), Intent.FLAG_ACTIVITY_NEW_TASK);                    break;                case R.id.id_btn3:                    pi = PendingIntent.getActivity(MainActivity.this, 0, new Intent(MainActivity.this, ActionActivity.class), Intent.FLAG_ACTIVITY_NEW_TASK);                    break;                default:                    break;            }            am.setInexactRepeating(AlarmManager.RTC_WAKEUP, now, 3000, pi);        }    };}

ActionActivity.java:

import android.app.Activity;import android.os.Bundle;import android.util.Log;import android.widget.Button;public class ActionActivity extends Activity {    private static int num = 0;    @Override    protected void onCreate(Bundle savedInstanceState) {        // TODO Auto-generated method stub        super.onCreate(savedInstanceState);        Log.e("ActionActivity", "Activity New Message !" + num++);    }   }   

ActionBroadCast.java:

import android.content.BroadcastReceiver;import android.content.Context;import android.content.Intent;import android.util.Log;public class ActionBroadCast extends BroadcastReceiver {    private static int num = 0;    @Override    public void onReceive(Context context, Intent intent) {        // TODO Auto-generated method stub        Log.e("ActionBroadCast", "New Message !" + num++);    }}

ActionService.java:

import android.app.Service;import android.content.Intent;import android.os.IBinder;import android.util.Log;public class ActionService extends Service {    private static int num = 0;    @Override    public IBinder onBind(Intent arg0) {        // TODO Auto-generated method stub        return null;    }    @Override    public void onStart(Intent intent, int startId) {        // TODO Auto-generated method stub        super.onStart(intent, startId);        Log.e("ActionService", "Service New Message !" + num++);    }    @Override    public int onStartCommand(Intent intent, int flags, int startId) {        // TODO Auto-generated method stub        Log.e("ActionService", "----------");        return super.onStartCommand(intent, flags, startId);    }}

Focus on technology, enjoy life!—— QQ:804212028
瀏覽連結:http://blog.csdn.net/y18334702058/article/details/44624305

步步為營_Android開發課[33]_使用者介面之AlarmManager(全域定時器)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.