具体操作:自定义消息通知内容布局;点击界面中心的“点击发送消息”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
相关文章:
简单实现Android验证码
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
购物网站制作公司有哪些,哪个购物网站比较好?
如何快速生成专业多端适配建站电话?
婚礼视频制作网站,学习*后期制作的网站有哪些?
平台云上自助建站如何快速打造专业网站?
如何在阿里云虚拟服务器快速搭建网站?
商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
网站制作公司广州有几家,广州尚艺美发学校网站是多少?
测试制作网站有哪些,测试性取向的权威测试或者网站?
c# await 一个已经完成的Task会发生什么
合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
建站主机选购指南与交易推荐:核心配置解析
如何在阿里云购买域名并搭建网站?
建站主机选虚拟主机还是云服务器更好?
高防服务器租用指南:配置选择与快速部署攻略
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
昆明高端网站制作公司,昆明公租房申请网上登录入口?
做企业网站制作流程,企业网站制作基本流程有哪些?
定制建站模板如何实现SEO优化与智能系统配置?18字教程
建站之星微信建站一键生成小程序+多端营销系统
如何在建站之星绑定自定义域名?
黑客入侵网站服务器的常见手法有哪些?
如何通过FTP服务器快速搭建网站?
如何生成腾讯云建站专用兑换码?
网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?
php json中文编码为null的解决办法
建站之星如何实现五合一智能建站与营销推广?
如何选择适配移动端的WAP自助建站平台?
淘宝制作网站有哪些,淘宝网官网主页?
建站之星官网登录失败?如何快速解决?
魔毅自助建站系统:模板定制与SEO优化一键生成指南
中山网站制作网页,中山新生登记系统登记流程?
宝塔建站助手安装配置与建站模板使用全流程解析
如何在香港服务器上快速搭建免备案网站?
如何确保西部建站助手FTP传输的安全性?
如何使用Golang安装API文档生成工具_快速生成接口文档
如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本
制作宣传网站的软件,小红书可以宣传网站吗?
金*站制作公司有哪些,金华教育集团官网?
香港服务器部署网站为何提示未备案?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
如何选择高性价比服务器搭建个人网站?
魔方云NAT建站如何实现端口转发?
如何在建站宝盒中设置产品搜索功能?
建站之星2.7模板快速切换与批量管理功能操作指南
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
如何用已有域名快速搭建网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。