public class MainActivity extends Activity {
private TextView tv = null;
private Button setTime,cancelTime;
private Calendar c = null;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
String alarm = getIntent().getStringExtra(“alarm”);
if(alarm != null&&alarm.equals(“alarm”)){
stopService(new Intent(“com.yqy.yqy_alarm.MUSIC”));
}
tv = (TextView)findViewById(R.id.tv);
setTime = (Button)findViewById(R.id.setAlarm);
cancelTime = (Button)findViewById(R.id.cancelAlarm);
//得到日历实例,主要是为了下面的获取时间
c = Calendar.getInstance();
setTime.setOnClickListener(new Button.OnClickListener()
{
@Override
public void onClick(View arg0) {
c.setTimeInMillis(System.currentTimeMillis());
int hour = c.get(Calendar.HOUR_OF_DAY);
int minute = c.get(Calendar.MINUTE);
new TimePickerDialog(MainActivity.this, minute, new TimePickerDialog.OnTimeSetListener() {
@Override
public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
//是设置日历的时间,主要是让日历的年月日和当前同步
c.setTimeInMillis(System.currentTimeMillis());
//设置小时分钟,秒和毫秒都设置为0
c.set(Calendar.HOUR_OF_DAY, hourOfDay);
c.set(Calendar.MINUTE, minute);
c.set(Calendar.SECOND, 0);
c.set(Calendar.MILLISECOND, 0);
int requestCode = 0;//闹钟的唯一标示
Intent intent = new Intent(MainActivity.this, AlarmReceiver.class);
intent.putExtra(“requestCode”, requestCode);
PendingIntent pi = PendingIntent.getBroadcast(MainActivity.this, requestCode, intent, 0);
//得到AlarmManager实例
AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);
//根据当前时间预设一个警报
am.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), pi);
/**
-
第一个参数是警报类型;第二个参数是第一次执行的延迟时间,可以延迟,也可以马上执行;第三个参数是重复周期为一天
-
这句话的意思是设置闹铃重复周期,也就是执行警报的间隔时间
*/
// am.setRepeating(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+(60*1000),
// (246060*1000), pi);
// am.setRepeating(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(),
// 1000605, pi);
String msg = hourOfDay+“:”+minute;
tv.setText(“当前设置的闹钟时间:”+msg);
}
}, hour, minute, true).show();
//上面的TimePickerDialog中的5个参数参考:http://blog.csdn.net/yang_hui1986527/article/details/6839342
}
});
cancelTime.setOnClickListener(new Button.OnClickListener()
{
@Override
public void onClick(View v) {
Intent intent = new Intent(MainActivity.this, AlarmReceiver.class);
PendingIntent pi = PendingIntent.getBroadcast(MainActivity.this, 0,
intent, 0);
AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE);
//取消警报
am.cancel(pi);
tv.setText(“闹钟取消”);
//取消闹钟的同时取消音乐
stopService(new Intent(“com.yqy.yqy_alarm.MUSIC”));
}
});
}
}
AlarmReceiver
package com.yqy.yqy_alarm;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;
public class AlarmReceiver extends BroadcastReceiver {
Intent intent;
int requestCode = -1;
@Override
public void onReceive(Context context, Intent arg1) {
requestCode = arg1.getIntExtra(“requestCode”, 0);
NotificationManager nm = (NotificationManager)context.getSystemService(Context.NOTIFICATION_SERVICE);
Notification n = new Notification(R.drawable.ic_launcher, “Hello,there!”, System.currentTimeMillis());
n.flags = Notification.FLAG_AUTO_CANCEL;
intent = new Intent(context, MainActivity.class);
intent.putExtra(“alarm”, “alarm”);
intent.setComponent(new ComponentName(“com.yqy.yqy_alarm”, “com.yqy.yqy_alarm.MainActivity”));
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP|Intent.FLAG_ACTIVITY_NEW_TASK| Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);//关键的一步,设置启动模式
PendingIntent contentIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_CANCEL_CURRENT);
n.setLatestEventInfo(
context,
“Hello,there!”,
“Hello,there,I’m john.”,
contentIntent);
nm.notify(R.string.app_name, n);
Toast.makeText(context, “闹钟时间到”, Toast.LENGTH_SHORT).show();
intent = new Intent(“com.yqy.yqy_alarm.MUSIC”);
//启动Service播放音乐
context.stopService(new Intent(“com.yqy.yqy_alarm.MUSIC”));
context.startService(intent);
}
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
![](https://img-blog.csdnimg.cn/img_convert/73ad1c8779977f1879ab8c968dd4176d.jpeg)
面试复习笔记
这份资料我从春招开始,就会将各博客、论坛。网站上等优质的Android开发中高级面试题收集起来,然后全网寻找最优的解答方案。每一道面试题都是百分百的大厂面经真题+最优解答。包知识脉络 + 诸多细节。
节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习。
《960页Android开发笔记》
《1307页Android开发面试宝典》
包含了腾讯、百度、小米、阿里、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。熟悉本文中列出的知识点会大大增加通过前两轮技术面试的几率。
《507页Android开发相关源码解析》
只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
《507页Android开发相关源码解析》
只要是程序员,不管是Java还是Android,如果不去阅读源码,只看API文档,那就只是停留于皮毛,这对我们知识体系的建立和完备以及实战技术的提升都是不利的。
真正最能锻炼能力的便是直接去阅读源码,不仅限于阅读各大系统源码,还包括各种优秀的开源库。
[外链图片转存中…(img-WFcSic6G-1712334364421)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!