Notification消息通知 自定义消息通知内容布局

 更新时间:2017年09月19日 15:59:46   作者:An_nAl  
这篇文章主要为大家详细介绍了Notification消息通知,消息合并且显示条数,自定义消息通知内容布局,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

具体操作:自定义消息通知内容布局;点击界面中心的“点击发送消息”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);
  }
}

没找到原创作者,所以也不知道来自何处,只有等以后知道原创作者后再补上来源网址!!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android Activity的启动过程源码解析

    Android Activity的启动过程源码解析

    这篇文章主要介绍了Android Activity的启动过程源码解析,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-05-05
  • Android中NestedScrolling滑动机制详解

    Android中NestedScrolling滑动机制详解

    本篇文章主要介绍了Android中NestedScrolling滑动机制详解,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-02-02
  • Android view自定义带文字带进度的控件

    Android view自定义带文字带进度的控件

    这篇文章主要为大家详细介绍了Android view自定义带文字带进度的控件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Android编程之计时器Chronometer简单示例

    Android编程之计时器Chronometer简单示例

    这篇文章主要介绍了Android计时器Chronometer简单用法,结合实例形式分析了Android计时器Chronometer的定义、事件响应及界面布局相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • Android学习教程之悬浮窗菜单制作(9)

    Android学习教程之悬浮窗菜单制作(9)

    这篇文章主要为大家详细介绍了Android学习教程之悬浮窗菜单制作方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • Android使用LinearLayout设置边框

    Android使用LinearLayout设置边框

    这篇文章主要介绍了Android如何使用LinearLayout设置边框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09
  • Flutter 日期时间DatePicker控件及国际化

    Flutter 日期时间DatePicker控件及国际化

    这篇文章主要介绍了Flutter 日期时间DatePicker控件及国际化,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Android开发之Picasso通过URL获取用户头像的圆形显示

    Android开发之Picasso通过URL获取用户头像的圆形显示

    这篇文章主要介绍了android开发之Picasso通过URL获取用户头像的圆形显示,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • 浅谈Android应用安全防护和逆向分析之apk反编译

    浅谈Android应用安全防护和逆向分析之apk反编译

    我们有时候在某个app上见到某个功能,某个效果蛮不错的,我们想看看对方的思路怎么走的,这时候,我们就可以通过反编译来编译该apk,拿到代码,进行分析。
    2021-06-06
  • 简单实现Android计算器功能

    简单实现Android计算器功能

    这篇文章主要为大家详细介绍了自己动手实现的Android计算器功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01

最新评论