具体操作:自定义消息通知内容布局;点击界面中心的“点击发送消息”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验证码
如何用低价快速搭建高质量网站?
html制作网站的步骤有哪些,iapp如何添加网页?
制作门户网站的参考文献在哪,小说网站怎么建立?
建站之星安装路径如何正确选择及配置?
平台云上自主建站:模板化设计与智能工具打造高效网站
定制建站哪家更专业可靠?推荐榜单揭晓
建站之星如何快速更换网站模板?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
如何零基础开发自助建站系统?完整教程解析
黑客如何通过漏洞一步步攻陷网站服务器?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
江苏网站制作公司有哪些,江苏书法考级官方网站?
常州自助建站费用包含哪些项目?
网站制作和推广的区别,想自己建立一个网站做推广,有什么快捷方法马上做好一个网站?
家庭服务器如何搭建个人网站?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
官网建站费用明细查询_企业建站套餐价格及收费标准指南
网站制作价目表怎么做,珍爱网婚介费用多少?
网页设计网站制作软件,microsoft office哪个可以创建网页?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
建站之星会员如何解锁更多建站功能?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
高端企业智能建站程序:SEO优化与响应式模板定制开发
开源网站制作软件,开源网站什么意思?
网站制作网站,深圳做网站哪家比较好?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
建站之星Pro快速搭建教程:模板选择与功能配置指南
音响网站制作视频教程,隆霸音响官方网站?
山东云建站价格为何差异显著?
如何通过虚拟主机空间快速建站?
独立制作一个网站多少钱,建立网站需要花多少钱?
c# await 一个已经完成的Task会发生什么
制作企业网站建设方案,怎样建设一个公司网站?
php json中文编码为null的解决办法
如何通过网站建站时间优化SEO与用户体验?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
建站主机是什么?如何选择适合的建站主机?
SQL查询语句优化的实用方法总结
如何在Golang中使用replace替换模块_指定本地或远程路径
如何用好域名打造高点击率的自主建站?
建站之星上传入口如何快速找到?
广德云建站网站建设方案与建站流程优化指南
企业微网站怎么做,公司网站和公众号有什么区别?
C++中引用和指针有什么区别?(代码说明)
如何基于云服务器快速搭建个人网站?
jQuery 常见小例汇总
如何快速搭建支持数据库操作的智能建站平台?
*请认真填写需求信息,我们会在24小时内与您取得联系。