使用Android服務,實現報警管理器和廣播接收器

介紹

幾乎在全部平臺上都有不少進程運行背景,它們被稱爲服務。可能在Android平臺中有一些服務能夠執行長時間運行的操做,這些操做在處理時不須要用戶交互。  java

在本文中,藉助預約義的Android警報服務,咱們將建立一個應用程序,在所需的時間間隔內將電話模式更改成振動模式。除此以外,咱們將編寫本身的Service類並在特定時間調用它。此外,此演示應用程序將回答如下問題:android

  • 如何使用Alarm Manager?
  • 如何經過Alarm Manager啓動Intent?
  • 如何使用BroadcastReceiver?
  • 如何使用服務?
  • 如何在AndroidManifest.xml中註冊服務和接收器?
  • 如何更改手機鈴聲模式?

背景

要理解本文,讀者應該瞭解Java和Android平臺。git

使用代碼

在開始編碼以前,應用程序的結構應該在編碼器的腦海中清楚。對於此演示應用程序,咱們能夠按照如下簡單步驟操做:app

  1. 獲取用戶的時間間隔 MainActivity
  2. 根據時間間隔,設置鬧鐘以廣播它
  3. 寫入BroadcastReceivers以接收警報並執行操做或呼叫服務。

在這個演示中,有4個類:ide

MainActivity             // main calss FromHourAlarmReceiver //BroadcastReceiver ToHourAlarmReceiver //BroadcastReceiver MyService //Service Class

1-在MainActivity中獲取用戶的時間間隔

a)MainActivity.class

public class MainActivity extends Activity { private EditText editText1; //create the objects private EditText editText2; private Button btn1; private int hourFrom; private int hourTo; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); editText1 = (EditText) findViewById(R.id.editText1); //bind the object editText2 = (EditText) findViewById(R.id.editText2); btn1 = (Button) findViewById(R.id.btn1); btn1.setOnClickListener(new OnClickListener() { //click listener for btn @Override public void onClick(View v) { }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }

b)main_activity.xml

<LinearLayout 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:paddingBottom="@dimen/activity_vertical_margin"      android:paddingLeft="@dimen/activity_horizontal_margin"      android:paddingRight="@dimen/activity_horizontal_margin"      android:paddingTop="@dimen/activity_vertical_margin"      android:orientation="vertical"      tools:context=".MainActivity" > <TextView          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:text="Enter The Desired Time Interval For To Changed In Vibrate Mode" /> <TextView          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:text="From (24 Hour Format)" /> <EditText          android:id="@+id/editText1"          android:layout_width="fill_parent"          android:layout_height="wrap_content"          android:numeric="integer"          /> <TextView          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:text="To (24 Hour Format)" /> <EditText          android:id="@+id/editText2"          android:layout_width="fill_parent"          android:layout_height="wrap_content"          android:numeric="integer"          /> <Button          android:id="@+id/btn1"          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:text="Set the Service"/> </LinearLayout>

2 - 根據間隔設置警報管理器

在建立Alarm Manager以前,咱們須要建立咱們的意圖來經過AlarmManager如下方式調用它們this

Intent intent1 = new Intent(getBaseContext(), FromHourAlarmReceiver.class); final PendingIntent sender1 = PendingIntent.getBroadcast(this, 192837, intent1, PendingIntent.FLAG_UPDATE_CURRENT); Intent intent2 = new Intent(getBaseContext(), ToHourAlarmReceiver.class); final PendingIntent sender2 = PendingIntent.getBroadcast(this, 192837, intent2, PendingIntent.FLAG_UPDATE_CURRENT);

在這裏,Intent是要執行的操做的名稱。因爲咱們將調用一個類,FromHourAlarmReceiver該類須要知道發生了什麼,爲何調用它,誰是調用者等等。所以咱們須要經過Intent對象[1]發送上下文。編碼

這裏有另外一個術語PendingIntent,這有兩點重要。第一個代表咱們寫的意圖將在稍後開始。第二個是經過使用PendingIntent咱們告訴咱們正與3通訊Android平臺研發 Android平臺的第三方應用程序或服務。在這個演示中,它是AlarmManager服務。
spa

咱們建立了兩個意圖,由於咱們將設置2個警報,第一個將手機狀態更改成振動模式,另外一個將其更改成正常模式。因此咱們須要2個日曆對象來設置時間。code

Calendar cal1 = Calendar.getInstance();
cal1.set(Calendar.HOUR,hourFrom);
                                  
Calendar cal2 = Calendar.getInstance();
cal2.set(Calendar.HOUR,hourTo);

在咱們擁有全部設置警報的對象和信息以後:orm

AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE);am.set(AlarmManager.RTC_WAKEUP,
cal1.getTimeInMillis(), sender1);am.set(AlarmManager.RTC_WAKEUP, cal2.getTimeInMillis(), sender2);

最後咱們MainActivity將看起來像這樣:

public class MainActivity extends Activity { private EditText editText1; private EditText editText2; private Button btn1; private int hourFrom; private int hourTo; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); editText1 = (EditText) findViewById(R.id.editText1); editText2 = (EditText) findViewById(R.id.editText2); btn1 = (Button) findViewById(R.id.btn1); Intent intent1 = new Intent(getBaseContext(), FromHourAlarmReceiver.class); final PendingIntent sender1 = PendingIntent.getBroadcast( this, 192837, intent1, PendingIntent.FLAG_UPDATE_CURRENT); Intent intent2 = new Intent(getBaseContext(), ToHourAlarmReceiver.class); final PendingIntent sender2 = PendingIntent.getBroadcast( this, 192837, intent2, PendingIntent.FLAG_UPDATE_CURRENT); btn1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { try{ hourFrom = Integer.parseInt(editText1.getText().toString()); hourTo = Integer.parseInt(editText2.getText().toString()); } catch(Exception e){} if((0<hourFrom&&hourFrom<24)&& (0<hourTo&&hourTo<24)){ Calendar cal1 = Calendar.getInstance(); cal1.set(Calendar.HOUR,hourFrom); Calendar cal2 = Calendar.getInstance(); cal2.set(Calendar.HOUR,hourTo); AlarmManager am = (AlarmManager) getSystemService(ALARM_SERVICE); am.set(AlarmManager.RTC_WAKEUP, cal1.getTimeInMillis(), sender1); am.set(AlarmManager.RTC_WAKEUP, cal2.getTimeInMillis(), sender2); Toast.makeText(getBaseContext(), "Phone Mode Will Be Changed Automatically !",Toast.LENGTH_LONG).show(); } else{ Toast.makeText(getBaseContext(), "Please enter hour in between 1-23 !",Toast.LENGTH_LONG).show(); } } }); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } }

3實現BroadcastReceivers

android源碼平臺中,幾乎全部在設備中執行的動做都被廣播。它能夠想象成一個游泳池。不管操做是什麼,都會將信息發送到該池。這樣,您能夠檢查設備中發生的狀況並根據它們執行操做。

在咱們的演示中,AlarmManager將廣播已發生警報並捕獲此警報,咱們須要編寫BroadcastReceiver以下所示:

public class FromHourAlarmReceiver extends BroadcastReceiver{ @Override public void onReceive(Context context, Intent intent) { } }

能夠用tie onReceive()方法執行指望的操做

注意:當a BroadcastReceiver添加到項目時,須要將其註冊到AndroidManifest.xml中如下代碼適用於此:

<receiverandroid:process=":remote" android:name="FromHourAlarmReceiver"></receiver> <receiverandroid:process=":remote" android:name="ToHourAlarmReceiver"></receiver>

因此咱們有2個BroadcastReceivers:

  1. FromHourAlarmReceiver 負責將手機狀態更改成振動模式。
  2. ToHourAlarmReceiver 負責將手機狀態更改成正常模式。

FromHourAlarmReceiver.class

public class FromHourAlarmReceiver extends BroadcastReceiver{ @Override public void onReceive(Context context, Intent intent) { AudioManager am= (AudioManager) context.getSystemService(Context.AUDIO_SERVICE); am.setRingerMode(AudioManager.RINGER_MODE_VIBRATE); Toast.makeText(context, "Phone Mode Is Changed to Vibrate Mode", Toast.LENGTH_LONG).show(); } }

ToHourAlarmManager.class

public class ToHourAlarmReceiver extends BroadcastReceiver{ @Override public void onReceive(Context context, Intent intent) { AudioManager am= (AudioManager) context.getSystemService(Context.AUDIO_SERVICE); am.setRingerMode(AudioManager.RINGER_MODE_NORMAL); Toast.makeText(context, "Phone Mode Is Changed to Normal Mode", Toast.LENGTH_LONG).show(); Log.d("warnning", "something is happend..."); } }

注意2:當a收到警報提醒時BroadCastReceiver,您能夠調用本身的服務類,以下所示:

Intent myServiceIntent = new
Intent(context,MyService.class);
context.startService(myServiceIntent);

注3:不要忘記將Service類註冊到AndroidManifest.xml

<service class=".MyService" android:name="MyService"> <intent-filter> <action android:value="com.javaorigin.android.sample.service.MY_SERVICE"             android:name=".MyService" /> </intent-filter> </service>

MyService.class

public class MyService extends Service{ @Override public void onCreate() { super.onCreate(); } @Override public int onStartCommand(Intent intent, int flags, int startId) { Toast.makeText(getApplicationContext(), "*** I am called by BroadcastReceiver ***", Toast.LENGTH_LONG).show(); return startId; } @Override public void onDestroy() { super.onDestroy(); } @Override public IBinder onBind(Intent arg0) { // TODO Auto-generated method stub return null; } }

2.服務類的註冊

衆所周知,AndroidManifest.xml負責全部權限,服務,意圖等。因此咱們編寫的服務必須由AndroidManifest.xml知道爲此,應將如下代碼添加到AndroidManifes.xml

<service class=".MyService" android:name="MyService"> <intent-filter> <action android:value="com.javaorigin.android.sample.service.MY_SERVICE"             android:name=".MyService" /> </intent-filter> </service>

注意4:若是服務在運行時被調用,可能會崩潰。要防止出現此類錯誤,請檢查方法的標誌類型onStartCommand

節點5:大多數系統應用程序服務對用戶不可見。若是你想編寫一個不可見的服務,你應該使你的「apk」好像它是一個系統應用程序。

相關文章
相關標籤/搜索