Android:Moring-早安闹钟开发过程记录(一)

2023-10-11 00:30

本文主要是介绍Android:Moring-早安闹钟开发过程记录(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该文章用于记录整理开发早安闹钟过程的思路及知识点

1.程序介绍

想做这样一个APP源于我经常在睡梦中轻易的把闹钟关掉,导致起不来,各种迟到,并且醒了以后完全不知道闹钟竟然响过,而且经常早上时间来不及了,穿好衣服出了门才发现不是太冷就是太热。

2. 界面布局

为了让HomeActivity的逻辑不会过于复杂,添加了三个Fragment,独立完成各自的逻辑。

  • FragmentAlarm

    用于显示闹钟的相关信息,并处理相关逻辑。核心控件为一个ListView,
    在Item中使用RelativeLayout实现点击出现编辑菜单。

    FragmentAlarm.jpg


    附上菜单动画的代码

    RelativeLayout rl_main = (RelativeLayout) view.findViewById(R.id.rl_main_item);LinearLayout ll_button = (LinearLayout) view.findViewById(R.id.ll_button_item);
    final Button bt_delete = (Button) view.findViewById(R.id.bt_delete_item);final Button bt_update = (Button) view.findViewById(R.id.bt_update_item);
    final SwitchButton sb= (SwitchButton) view.findViewById(R.id.bt_turn_item);
    float back = ll_button.getWidth();
    float front = rl_main.getWidth();float width = back / front;
    ll_button.setMinimumHeight(rl_main.getHeight());
    Log.d("alarm", width + "宽度");TranslateAnimation ta;
    if(isMenuOn){    //开着的就关    ta= new TranslateAnimation(Animation.RELATIVE_TO_SELF, width, Animation.RELATIVE_TO_SELF, 0f,Animation.RELATIVE_TO_SELF, 0f, Animation.RELATIVE_TO_SELF, 0f);    onMenu=null;    isMenuOn=false;
    }else{    ta= new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0f, Animation.RELATIVE_TO_SELF, width, Animation.RELATIVE_TO_SELF, 0f, Animation.RELATIVE_TO_SELF, 0f); onMenu=view;    isMenuOn=true;
    }
    ta.setDuration(200);
    ta.setFillAfter(true);

    View onMenu用来接收当前有菜单开启的item,便于点击下一个Item的时候关闭该菜单,Boolean isMenuOn用于判断当前是否有菜单开启

  • FragmentWeather

     用于显示天气的相关信息,并处理相关逻辑。布局较为简单不进行赘述。

    *FragmentMenu

      用于显示侧滑菜单,侧滑菜单核心控件为ListView

    3.功能分析

  • 闹钟功能模块
    -添加闹钟
        核心逻辑:将用户添加的闹钟的各种信息记录到数据库中,同时在点击完成的时候将数据传给FragmentAlarm,刷新UI。用到的类AlarmInfo.class(闹钟信息对象),AlarmInfoDao(数据库读取工具类)。
    -修改闹钟
        与添加闹钟相同,返回数据时通过不同的RequestCode来与添加闹钟区分
    -启动闹钟定时任务
    AlarmManager
    通过getSystemService(ALARM_SERVICE)获取到AlarmManager对象
    AlarmManger中有set()和setRepeating()方法用于一次性定时任务和重复定时任务
    但在实际测试中发现会有不同程度的delay,(PS.小米真的很严重)
    通过查阅官方文档可知
    在API 19以后这两个方法将不再精准,如果需要使用精确定时任务,应该使用setExact();(API 19以前没有问题)
    -因此在设置定时任务时加一个判断(由于该方法在多处进行调用,我把它单独封装成了一个类)
    public void startAlarm(AlarmManager mAlamManager, PendingIntent pi){   //设置定时任务触发的时间 Calendar c=Calendar.getInstance();                     c.set(Calendar.HOUR_OF_DAY,alarmInfo.getHour());    c.set(Calendar.MINUTE,alarmInfo.getMinute());    c.set(Calendar.SECOND,0);    c.set(Calendar.MILLISECOND, 0);    //  Log.d("alarm", "当前系统版本" + Build.VERSION.SDK_INT);    if(c.getTimeInMillis()<System.currentTimeMillis()){        if(Build.VERSION.SDK_INT>=19) {            mAlamManager.setExact(AlarmManager.RTC_WAKEUP, c.getTimeInMillis() + 24 * 60 * 60 * 1000, pi);        }else{            mAlamManager.set(AlarmManager.RTC_WAKEUP,     c.getTimeInMillis() + 24 * 60 * 60 * 1000, pi);}    }else{if(Build.VERSION.SDK_INT>=19) {                        mAlamManager.setExact(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), pi);}else{mAlamManager.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), pi);} }
    }
    -问题来了:setExact();只能执行一次性定时任务如何实现重复闹钟?
    这里我最后采取得方法是在AlarmReceiver中再定一次相同的定时任务,这样在每次收到定时广播后,又重新设定一个相同的定时任务,就能达到重复精确定时的效果。
        另外,在判断闹钟应该在那几天重复,我写的逻辑是,除了一次性闹钟外,所有的重复闹钟都会在每天执行定时广播在AlarmReceiver中去判断今天的dayOfWeek和闹钟信息的dayOfWeek是否吻合吻合就启动闹钟service,否则重新定时
    用于判断当前dayOfweek的代码
    Calendar calendar=Calendar.getInstance();
    calendar.setTimeInMillis(System.currentTimeMillis());
    int currentDay=calendar.get(Calendar.DAY_OF_WEEK)-1;
    for(int i=0;i<dayOfWeek.length;i++){if(currentDay==dayOfWeek[i]){wakePhoneAndUnlock();//点亮屏幕并解锁ringAlarm();}
    这里用到了点亮屏幕和解锁,也贴一下代码,这段代码是我在CSDN上学到的不知道哪位大大的代码(那天脑袋晕晕的真的忘了T_T,如果原作者看到并且希望我删除或者怎么样的请联系我,我会照做的)
      //点亮屏幕并解锁    private void wakePhoneAndUnlock() {PowerManager pm = (PowerManager)context.getSystemService(Context.POWER_SERVICE);PowerManager.WakeLock mWakelock = pm.newWakeLock(PowerManager.ACQUIRE_CAUSES_WAKEUP | PowerManager.FULL_WAKE_LOCK, "WakeLock");mWakelock.acquire();//唤醒屏幕//......KeyguardManager mManager = (KeyguardManager)context.getSystemService(Context.KEYGUARD_SERVICE);KeyguardManager.KeyguardLock mKeyguardLock = mManager.newKeyguardLock("Lock");mKeyguardLock.disableKeyguard();mWakelock.release();
    //释放}
    到这里闹钟的基本定时功能就完成了,另外在AlarmReceiver中加入了开机广播的监听,来开启应该要开启的闹钟
    //开机时检查是否有闹钟需要开启
    private void checkAndStartAlarm() {Log.d("alarm","开始检查是否有闹钟");AlarmInfoDao dao=new AlarmInfoDao(context);ArrayList<AlarmInfo> list= (ArrayList<AlarmInfo>) dao.getAllInfo();AlarmClock clock=new AlarmClock(context);for (AlarmInfo alarmInfo:list) {if(PrefUtils.getBoolean(context,alarmInfo.getId(),true)){Log.d("alarm","有闹钟,开启");clock.turnAlarm(alarmInfo,true);}}
    }
    //请自动忽略掉Log信息

    结尾

    到这里闹钟的定时任务就全部完成,在下一篇文章中分析对话框和天气早知道功能的实现
    未完待续...

这篇关于Android:Moring-早安闹钟开发过程记录(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/184220

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

oracle 11g导入\导出(expdp impdp)之导入过程

《oracle11g导入导出(expdpimpdp)之导入过程》导出需使用SEC.DMP格式,无分号;建立expdir目录(E:/exp)并确保存在;导入在cmd下执行,需sys用户权限;若需修... 目录准备文件导入(impdp)1、建立directory2、导入语句 3、更改密码总结上一个环节,我们讲了

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10