summaryrefslogtreecommitdiffstats
path: root/samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java
diff options
context:
space:
mode:
authorAlexander Lucas <alexlucas@google.com>2014-02-06 15:38:51 -0800
committerAlexander Lucas <alexlucas@google.com>2014-02-07 13:17:23 -0800
commit0b3758ea4e53f9bfd0b112eaa4a7dd7b7f4040f5 (patch)
tree8a092424bc4793e2daa6b5f62d2b081050774fff /samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java
parent01d72b37a87ce8781cd35d5aaa834b508f964be7 (diff)
downloadandroid_development-0b3758ea4e53f9bfd0b112eaa4a7dd7b7f4040f5.tar.gz
android_development-0b3758ea4e53f9bfd0b112eaa4a7dd7b7f4040f5.tar.bz2
android_development-0b3758ea4e53f9bfd0b112eaa4a7dd7b7f4040f5.zip
Adding new samples to browseable section of DAC
Change-Id: I58e10e787f5df668331fc04e97a6c2efcd75f76f
Diffstat (limited to 'samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java')
-rw-r--r--samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java96
1 files changed, 96 insertions, 0 deletions
diff --git a/samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java b/samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java
new file mode 100644
index 000000000..81b1e447f
--- /dev/null
+++ b/samples/browseable/RepeatingAlarm/src/com.example.android.repeatingalarm/RepeatingAlarmFragment.java
@@ -0,0 +1,96 @@
+/*
+* Copyright 2013 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.repeatingalarm;
+
+import android.app.AlarmManager;
+import android.app.PendingIntent;
+import android.content.Intent;
+import android.os.Bundle;
+import android.os.SystemClock;
+import android.support.v4.app.Fragment;
+import android.view.MenuItem;
+import com.example.android.common.logger.*;
+
+
+public class RepeatingAlarmFragment extends Fragment {
+
+ // This value is defined and consumed by app code, so any value will work.
+ // There's no significance to this sample using 0.
+ public static final int REQUEST_CODE = 0;
+
+ @Override
+ public void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setHasOptionsMenu(true);
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ if(item.getItemId() == R.id.sample_action) {
+
+ // BEGIN_INCLUDE (intent_fired_by_alarm)
+ // First create an intent for the alarm to activate.
+ // This code simply starts an Activity, or brings it to the front if it has already
+ // been created.
+ Intent intent = new Intent(getActivity(), MainActivity.class);
+ intent.setAction(Intent.ACTION_MAIN);
+ intent.setFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT);
+ // END_INCLUDE (intent_fired_by_alarm)
+
+ // BEGIN_INCLUDE (pending_intent_for_alarm)
+ // Because the intent must be fired by a system service from outside the application,
+ // it's necessary to wrap it in a PendingIntent. Providing a different process with
+ // a PendingIntent gives that other process permission to fire the intent that this
+ // application has created.
+ // Also, this code creates a PendingIntent to start an Activity. To create a
+ // BroadcastIntent instead, simply call getBroadcast instead of getIntent.
+ PendingIntent pendingIntent = PendingIntent.getActivity(getActivity(), REQUEST_CODE,
+ intent, 0);
+
+ // END_INCLUDE (pending_intent_for_alarm)
+
+ // BEGIN_INCLUDE (configure_alarm_manager)
+ // There are two clock types for alarms, ELAPSED_REALTIME and RTC.
+ // ELAPSED_REALTIME uses time since system boot as a reference, and RTC uses UTC (wall
+ // clock) time. This means ELAPSED_REALTIME is suited to setting an alarm according to
+ // passage of time (every 15 seconds, 15 minutes, etc), since it isn't affected by
+ // timezone/locale. RTC is better suited for alarms that should be dependant on current
+ // locale.
+
+ // Both types have a WAKEUP version, which says to wake up the device if the screen is
+ // off. This is useful for situations such as alarm clocks. Abuse of this flag is an
+ // efficient way to skyrocket the uninstall rate of an application, so use with care.
+ // For most situations, ELAPSED_REALTIME will suffice.
+ int alarmType = AlarmManager.ELAPSED_REALTIME;
+ final int FIFTEEN_SEC_MILLIS = 15000;
+
+ // The AlarmManager, like most system services, isn't created by application code, but
+ // requested from the system.
+ AlarmManager alarmManager = (AlarmManager)
+ getActivity().getSystemService(getActivity().ALARM_SERVICE);
+
+ // setRepeating takes a start delay and period between alarms as arguments.
+ // The below code fires after 15 seconds, and repeats every 15 seconds. This is very
+ // useful for demonstration purposes, but horrendous for production. Don't be that dev.
+ alarmManager.setRepeating(alarmType, SystemClock.elapsedRealtime() + FIFTEEN_SEC_MILLIS,
+ FIFTEEN_SEC_MILLIS, pendingIntent);
+ // END_INCLUDE (configure_alarm_manager);
+ Log.i("RepeatingAlarmFragment", "Alarm set.");
+ }
+ return true;
+ }
+}