Android AlarmManager 重复精准重复定时

    // 获取AlarmManager实例
    public static AlarmManager getAlarmManager(Context context) {
        return (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
    }
 String text 为要设置的时间  格式为:13:02
 requestCode第二个参数传不同的值,可以设置多个个闹钟
 PendingIntent pendingIntent = PendingIntent.getService(context, requestCode, intent, requestCode);//0x102
 requestCode 也可以吧这个值传给广播或者Service中判断是那个闹钟响了,需要执行什么操作

  getString()保存定时的时间,和传入的参数  以便重复定时使用

 //设置闹钟
    @RequiresApi(api = Build.VERSION_CODES.KITKAT)
    public static void timing(Context context, AlarmManager alarmManager, String text, int requestCode) {

        if (text != null && text.length() > 0) {

            String[] times = text.split(":");

            //发送广播
            Intent intent = new Intent(context, My_Service.class);//context,My_Service.class
//            intent.setAction("com.example.android_08_alarm.ring_ck");
            intent.putExtra("requestCode", requestCode + "");
            //将来时态的跳转   第四个参数flags意为标记,初步认为flags是标识各个PendingIntent的
            PendingIntent pendingIntent = PendingIntent.getService(context, requestCode, intent, requestCode);//0x102
            //选择闹钟启用的时间  此处时间从textview截取
            Calendar calendar2 = Calendar.getInstance();
            calendar2.set(Calendar.HOUR_OF_DAY, Integer.parseInt(times[0]));  //时
            calendar2.set(Calendar.MINUTE, Integer.parseInt(times[1]));        //分

            //获取当前系统时间
            Calendar calendar3 = Calendar.getInstance();

            //当前系统时间16点>你想设置的时间8点 把日期加一到第二天
            if (calendar3.getTimeInMillis() > calendar2.getTimeInMillis()) {
                calendar2.set(Calendar.DAY_OF_YEAR, calendar2.get(Calendar.DAY_OF_YEAR) + 1);
            }
            //AlarmManager.INTERVAL_DAY 间隔一天 24 * 60 * 60 * 1000
//            int A=24 * 60 * 60 * 1000;
            alarmManager.setExact(AlarmManager.RTC_WAKEUP, calendar2.getTimeInMillis(), pendingIntent);


            //保存定时的时间,和传入的参数  以便重复定时使用
            getString(text, requestCode);

        }

    }



 //重复定时保存需要定时的时间
    private static void getString(String text_value, int requestCode_value) {

        if (requestCode_value == 1)
            SharedPreferencesUtils.putString("time1_CF", text_value);

        if (requestCode_value == 2)
            SharedPreferencesUtils.putString("time2_CF", text_value);
}

此处是service中的操作

         //获取穿入的值
   values = intent.getStringExtra("requestCode");

                            switch (Integer.valueOf(values)) {
                               //根据传值执行需要的操作
                                case 1:
                                    week_RQ.send_Serial(context, (byte) 0x01);
                                    
                                    //重复定时
                                    getTimer(context, timer1, task1, "time1_CF", 1);

                                    break;
                                case 2:
                                    week_RQ.send_Serial(context, (byte) 0x02);

       
                                    //重复定时
                                    getTimer(context, timer2, task2, "time2_CF", 2);

                                    break;
                                case 3:
                                    week_RQ.send_Serial(context, (byte) 0x04);

       
                                    //重复定时
                                    getTimer(context, timer3, task3, "time3_CF", 3);
                                    break;
                            }


 //重复定时
    private static void getTimer(final Context context, Timer timer, TimerTask task, final String time_CF, final int request) {

        if (timer == null)
            timer = new Timer();

        //此处延迟一分钟 定时是实时的  防止多次重复响铃
        task = new TimerTask() {
            @RequiresApi(api = Build.VERSION_CODES.KITKAT)
            @Override
            public void run() {
                //重复定时 关闭在定时
                String time_CFS = "";
                time_CFS = SharedPreferencesUtils.getString(time_CF);
                timeutils.timing(context, FragmentYaoXiang.alarmManager, time_CFS, request);
            }
        };
        timer.schedule(task, 60000);  //参数2延时时间,周期时间,1分钟取后台数据


    }

最后取消定时的时候记得关闭重复定时,重复定时是延时一分钟执行的  如果定时响铃后立马关闭并没有取消重复定时

所以取消定时后需要执行关闭计时任务


    public static void getCancel(Timer timer, TimerTask task) {

        if (timer != null) {
            timer.cancel();
            timer = null;
        }

        if (task != null) {
            task.cancel();
            task = null;
        }
    }

取消定时代码

 // 取消指定requestCode的定时任务
    // 参数:
    // context:上下文
    // requestCode:请求码,用于区分不同的任务
    // cls:广播接收器的class
    public static void cancelAlarmBroadcast(Context context, AlarmManager alarmManager, int requestCode) {
        Intent intent = new Intent(context, My_Service.class);//context,My_Service.class
//        intent.setAction("com.example.android_08_alarm.ring_ck");
        PendingIntent pi = PendingIntent.getBroadcast(context, requestCode, intent, requestCode);
        alarmManager.cancel(pi);
    }

 

只需要在你取消的点击事件中执行

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用 AlarmManager 实现定时重置流量统计可以分为以下几个步骤: 1. 在 AndroidManifest.xml 文件中添加以下权限: ```xml <uses-permission android:name="android.permission.MODIFY_PHONE_STATE" /> <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" /> ``` 2. 创建一个 BroadcastReceiver,用于接收定时任务的触发事件,并在其中实现重置流量统计的逻辑。例如: ```java public class TrafficStatsResetReceiver extends BroadcastReceiver { @Override public void onReceive(Context context, Intent intent) { // 重置流量统计信息 TrafficStats.clearAllStats(); } } ``` 3. 在 AndroidManifest.xml 文件中注册 BroadcastReceiver,并且添加一个 ACTION_BOOT_COMPLETED 的 intent-filter,以便在设备启动时启动定时任务。例如: ```xml <receiver android:name=".TrafficStatsResetReceiver" android:enabled="true" android:exported="false"> <intent-filter> <action android:name="com.example.trafficstatsreset.ACTION_RESET_TRAFFIC_STATS" /> <action android:name="android.intent.action.BOOT_COMPLETED" /> </intent-filter> </receiver> ``` 4. 在应用程序启动时注册一个定时任务,例如: ```java private void registerTrafficStatsResetTask(Context context) { // 创建一个 PendingIntent,用于触发定时任务 Intent intent = new Intent(context, TrafficStatsResetReceiver.class); intent.setAction("com.example.trafficstatsreset.ACTION_RESET_TRAFFIC_STATS"); PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT); // 获取 AlarmManager 实例 AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE); // 计算定时任务的触发时间 long triggerTime = System.currentTimeMillis() + 24 * 60 * 60 * 1000; // 每天重置一次流量统计 // 注册定时任务 alarmManager.setRepeating(AlarmManager.RTC_WAKEUP, triggerTime, 24 * 60 * 60 * 1000, pendingIntent); } ``` 在上述代码中,我们创建了一个 PendingIntent,并将其传递给 AlarmManager 的 setRepeating 方法,以便注册一个每天重置一次流量统计的定时任务。需要注意的是,我们设置的定时任务触发时间是当前时间加上一天的时间间隔,这样可以确保定时任务在第二天凌晨触发。 5. 在应用程序启动时调用 registerTrafficStatsResetTask 方法,注册定时任务即可: ```java @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); // 注册定时任务 registerTrafficStatsResetTask(this); } ``` 经过上述步骤,您就可以使用 AlarmManager 来实现定时重置流量统计的功能了。需要注意的是,使用 AlarmManager 时需要仔细管理定时任务的触发时间和间隔,以确保应用程序的稳定性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值