具体操作:自定义消息通知内容布局;点击界面中心的“点击发送消息”TextView控件,模拟发送通知消息,通知栏接收消息,点击几次则发送几次,点击通知栏消息,跳转到详情界面。

1.activity_main.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
tools:context=".MainActivity">
<TextView
android:id="@+id/tv_show"
android:text="点击发送消息"
android:textSize="24sp"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
2.layout_item.xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:src="@mipmap/ic_launcher" />
<TextView
android:id="@+id/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="18dp"
android:layout_toRightOf="@+id/imageView1"
android:text="TextView" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@+id/textView1"
android:layout_below="@+id/textView1"
android:layout_marginTop="15dp"
android:text="TextView" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/textView1"
android:layout_marginLeft="54dp"
android:layout_toRightOf="@+id/textView2"
android:text="TextView" />
<TextView
android:id="@+id/textView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_below="@+id/textView1"
android:text="TextView" />
</RelativeLayout>
3.activity_detail.xml:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="New Text"
android:id="@+id/name"
android:textSize="18sp"
android:layout_gravity="center_horizontal"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="New Text"
android:id="@+id/price"
android:textSize="18sp"
android:layout_gravity="center_horizontal"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="New Text"
android:id="@+id/detail"
android:textSize="18sp"
android:layout_gravity="center_horizontal"/>
</LinearLayout>
4.SingletonF类:
/**
* 用于存储消息数目
* Created by admin on 2017/9/4.
*/
public class SingletonF{
private int info_number=0;
private static class SingletonHolder {
/**
* 单例对象实例
*/
static final SingletonF INSTANCE = new SingletonF();
}
public static SingletonF getInstance() {
return SingletonHolder.INSTANCE;
}
/**
* private的构造函数用于避免外界直接使用new来实例化对象
*/
private SingletonF() {}
public int getInfo_number() {
return info_number;
}
public void setInfo_number(int info_number) {
this.info_number = info_number;
}
// /**
// * 若SingletonF implements Serializable则必须实现readResolve方法
// * readResolve方法应对单例对象被序列化时候
// */
// private Object readResolve() {
// return getInstance();
// }
}
5.MyBroadcastReceiver类:
import java.text.SimpleDateFormat;
import java.util.Date;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.os.Handler;
import android.os.Message;
import android.support.v4.app.NotificationCompat;
import android.util.Log;
import android.widget.RemoteViews;
public class MyBroadcastReceiver extends BroadcastReceiver {
private SingletonF singletonF;
private Context context1;
@Override
public void onReceive(Context context, Intent intent) {
this.context1 = context;
// if (intent.getStringExtra("info").equals("广播发送了")) {
// Log.i("静态广播:", "广播我已经接受了");
// }
Message message = handler.obtainMessage();
message.what = 0;
handler.sendMessage(message);
}
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case 0:
singletonF = SingletonF.getInstance();
int first = singletonF.getInfo_number();
first++;
Date nowTime = new Date(System.currentTimeMillis());
SimpleDateFormat sdFormatter = new SimpleDateFormat("HH:mm");
String retStrFormatNowDate = sdFormatter.format(nowTime);
singletonF.setInfo_number( first);
RemoteViews contentViews = new RemoteViews(context1.getPackageName(), R.layout.layout_item);
// 通过控件的Id设置属性
contentViews.setImageViewResource(R.id.imageView1, R.mipmap.ic_launcher_round);
contentViews.setTextViewText(R.id.textView1, "消息标题");
contentViews.setTextViewText(R.id.textView2, "消息内容");
contentViews.setTextViewText(R.id.textView3, " (" + first + "条新消息)");
contentViews.setTextViewText(R.id.textView4, "" + retStrFormatNowDate);
// 点击通知栏跳转的activity
Intent intent = new Intent(context1, ActDetail.class);
PendingIntent pendingIntent = PendingIntent.getActivity(context1, 0, intent,
PendingIntent.FLAG_CANCEL_CURRENT);
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(context1)
.setSmallIcon(R.mipmap.ic_launcher_round).setTicker("new message");
// 自动管理通知栏消息
mBuilder.setAutoCancel(true);
mBuilder.setContentIntent(pendingIntent);
/// 自定义布局
mBuilder.setContent(contentViews);
// 使用默认提示音
mBuilder.setDefaults(Notification.DEFAULT_ALL);
NotificationManager mNotificationManager = (NotificationManager) context1
.getSystemService(context1.NOTIFICATION_SERVICE);
// notify(int id, Notification notification)若id为同一个值,则通知栏只会显示一行,并不停更新此消息内容
// 若为类似UUID.randomUUID().hashCode()这样不同的唯一标识符,则有几条消息通知栏就显示几行
mNotificationManager.notify(1, mBuilder.build());
break;
default:
break;
}
}
};
}
6.MainActivity类:
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity {
private TextView tv_show;
private int btn_number = 0;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
tv_show = (TextView) this.findViewById( R.id.tv_show);
tv_show.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
showNotify();
btn_number++;
tv_show.setText("发送了" + btn_number + "次广播");
}
});
}
private void showNotify() {
Intent intent = new Intent();
intent.setAction("MASSAGE_NOTIFICATION");
// intent.putExtra("info", "广播发送了");
sendBroadcast(intent);
}
@Override
protected void onStop() {
btn_number = 0;
tv_show.setText("发送了" + btn_number + "次广播");
super.onStop();
}
@Override
protected void onPause() {
btn_number = 0;
tv_show.setText("发送了" + btn_number + "次广播");
super.onPause();
}
@Override
protected void onDestroy() {
btn_number = 0;
super.onDestroy();
}
}
7.ActDetail类:
import android.app.NotificationManager;
import android.content.Context;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
/**
* Created by admin on 2017/9/4.
*/
public class ActDetail extends AppCompatActivity{
NotificationManager notificationManager;
SingletonF singletonF;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_detail);
singletonF = SingletonF.getInstance();
notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
notificationManager.cancel(1);
singletonF.setInfo_number(0);
}
}
没找到原创作者,所以也不知道来自何处,只有等以后知道原创作者后再补上来源网址!!!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Notification
# 消息通知
# Android中通知Notification使用实例(振动、灯光、声音)
# Android中通过Notification&NotificationManager实现消息通知
# android中创建通知栏Notification代码实例
# Android开发 -- 状态栏通知Notification、NotificationManager
# android使用NotificationListenerService监听通知栏消息
# 详解Android中Notification通知提醒
# Android种使用Notification实现通知管理以及自定义通知栏实例(示例四)
# iOS推送之本地通知UILocalNotification
# Android 使用AlarmManager和NotificationManager来实现闹钟和通知
# Android开发之Notification通知用法详解
# 送了
# 几次
# 自定义
# 发送消息
# 也不
# 只会
# 跳转
# 几条
# 则有
# 补上
# 大家多多
# 具体操作
# 跳转到
# 若为
# 我已经
# 几行
# 提示音
# 新消息
# 序列化
# layout_gravity
相关文章:
做企业网站制作流程,企业网站制作基本流程有哪些?
常州自助建站工具推荐:低成本搭建与模板选择技巧
哈尔滨网站建设策划,哈尔滨电工证查询网站?
音乐网站服务器如何优化API响应速度?
如何基于云服务器快速搭建网站及云盘系统?
php条件判断怎么写_ifelse和switchcase的使用区别【对比】
网站制作的方法有哪些,如何将自己制作的网站发布到网上?
建站之星多图banner生成与模板自定义指南
如何在腾讯云免费申请建站?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
公司门户网站制作流程,华为官网怎么做?
网站图片在线制作软件,怎么在图片上做链接?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
如何在自有机房高效搭建专业网站?
宁波自助建站系统如何快速打造专业企业网站?
手机网站制作与建设方案,手机网站如何建设?
建站之家VIP精选网站模板与SEO优化教程整合指南
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
建站之星如何保障用户数据免受黑客入侵?
非常酷的网站设计制作软件,酷培ai教育官方网站?
网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何选择CMS系统实现快速建站与SEO优化?
网站设计制作企业有哪些,抖音官网主页怎么设置?
如何选择适配移动端的WAP自助建站平台?
建站主机服务器选型指南与性能优化方案解析
网站制作需要会哪些技术,建立一个网站要花费多少?
如何续费美橙建站之星域名及服务?
如何安全更换建站之星模板并保留数据?
如何快速查询网站的真实建站时间?
c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】
如何快速选择适合个人网站的云服务器配置?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
如何通过老薛主机一键快速建站?
Swift中switch语句区间和元组模式匹配
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
,交易猫的商品怎么发布到网站上去?
如何彻底卸载建站之星软件?
如何快速搭建自助建站会员专属系统?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
如何快速使用云服务器搭建个人网站?
如何零基础开发自助建站系统?完整教程解析
官网网站制作腾讯审核要多久,联想路由器newifi官网
云南网站制作公司有哪些,云南最好的招聘网站是哪个?
免费视频制作网站,更新又快又好的免费电影网站?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
Swift中循环语句中的转移语句 break 和 continue
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
*请认真填写需求信息,我们会在24小时内与您取得联系。