Jpush使用总结 _ 客户端定义通知栏样式

2024-02-24 05:48

本文主要是介绍Jpush使用总结 _ 客户端定义通知栏样式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载地址: http://www.tuicool.com/articles/vQR7Jf

http://www.itnpc.com/news/web/145577790442449.html 


 点击消息后,会跳转到一个Activity(此Activity需要在清单文件中注册过滤器  

  < activity   android:name = "com.example.jpushdemo.TestActivity"   >

             < intent-filter >

                 < action   android:name = "jpush.testAction"   />

                 < category   android:name = "jpush.testCategory"   />

             </ intent-filter >

         </ activity >

   )中,可以在此Activity中以获取传递Intent的方式获取到message的对象。并将其显示在Activity中。

     tv_title  = (TextView) findViewById(R.id. tv_title );

         tv_content  = (TextView) findViewById(R.id. content );

        Intent intent = getIntent();

         if  ( null  != intent) {

            Bundle bundle = getIntent().getExtras();

            String title = bundle.getString(JPushInterface. EXTRA_NOTIFICATION_TITLE );

            String content = bundle.getString(JPushInterface. EXTRA_ALERT );

             tv_title .setText(title);

             tv_content .setText(content);

        }

△ 一般来说如果不需要太多复杂内容的话,可以直接使用此种方式,将数据封装成一个Json,将其推送,客户端收到后将json解析出来并展现到前台即可。

此种方式有缺陷 ,极光中对推送通知中文本的大小有限制,为72个汉字(或144个其它类型字符)。传输信息有限。



/**

 * 自定义接收器

 * 如果不定义这个 Receiver,则:

 * 1) 默认用户会打开主界面

 * 2) 接收不到自定义消息

*/
public   class  MyReceiver  extends  BroadcastReceiver

消息只能在此Receiver中获取,不会显示成通知,或者其他。在 onReceive(Context context, Intent intent)中获取方式为

  if  (JPushInterface. ACTION_MESSAGE_RECEIVED .equals(intent.getAction())) {

                  Bundle bundle = intent.getExtras();   
            Log. d ( TAG ,  "[MyReceiver] 接收到推送下来的自定义消息: "  + bundle.getString(JPushInterface. EXTRA_MESSAGE ));

}

在此处也可获取推送通知中的内容

  else   if  (JPushInterface. ACTION_NOTIFICATION_RECEIVED .equals(intent.getAction())) {

            Log. d ( TAG ,  "[MyReceiver] 接收到推送下来的通知" );

             int  notifactionId = bundle.getInt(JPushInterface. EXTRA_NOTIFICATION_ID );

            Log. d ( TAG ,  "[MyReceiver] 接收到推送下来的通知的ID: "  + notifactionId);

                Log. i ( TAG , bundle.getString(JPushInterface. EXTRA_ALERT ));//此处获取到的文本就是通知的内容

此种方式明显比推送通知的方式好一点的是其发送的信息容量比较大,为 236 个汉字。    




自定义的通知栏样式,是在客户端进行的。请参考 通知栏样式定制API 来看所支持的功能。

自定义通知栏样式设计

在收到推送消息的那一瞬间,推送图标被截取。在极光论坛大多数人的答案是图片适配,既在不同的drawble文件夹放推送的icon,然,极光推送默认调用应用的launcher_icon,我的手机分辨率是1920*1080,调用drawable-xhdpi文件夹里面的launcher_icon,大小为144*144,而在drawable-xhdpi中的通知的图标大小为48*48才会显示全,所以出现被截取的现象是很正常不过。

    问题来了,既然极光默认调用应用的launcher_icon,难道我们要把应用的launcher_icon改为48*48吗?这样我们的应用图标在桌面上显示的肯定小,出现白边。问了极光的技术客服,不知道他们是没有懂我的意思还是上什么的,他们的答案依然是对图标做适配。呵呵,要把应用图标大小改为48*48?

    当然极光也提供了对应的解决方案,只是官方文档只说了在客户端如何,却没有说要在服务端做对应的设置




  • 有个 PushNotificationBuilder 概念,开发者使用 setPushNotificationBuilder 方法为某种类型的 PushNotificationBuilder 指定编号。

  • setPushNotificationBuilder 可以在 JPushInterface.init() 之后任何地方调用,可以是开发者应用的逻辑来触发调用,或者初始化时调用。

  • 只需要设置一次,JPush SDK 会记住这个设置。在下次收到推送通知时,就根据通知里指定的编号来找到 PushNotificationBuilder 来展现、执行。

API - setDefaultPushNotificationBuilder 设置默认

此 API 改变默认的编号为 0 的通知栏样式。

API - setPushNotificationBuilder 指定编号

此 API 为开发者指定的编号,设置一个自定义的 PushNotificationBuilder(通知样式构建器)。

Example - 基础的 PushNotificationBuilder

定制声音、震动、闪灯等 Notification 样式。

int builderId =1;

BasicPushNotificationBuilder builder = new BasicPushNotificationBuilder(MainActivity.this);
builder.statusBarDrawable = R.drawable.jpush_notification_icon;
builder.notificationFlags = Notification.FLAG_AUTO_CANCEL;  //设置为自动消失
builder.notificationDefaults = Notification.DEFAULT_SOUND | Notification.DEFAULT_VIBRATE | Notification.DEFAULT_LIGHTS;  // 设置为铃声与震动都要

JPushInterface.setPushNotificationBuilder(builderId , builder);


 客户端需设置消息的类型,即builderId ,当服务端发送对应的类型时,极光会先进行消息类型匹配,若匹配不上,则默认调用应用的图标,若匹配上,则调用客户端指定的图标builder.statusBarDrawable。


2、服务端配置,也是需要设置消息类型builderId,builderId 必须与客户端的一致 。我们使用java版sdk,其他语言的sdk也可以设置builderId 。

设置关键代码如下:

wKiom1bFQoOD-UyuAAKt8nceRf4988.jpg


附:


通知的图标大小

drawable-xhdpi 48*48

drawable-hdpi 36*36

drawable-mdpi 24*24







这篇关于Jpush使用总结 _ 客户端定义通知栏样式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/741124

相关文章

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有