利用AlarmManager实现闹钟设置

//设置本地闹钟,actiongString:闹钟标识
setLocAlarm(int week, String actionString) { Calendar currentCalendar = Calendar.getInstance();
currentCalendar.setTime(new Date());
int nowWeek = currentCalendar.get(Calendar.DAY_OF_WEEK);
int nowHour = currentCalendar.get(Calendar.HOUR_OF_DAY);
int nowMinute = currentCalendar.get(Calendar.MINUTE); int setHour = mTimePicker.getCurrentHour();
int setMinute = mTimePicker.getCurrentMinute(); Calendar calendar = Calendar.getInstance();
calendar.set(Calendar.DAY_OF_WEEK, week);//星期
calendar.set(Calendar.HOUR_OF_DAY, setHour);//时
calendar.set(Calendar.MINUTE, setMinute);//分
calendar.set(Calendar.SECOND, 0);//秒
//代表设置的的是过去的时间加上7*24*60*60秒
if (week < nowWeek || (week == nowWeek && setHour < nowHour) || (week == nowWeek && setHour == nowHour && setMinute < nowMinute)) {
calendar.add(Calendar.SECOND, 7 * 24 * 60 * 60);
}
Intent intent = new Intent(getActivity(), AlarmService.class);
intent.setAction(actionString); PendingIntent pendingIntent = PendingIntent.getService(getActivity(), 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
//指定唤醒service
AlarmManager manager = (AlarmManager) getActivity().getSystemService(Context.ALARM_SERVICE);
//设置准确时间也可以利用manager.setRepeating();设置重复闹钟(时间不准)
manager.setExact(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), pendingIntent); }

2.取消闹钟

//根据表示取消闹钟
void cancelAlarm(String actionString) {
Intent intent = new Intent(getActivity(), AlarmService.class);
intent.setAction(actionString);
PendingIntent pendingIntent = PendingIntent.getService(getActivity(), 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
AlarmManager manager = (AlarmManager) getActivity().getSystemService(Context.ALARM_SERVICE);
manager.cancel(pendingIntent);
}

3.在service中处理闹钟

public class AlarmService extends Service {
public AlarmService() {
} @Nullable
@Override
public IBinder onBind(Intent intent) {
return null;
} @Override
public int onStartCommand(Intent intent, int flags, int startId) {
LogUtil.d("sss","收到了。。action=="+intent.getAction());
// 如果是重复的闹钟就根据当前时间重新设置下
if (needRepeat) {
resetAlarm(intent.getAction());
} Intent intent1 = new Intent();
intent1.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
//打开闹钟提示activity
intent1.setClass(this, AlarmTipActivity.class); //若果是在前台收到的闹钟消息
if (LHTool.isForeceground(this)) {
intent1.putExtra("fromhead",true);
}else {
intent1.putExtra("fromhead",false);
}
startActivity(intent1);
return super.onStartCommand(intent,flags,startId); }
//重新设置下周当前时间的闹钟
private void resetAlarm(String actionStr){
Calendar calendar = Calendar.getInstance();
calendar.setTime(new Date());
calendar.add(Calendar.SECOND, 7 * 24 * 60 * 60);
Intent intent = new Intent(this, AlarmService.class);
intent.setAction(actionStr); PendingIntent pendingIntent = PendingIntent.getService(this, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
AlarmManager manager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
// manager.setRepeating(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), 7 * 24 * 60 * 60 * 1000, pendingIntent);
manager.setExact(AlarmManager.RTC_WAKEUP,calendar.getTimeInMillis(),pendingIntent); } }

 4.在acitivity中进行相关提示操作


public class AlarmTipActivity extends AppCompatActivity {

    private MediaPlayer mMediaPlayer;

    @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_alarm_tip);
AlertDialog.Builder builder = new AlertDialog.Builder(this); final AlertDialog dialog = builder.create();
builder.setMessage("Alarm Clock!");
builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialogInterface, int i) { dialog.cancel();
Intent intent = getIntent();
//如果不是从前台过来的闹钟就启动MainActivity
if (!intent.getBooleanExtra("fromhead", false)) {
Intent intent1 = new Intent();
intent1.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
intent1.setClass(AlarmTipActivity.this, MainActivity.class);
startActivity(intent1);
}
finish();
}
});
//点击空白处不可取消alert
builder.setCancelable(false);
builder.show();
wakeUpScreen();
}
@Override
protected void onStart() {
super.onStart();
//确保唤醒后也能播放音乐
playMusic();
} private void playMusic() { mMediaPlayer = MediaPlayer.create(this, LHSharePreferenceTool.getAlarmRing(this));
mMediaPlayer.setWakeMode(getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);
mMediaPlayer.setScreenOnWhilePlaying(true);
mMediaPlayer.start(); }
/*唤醒屏幕*/
private void wakeUpScreen() {
getWindow().addFlags(WindowManager.LayoutParams.FLAG_SHOW_WHEN_LOCKED|
WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON
| WindowManager.LayoutParams.FLAG_TURN_SCREEN_ON|WindowManager.LayoutParams.FLAG_DISMISS_KEYGUARD
|WindowManager.LayoutParams.FLAG_ALLOW_LOCK_WHILE_SCREEN_ON);
} @Override
protected void onStop() {
super.onStop();
if (mMediaPlayer != null) { mMediaPlayer.release();
mMediaPlayer = null;
}
}
}

相关权限

<uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
<uses-permission android:name="android.permission.WAKE_LOCK"/>

Android简单闹钟设置的更多相关文章

  1. Android闹钟设置的解决方案

    Android设置闹钟并不像IOS那样这么简单,做过Android设置闹钟的开发者都知道里面的坑有多深.下面记录一下,我解决Android闹钟设置的解决方案. 主要问题 API19开始AlarmMan ...

  2. android 闹钟设置问题

    Android开发中,alarmManager在5.0以上系统,启动时间设置无效的问题 做一个app,需要后台保持发送心跳包.由于锁屏后CPU休眠,导致心跳包线程被挂起,所以尝试使用alarmMana ...

  3. Android系统默认设置

    修改Settings源码,可修改系统设置项,Settings数据被存放于com.android.providers.settings/databases/settings.db中,如果想修改系统启动后 ...

  4. 【Android】 TextView设置个别字体样式

    SpannableString msp = new SpannableString("测试"+XM+"更换当前号码将从手机发送一条普通短信进行验证"); msp ...

  5. Android 编程下设置 Activity 切换动画

    为 Activity 设置切换动画 我们知道,我们可以在 AndroidManifest.xml 文件中,通过 android:theme 属性设置 Activity 的主题.主题中定义了关于 Act ...

  6. Android 小闹钟程序

    最近写了个闹钟的程序,看到SharedPreferences在一个程序中可以共享数据,SharedPreferences是一个轻量级的键值存储机制,只可以存储基本数据类型.我就拿来用用,没想到Shar ...

  7. Android 实现闹钟功能

      原文地址:Android 实现闹钟功能作者:Android_Learners 一.手机闹钟主要用到了AlarmManager类,AlarmManager类提供了访问系统定时服务的途径,开发人员可以 ...

  8. Android开发技巧——设置系统状态栏颜色

    开门见山,先来三张效果图: 然后我们再来讲如何实现以及如何快速地实现. 如何实现 实现设置系统状态栏颜色需要至少在Android 4.4.2(API 19)以上.这是因为,在这个版本以下,没有任何的A ...

  9. 基于Android的闹钟的软件

    一.本课题要求:设计一个基于Android的闹钟的软件. 实现的功能有:能通过界面设置闹钟的启动条件建立后台服务进程,当满足触发条件时,闹钟响应相应事件. 二.需求分析 该课题实现在手机操作系统And ...

随机推荐

  1. 004-guava 集合-新增集合类型-MultiSet, MultiMap, BiMap , Table, ClassToInstanceMap, RangeSe, RangeMap等

    一.概述 Guava引入了很多JDK没有的.但明显有用的新集合类型.这些新类型是为了和JDK集合框架共存,而没有往JDK集合抽象中硬塞其他概念.作为一般规则,Guava集合非常精准地遵循了JDK接口契 ...

  2. 判断本网段有多少可用的ip地址

    为了提高效率,使用多线程方式同时ping. 但是如果开启255个线程,又会因为网络端口太拥挤,会被判定为无法ping通.所以本例使用java自带线程池,线程池的连接数还不能太大,启动了15个线程. 等 ...

  3. RHEL7 的注册

    RHEL7 的注册 2016年09月12日 20:37:19 wojiushiwoba 阅读数 13002更多 分类专栏: 嵌入式linux   版权声明:本文为博主原创文章,遵循CC 4.0 BY- ...

  4. Eclipse JEE 2018.12R TUNA源直接下载地址

    下载地址:https://mirrors.tuna.tsinghua.edu.cn/eclipse/technology/epp/downloads/release/2018-12/R/eclipse ...

  5. Linux脚本检测当前用户是否为root用户

    #/bin/bash if [ $UID -ne 0 ]; then echo Non root user. Please run as root. else echo Root user fi

  6. node不要使用最新版本,使用LTS版本

    错误现象 const { Math, Object, Reflect } = primordials; 原因 使用了最新的node版本 解决 使用稳定版本,参考官网说明,目前10.x的版本是稳定版本( ...

  7. RabbitMQ官方教程三 Publish/Subscribe(GOLANG语言实现)

    RabbitMQ官方教程三 Publish/Subscribe(GOLANG语言实现) 在上一个教程中,我们创建了一个工作队列. 工作队列背后的假设是,每个任务都恰好交付给一个worker处理. 在这 ...

  8. 【GStreamer开发】GStreamer播放教程03——pipeline的快捷访问

    目的 <GStreamer08--pipeline的快捷访问>展示了一个应用如何用appsrc和appsink这两个特殊的element在pipeline中手动输入/提取数据.playbi ...

  9. KVM虚拟机两种配置的概念不同之处

    KVM虚拟机配置的两种方式之间的不同之处 NAT方式 NAT模式中,让虚拟机借助NAT(网络地址转换)功能,通过宿主机器所在的网络来访问公网. NAT模式中,虚拟机的网卡和物理网卡的网络,不在同一个网 ...

  10. mybatis执行流程

    mybatis 简介 开源的持久层框架:代码简洁,写sql,性能还可以.容易掌握 执行图 文字说明 先创建核心配置文件(sqlMapConfig.xml) 再创建映射文件(可以有多个 ~ 通常有多少张 ...