- 小图标,使用setSamllIcon()方法设置。
- 标题,使用setContentTitle()方法设置。
- 文本内容,使用setContentText()方法设置。
publicvoid clickButton(View view) {
switch (view.getId()) {
case R.id.button_main_common:
Notification.Builder builder1 = new Notification.Builder(this);
builder1.setSmallIcon(R.drawable.ic_launcher);
builder1.setContentTitle("提示:");
builder1.setContentText("请注意休息,时间到了!");builder1.setAutoCancel(true);
Intent intent = new Intent(this, NextActivity.class);
PendingIntent pIntent = PendingIntent.getActivity(this, 1, intent,
PendingIntent.FLAG_ONE_SHOT);
builder1.setContentIntent(pIntent);
nManager.notify(R.id.button_main_common, builder1.build());
break;
case R.id.button_main_bigpicture:
Notification.Builder builder2 = new Notification.Builder(this);
builder2.setSmallIcon(R.drawable.alert);
builder2.setContentTitle("提示:");
builder2.setContentText("以下是展示的大图片。。。");
Notification.BigPictureStyle bigStyle = new BigPictureStyle(builder2);
Bitmap bitmap = BitmapFactory.decodeResource(getResources(),
R.drawable.big);
bigStyle.bigPicture(bitmap);
nManager.notify(R.id.button_main_bigpicture, bigStyle.build());
break;
case R.id.button_main_progress:
final Notification.Builder builder3 = new Notification.Builder(this);
builder3.setSmallIcon(R.drawable.alert);
builder3.setContentTitle("提示:");
builder3.setContentText("数据下载中。。。");
new Thread(new Runnable() {
@Override
publicvoid run() {
for (int i = 0; i <= 100; i += 5) {
builder3.setProgress(100, i, false);
nManager.notify(R.id.button_main_progress,
builder3.build());
try {
Thread.sleep(500);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
builder3.setContentText("下载完毕!");
nManager.notify(R.id.button_main_progress, builder3.build());nManager.cancel(R.id.button_main_progress);
}
}).start();
break;
case R.id.button_main_clear:
nManager.cancelAll();
break;
}
}
- Intent是立即使用的,而PendingIntent可以等到事件发生后触发,PendingIntent可以cancel;
- Intent在程序结束后即终止,而PendingIntent在程序结束后依然有效;
- PendingIntent自带Context,而Intent需要在某个Context内运行;
- Intent在原task中运行,PendingIntent在新的task中运行。
- FLAG_ONE_SHOT : 这个PendingIntent只能使用一次。
- FLAG_NO_CREATE : 如果被描述的PendingIntent不存在,那么简单地返回null,而不是创建它。
- FLAG_CANCEL_CURRENT : 如果被描述的PendingIntent已经存在,在即将生成一个新的PendingIntent前,当前的一个要被取消。
- FLAG_UPDATE_CURRENT :如果被描述的PendingIntent已经存在,那么继续保持它,但它其中的数据会因为新Intent而更新。
FLAG_CANCEL_CURRENT:如果当前系统中已经存在一个相同的PendingIntent对象,那么就将先将已有的PendingIntent取消,然后重新生成一个PendingIntent对象。
FLAG_NO_CREATE:如果当前系统中不存在相同的PendingIntent对象,系统将不会创建该PendingIntent对象而是直接返回null。
FLAG_ONE_SHOT:该 PendingIntent只作用一次。在该PendingIntent对象通过send()方法触发过后,PendingIntent将自动调用 cancel()进行销毁,那么如果你再调用send()方法的话,系统将会返回一个SendIntentException。
FLAG_UPDATE_CURRENT: 如果系统中有一个和你描述的PendingIntent对等的PendingInent,那么系统将使用该PendingIntent对象,但是会使用新 的Intent来更新之前PendingIntent中的Intent对象数据,例如更新Intent中的Extras。
】二、广播简介:
<receiver
android:name=".CallReceiver"
android:enabled="true">
<intent-filter >
<action android:name="android.intent.action.PHONE_STATE"/>
</intent-filter>
</receiver>
静态注册就是在AndroidManifest.xml文件中定义,注册的广播接收器必须继承BroadReceiver;
动态注册方式是在activity里面调用当前上下文对象的registerReceiver() 方法 来注册,和静态的内容差不多。一个形参是receiver对象,另一个是IntentFilter对象。而IntentFilter构造方法的参数是要接收的action。
动态注册广播接收器的特点,就是当用来注册的 Activity 关掉后,广播也就失效了。同时反映了静态注册的一个优势,就是无需担忧广播接收器是否被关闭,只要设备是开启状态,广播接收器就是打开着的。
MyReceiver receiver = new MyReceiver();
//创建过滤器,并指定action,使之用于接收同action的广播 IntentFilter filter = new IntentFilter("android.intent.action.PHONE_STATE");
//或者:
IntentFilter filter = new IntentFilter();
filter.addAction("android.intent.action.PHONE_STATE");
filter.setPriority(999);
registerReceiver(receiver, filter);
// 指定广播目标Action Intent intent = new Intent("MyReceiver_Action"); // 可通过Intent携带消息 intent.putExtra("msg", "发送广播"); // 发送广播消息 sendBroadcast(intent);
//动态注册的广播要记住在activity的onDestroy回调方法中注销广播接收器 unregisterReceiver(receiver);
-
Protocol Data Unit (PDU:
协议数据单元)
public void onReceive(Context context, Intent intent) {
Log.i(TAG, "==来短信了");
// 获取短信的具体信息:短信发送号码,短信内容,短信发送时间
Bundle bundle = intent.getExtras();
Object[] pdus = (Object[]) bundle.get("pdus");
SmsMessage[] smsMessage = new SmsMessage[pdus.length];
for (int i = 0; i < pdus.length; i++) {
smsMessage[i] = SmsMessage.createFromPdu((byte[]) pdus[i]);
}
String phoneNumber = smsMessage[0].getDisplayOriginatingAddress();
StringBuilder sb = new StringBuilder();
for (SmsMessage sms : smsMessage) {
sb.append(sms.getDisplayMessageBody());
}
String content = sb.toString();
Log.i(TAG, "==来短信了" + phoneNumber + ":" + content);
abortBroadcast();
}
<receiver
android:name=".MySmsReceiver"
android:enabled="true"
android:exported="true" >
<intent-filter android:priority="1" >
<action android:name="android.provider.Telephony.SMS_RECEIVED" >
</action>
</intent-filter>
</receiver>
public void onReceive(Context context, Intent intent) {
Log.i(TAG, "==电话状态改变了");
TelephonyManager manager = (TelephonyManager) context
.getSystemService(Service.TELEPHONY_SERVICE);
Bundle bundle = intent.getExtras();
// String phoneNumber0 = bundle
// .getString(TelephonyManager.EXTRA_INCOMING_NUMBER);
phoneNumber = bundle.getString("incoming_number");
prefs = context.getSharedPreferences("phonenumber",
Context.MODE_PRIVATE);
if (phoneNumber != null) {
editor = prefs.edit();
editor.putString("phoneNumber", phoneNumber);
editor.commit();
} else {
phoneNumber = prefs.getString("phoneNumber", "");
}
int state = manager.getCallState();
switch (state) {
case TelephonyManager.CALL_STATE_RINGING:// 铃声响动
Log.i(TAG, "==铃声响了" + phoneNumber);
break;
case TelephonyManager.CALL_STATE_OFFHOOK:// 电话接听
Log.i(TAG, "==接听电话" + phoneNumber);
break;
case TelephonyManager.CALL_STATE_IDLE:// 挂电话了
Log.i(TAG, "==电话挂了" + phoneNumber);
break;
default:
break;
}
}
<receiverandroid:name=".MyPhoneReceiver"android:enabled="true"android:exported="true" ><intent-filter><action android:name="android.intent.action.PHONE_STATE" >
</action></intent-filter></receiver>
public void onReceive(Context context, Intent intent) {
if (Intent.ACTION_SCREEN_OFF.equals(intent.getAction())) {
Log.i(TAG, "==屏幕休眠了");
}
if (Intent.ACTION_SCREEN_ON.equals(intent.getAction())) {
Log.i(TAG, "==屏幕唤醒了");
}
}
【注册:】
ScreenOffOnReceiver myReceiver = new ScreenOffOnReceiver();
IntentFilter filter = new IntentFilter();
filter.addAction(Intent.ACTION_SCREEN_OFF);
filter.addAction(Intent.ACTION_SCREEN_ON);
registerReceiver(myReceiver, filter);
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "监听到开机了", Toast.LENGTH_LONG).show();
Intent intent2 = new Intent(context, MainActivity.class);
context.startActivity(intent2);
}
<receiver
android:name=".LaunchReceiver"
android:enabled="true"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "电量降低 ", Toast.LENGTH_LONG).show();
}
<receiver
android:name=".BatteryReceiver"
android:enabled="true"
android:exported="true" >
<intent-filter>
<action android:name="android.intent.action.BATTERY_LOW" >
</action>
</intent-filter>
</receiver>
- A 发送的广播只会在自己App内传播,不会泄露给其他App,确保隐私数据不会泄露
- B 其他App也无法向你的App发送该广播,不用担心其他App会来搞破坏
- C 比系统全局广播更加高效
- String ADD_SHORTCUT_ACTION 动作:在系统中添加一个快捷方式。
- String ALL_APPS_ACTION 动作:列举所有可用的应用。输入:无。
- String ALTERNATIVE_CATEGORY 类别:说明 activity 是用户正在浏览的数据的一个可选操作。
- String ANSWER_ACTION 动作:处理拨入的电话。
- String BATTERY_CHANGED_ACTION 广播:充电状态,或者电池的电量发生变化。
- String BOOT_COMPLETED_ACTION 广播:在系统启动后,这个动作被广播一次(只有一次)。
- String BROWSABLE_CATEGORY 类别:能够被浏览器安全使用的 activities 必须支持这个类别。
- String BUG_REPORT_ACTION 动作:显示 activity 报告错误。
- String CALL_ACTION 动作:拨打电话,被呼叫的联系人在数据中指定。
- String CALL_FORWARDING_STATE_CHANGED_ACTION 广播:语音电话的呼叫转移状态已经改变。
- String CLEAR_CREDENTIALS_ACTION 动作:清除登陆凭证 (credential)。
- String CONFIGURATION_CHANGED_ACTION 广播:设备的配置信息已经改变,参见 Resources.Configuration.
- Creator CREATOR 无 无
- String DATA_ACTIVITY_STATE_CHANGED_ACTION 广播:电话的数据活动(data activity)状态(即收发数据的状态)已经改变。
- String DATA_CONNECTION_STATE_CHANGED_ACTION 广播:电话的数据连接状态已经改变。
- String DATE_CHANGED_ACTION 广播:日期被改变。
- String DEFAULT_ACTION 动作:和 VIEW_ACTION 相同,是在数据上执行的标准动作。
- String DEFAULT_CATEGORY 类别:如果 activity 是对数据执行确省动作(点击, center press)的一个选项,需要设置这个类别。
- String DELETE_ACTION 动作:从容器中删除给定的数据。
- String DEVELOPMENT_PREFERENCE_CATEGORY 类别:说明 activity 是一个设置面板 (development preference panel).
- String DIAL_ACTION 动作:拨打数据中指定的电话号码。
- String EDIT_ACTION 动作:为制定的数据显示可编辑界面。
- String EMBED_CATEGORY 类别:能够在上级(父)activity 中运行。
- String EMERGENCY_DIAL_ACTION 动作:拨打紧急电话号码。
- int FORWARD_RESULT_LAUNCH 启动标记:如果这个标记被设置,而且被一个已经存在的 activity 用来启动新的 activity,已有 activity 的回复目标 (reply target) 会被转移给新的 activity。
- String FOTA_CANCEL_ACTION 广播:取消所有被挂起的 (pending) 更新下载。
- String FOTA_INSTALL_ACTION 广播:更新已经被确认,马上就要开始安装。
- String FOTA_READY_ACTION 广播:更新已经被下载,可以开始安装。
- String FOTA_RESTART_ACTION 广播:恢复已经停止的更新下载。
- String FOTA_UPDATE_ACTION 广播:通过 OTA 下载并安装操作系统更新。
- String FRAMEWORK_INSTRUMENTATION_TEST_CATEGORY 类别:To be used as code under test for framework instrumentation tests.
- String GADGET_CATEGORY 类别:这个 activity 可以被嵌入宿主 activity (activity that is hosting gadgets)。
- String GET_CONTENT_ACTION 动作:让用户选择数据并返回。
- String HOME_CATEGORY 类别:主屏幕 (activity),设备启动后显示的第一个 activity。
- String INSERT_ACTION 动作:在容器中插入一个空项 (item)。
- String INTENT_EXTRA 附加数据:和 PICK_ACTIVITY_ACTION 一起使用时,说明用户选择的用来显示的 activity;和 ADD_SHORTCUT_ACTION 一起使用的时候,描述要添加的快捷方式。
- String LABEL_EXTRA 附加数据:大写字母开头的字符标签,和 ADD_SHORTCUT_ACTION 一起使用。
- String LAUNCHER_CATEGORY 类别:Activity 应该被显示在顶级的 launcher 中。
- String LOGIN_ACTION 动作:获取登录凭证。
- String MAIN_ACTION 动作:作为主入口点启动,不需要数据。
- String MEDIABUTTON_ACTION 广播:用户按下了“Media Button”。
- String MEDIA_BAD_REMOVAL_ACTION 广播:扩展介质(扩展卡)已经从 SD 卡插槽拔出,但是挂载点 (mount point) 还没解除 (unmount)。
- String MEDIA_EJECT_ACTION 广播:用户想要移除扩展介质(拔掉扩展卡)。
- String MEDIA_MOUNTED_ACTION 广播:扩展介质被插入,而且已经被挂载。
- String MEDIA_REMOVED_ACTION 广播:扩展介质被移除。
- String MEDIA_SCANNER_FINISHED_ACTION 广播:已经扫描完介质的一个目录。
- String MEDIA_SCANNER_STARTED_ACTION 广播:开始扫描介质的一个目录。
- String MEDIA_SHARED_ACTION 广播:扩展介质的挂载被解除 (unmount),因为它已经作为 USB 大容量存储被共享。
- String MEDIA_UNMOUNTED_ACTION 广播:扩展介质存在,但是还没有被挂载 (mount)。
- String MESSAGE_WAITING_STATE_CHANGED_ACTION 广播:电话的消息等待(语音邮件)状态已经改变。
- int MULTIPLE_TASK_LAUNCH 启动标记:和 NEW_TASK_LAUNCH 联合使用,禁止将已有的任务改变为前景任务 (foreground)。
- String NETWORK_TICKLE_RECEIVED_ACTION 广播:设备收到了新的网络 "tickle" 通知。
- int NEW_TASK_LAUNCH 启动标记:设置以后,activity 将成为历史堆栈中的第一个新任务(栈顶)。
- int NO_HISTORY_LAUNCH 启动标记:设置以后,新的 activity 不会被保存在历史堆栈中。
- String PACKAGE_ADDED_ACTION 广播:设备上新安装了一个应用程序包。
- String PACKAGE_REMOVED_ACTION 广播:设备上删除了一个应用程序包。
- String PHONE_STATE_CHANGED_ACTION 广播:电话状态已经改变。
- String PICK_ACTION 动作:从数据中选择一个项目 (item),将被选中的项目返回。
- String PICK_ACTIVITY_ACTION 动作:选择一个 activity,返回被选择的 activity 的类(名)。
- String PREFERENCE_CATEGORY 类别:activity是一个设置面板 (preference panel)。
- String PROVIDER_CHANGED_ACTION 广播:更新将要(真正)被安装。
- String PROVISIONING_CHECK_ACTION 广播:要求 polling of provisioning service 下载最新的设置。
- String RUN_ACTION 动作:运行数据(指定的应用),无论它(应用)是什么。
- String SAMPLE_CODE_CATEGORY 类别:To be used as an sample code example (not part of the normal user experience).
- String SCREEN_OFF_ACTION 广播:屏幕被关闭。
- String SCREEN_ON_ACTION 广播:屏幕已经被打开。
- String SELECTED_ALTERNATIVE_CATEGORY 类别:对于被用户选中的数据,activity 是它的一个可选操作。
- String SENDTO_ACTION 动作:向 data 指定的接收者发送一个消息。
- String SERVICE_STATE_CHANGED_ACTION 广播:电话服务的状态已经改变。
- String SETTINGS_ACTION 动作:显示系统设置。输入:无。
- String SIGNAL_STRENGTH_CHANGED_ACTION 广播:电话的信号强度已经改变。
- int SINGLE_TOP_LAUNCH 启动标记:设置以后,如果 activity 已经启动,而且位于历史堆栈的顶端,将不再启动(不重新启动) activity。
- String STATISTICS_REPORT_ACTION 广播:要求 receivers 报告自己的统计信息。
- String STATISTICS_STATE_CHANGED_ACTION 广播:统计信息服务的状态已经改变。
- String SYNC_ACTION 动作:执行数据同步。
- String TAB_CATEGORY 类别:这个 activity 应该在 TabActivity 中作为一个 tab 使用。
- String TEMPLATE_EXTRA 附加数据:新记录的初始化模板。
- String TEST_CATEGORY 类别:作为测试目的使用,不是正常的用户体验的一部分。
- String TIMEZONE_CHANGED_ACTION 广播:时区已经改变。
- String TIME_CHANGED_ACTION 广播:时间已经改变(重新设置)。
- String TIME_TICK_ACTION 广播:当前时间已经变化(正常的时间流逝)。
- String UMS_CONNECTED_ACTION 广播:设备进入 USB 大容量存储模式。
- String UMS_DISCONNECTED_ACTION 广播:设备从 USB 大容量存储模式退出。
- String UNIT_TEST_CATEGORY 类别:应该被用作单元测试(通过 test harness 运行)。
- String VIEW_ACTION 动作:向用户显示数据。
- String WALLPAPER_CATEGORY 类别:这个 activity 能过为设备设置墙纸。
- String WALLPAPER_CHANGED_ACTION 广播:系统的墙纸已经改变。
- String WALLPAPER_SETTINGS_ACTION 动作:显示选择墙纸的设置界面。输入:无。
- String WEB_SEARCH_ACTION 动作:执行 web 搜索。
- String XMPP_CONNECTED_ACTION 广播:XMPP 连接已经被建立。
- String XMPP_DISCONNECTED_ACTION 广播:XMPP 连接已经被断开。