| /* |
| * Copyright (C) 2010 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package com.example.android.newalarm; |
| |
| import android.app.Activity; |
| import android.app.AlarmManager; |
| import android.app.PendingIntent; |
| import android.content.Intent; |
| import android.os.SystemClock; |
| import android.os.Bundle; |
| import android.view.View; |
| import android.view.View.OnClickListener; |
| import android.widget.Button; |
| import android.widget.Toast; |
| |
| /** |
| * This is the activity that controls AlarmService. |
| * <p> |
| * When the user clicks the "Start Alarm Service" button, it triggers a repeating countdown |
| * timer. Every thirty seconds, the timer starts AlarmService, which then runs for 15 seconds |
| * and shuts itself down. |
| * </p> |
| * <p> |
| * When the user clicks the "Stop Alarm Service" button, it stops the countdown timer. |
| * </p> |
| */ |
| |
| public class AlarmActivity extends Activity { |
| // 30 seconds in milliseconds |
| private static final long THIRTY_SECONDS_MILLIS = 30 * 1000; |
| |
| // An intent for AlarmService, to trigger it as if the Activity called startService(). |
| private PendingIntent mAlarmSender; |
| |
| // Contains a handle to the system alarm service |
| private AlarmManager mAlarmManager; |
| |
| /** |
| * This method is called when Android starts the activity. It initializes the UI. |
| * <p> |
| * This method is automatically called when Android starts the Activity |
| * </p> |
| */ |
| @Override |
| protected void onCreate(Bundle savedInstanceState) { |
| super.onCreate(savedInstanceState); |
| |
| // Create a PendingIntent to trigger a startService() for AlarmService |
| mAlarmSender = PendingIntent.getService( // set up an intent for a call to a service |
| AlarmActivity.this, // the current context |
| 0, // request code (not used) |
| new Intent(AlarmActivity.this, AlarmService.class), // A new Service intent |
| 0 // flags (none are required for a service) |
| ); |
| |
| // Creates the main view |
| setContentView(R.layout.main); |
| |
| // Finds the button that starts the repeating countdown timer |
| Button button = (Button)findViewById(R.id.start_alarm); |
| |
| // Sets the listener for the start button |
| button.setOnClickListener(mStartAlarmListener); |
| |
| // Finds the button that stops countdown timer |
| button = (Button)findViewById(R.id.stop_alarm); |
| |
| // Sets the listener for the stop button |
| button.setOnClickListener(mStopAlarmListener); |
| |
| // Gets the handle to the system alarm service |
| mAlarmManager = (AlarmManager)getSystemService(ALARM_SERVICE); |
| } |
| |
| // Creates a new anonymous click listener for the start button. It starts the repeating |
| // countdown timer. |
| private OnClickListener mStartAlarmListener = new OnClickListener() { |
| // Sets the callback for when the button is clicked |
| public void onClick(View v) { |
| |
| // Sets the time when the alarm will first go off |
| // The Android AlarmManager uses this form of the current time. |
| long firstAlarmTime = SystemClock.elapsedRealtime(); |
| |
| // Sets a repeating countdown timer that triggers AlarmService |
| mAlarmManager.setRepeating( |
| AlarmManager.ELAPSED_REALTIME_WAKEUP, // based on time since last wake up |
| firstAlarmTime, // sends the first alarm immediately |
| THIRTY_SECONDS_MILLIS, // repeats every thirty seconds |
| mAlarmSender // when the alarm goes off, sends this Intent |
| ); |
| |
| // Notifies the user that the repeating countdown timer has been started |
| Toast.makeText( |
| AlarmActivity.this, // the current context |
| R.string.repeating_started, // the message to display |
| Toast.LENGTH_LONG // how long to display the message |
| ).show(); // show the message on the screen |
| } |
| }; |
| |
| // Creates a new anonymous click listener for the stop button. It shuts off the repeating |
| // countdown timer. |
| private OnClickListener mStopAlarmListener = new OnClickListener() { |
| // Sets the callback for when the button is clicked |
| public void onClick(View v) { |
| |
| // Cancels the repeating countdown timer |
| mAlarmManager.cancel(mAlarmSender); |
| |
| // Notifies the user that the repeating countdown timer has been stopped |
| Toast.makeText( |
| AlarmActivity.this, // the current context |
| R.string.repeating_stopped, // the message to display |
| Toast.LENGTH_LONG // how long to display the message |
| ).show(); // display the message |
| } |
| }; |
| } |