jpush-phonegap-plugin/doc/Android_detail_api.md

188 lines
6.1 KiB
Markdown
Raw Normal View History

2017-04-13 13:50:26 +08:00
# Android API 简介
2016-04-21 20:32:28 +08:00
- [清除通知](#清除通知)
- [设置允许推送时间](#设置允许推送时间)
- [设置通知静默时间](#设置通知静默时间)
- [通知栏样式定制](#通知栏样式定制)
- [设置保留最近通知条数](#设置保留最近通知条数)
- [本地通知](#本地通知)
2017-04-13 13:50:26 +08:00
## 获取集成日志(同时适用于 iOS
2016-04-21 20:32:28 +08:00
### API - setDebugMode
2015-04-14 09:58:44 +08:00
用于开启调试模式,可以查看集成 JPush 过程中的 Log如果集成失败可方便定位问题所在。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.setDebugMode(mode)
```
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 参数说明
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
- mode:
2017-09-22 21:15:37 +08:00
- true 显示集成日志。
- false 不显示集成日志。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
### API - reportNotificationOpened
2015-04-14 09:58:44 +08:00
用于上报用户的通知栏被打开,或者用于上报用户自定义消息被展示等客户端需要统计的事件。
2016-04-21 20:32:28 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.reportNotificationOpened(msgID)
```
2016-03-11 11:19:42 +08:00
2016-04-21 20:32:28 +08:00
#### 参数说明
- msgID: 收到的通知或者自定义消息的 id。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
## 清除通知
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
### API - clearAllNotification
2015-04-14 09:58:44 +08:00
推送通知到客户端时,由 JPush SDK 展现通知到通知栏上。
此 API 提供清除通知的功能,包括:清除所有 JPush 展现的通知(不包括非 JPush SDK 展现的)。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.clearAllNotification()
```
2015-04-14 09:58:44 +08:00
### API - clearNotificationById
根据通知 Id 清除通知(包括本地通知)。
#### 接口定义
2017-09-22 21:15:37 +08:00
```js
window.JPush.clearNotificationById(notificationId)
```
#### 参数说明
- notificationIdint通知的 id。
#### 代码示例
2017-09-22 21:15:37 +08:00
```js
window.JPush.clearNotificationById(1)
```
2016-04-21 20:32:28 +08:00
## 设置允许推送时间
### API - setPushTime
2017-09-22 21:15:37 +08:00
默认情况下用户在任何时间都允许推送。即任何时候有推送下来,客户端都会收到,并展示。
开发者可以调用此 API 来设置允许推送的时间。
如果不在该时间段内收到消息,当前的行为是:推送到的通知会被扔掉。
2016-04-21 20:32:28 +08:00
#### 接口定义
2017-09-22 21:15:37 +08:00
```js
window.JPush.setPushTime(days, startHour, endHour)
```
2016-04-21 20:32:28 +08:00
#### 参数说明
2017-09-22 21:15:37 +08:00
2016-04-21 20:32:28 +08:00
- days: 数组0 表示星期天1 表示星期一以此类推7天制数组中值的范围为 0 到 6 )。
2017-10-19 13:51:19 +08:00
数组的值为 null, 表示任何时间都可以收到消息和通知,数组的 size 为 0则表示任何时间都收不到消息和通知。
2016-04-21 20:32:28 +08:00
- startHour: 整形,允许推送的开始时间 24 小时制startHour 的范围为 0 到 23
- endHour: 整形,允许推送的结束时间 24 小时制endHour 的范围为 0 到 23
2016-04-21 20:32:28 +08:00
## 设置通知静默时间
2016-04-21 20:32:28 +08:00
### API - setSilenceTime
默认情况下用户在收到推送通知时,客户端可能会有震动,响铃等提示。
但用户在睡觉、开会等时间点希望为 "免打扰" 模式,也是静音时段的概念。
开发者可以调用此 API 来设置静音时段。如果在该时间段内收到消息,则:不会有铃声和震动。
2016-04-21 20:32:28 +08:00
#### 接口定义
2017-09-22 21:15:37 +08:00
```js
window.JPush.setSilenceTime(startHour, startMinute, endHour, endMinute)
```
2016-04-21 20:32:28 +08:00
#### 参数说明
2016-04-21 20:32:28 +08:00
- startHour: 整形,静音时段的开始时间 - 小时 24小时制范围0~23 )。
- startMinute: 整形,静音时段的开始时间 - 分钟范围0~59 )。
- endHour: 整形,静音时段的结束时间 - 小时 24小时制范围0~23 )。
- endMinute: 整形,静音时段的结束时间 - 分钟范围0~59 )。
2016-04-21 20:32:28 +08:00
## 通知栏样式定制
2017-09-25 12:32:27 +08:00
目前 REST API 与极光控制台均已支持「大文本通知栏样」、「文本条目通知栏样式」和「大图片通知栏样式」。可直接推送对应样式
的通知。
此外也能够通过设置 Notification 的 flag 来控制通知提醒方式,具体用法可参考 [后台 REST API](https://docs.jiguang.cn/jpush/server/push/rest_api_v3_push/#notification)。
2016-04-21 20:32:28 +08:00
### API - setBasicPushNotificationBuilder, setCustomPushNotificationBuilder
2015-04-14 09:58:44 +08:00
当用户需要定制默认的通知栏样式时,则可调用此方法。
需要用户去自定义 ../JPushPlugin.java 中的同名方法代码,然后再在 js 端 调用该方法。
2016-09-26 12:34:59 +08:00
具体用法可参考[官方文档](http://docs.jiguang.cn/jpush/client/Android/android_api/#api_6)。
2016-04-21 20:32:28 +08:00
JPush SDK 提供了 2 个用于定制通知栏样式的构建类:
2015-04-14 09:58:44 +08:00
- setBasicPushNotificationBuilder:
Basic 用于定制 Android Notification 里的 defaults / flags / icon 等基础样式(行为)。
- setCustomPushNotificationBuilder:
继承 Basic 进一步让开发者定制 Notification Layout。
2016-03-11 11:19:42 +08:00
如果不调用此方法定制,则极光 Push SDK 默认的通知栏样式是 Android 标准的通知栏。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.setBasicPushNotificationBuilder()
window.JPush.setCustomPushNotificationBuilder()
```
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
## 设置保留最近通知条数
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
### API - setLatestNotificationNum
2015-04-14 09:58:44 +08:00
通过极光推送,推送了很多通知到客户端时,如果用户不去处理,就会有很多保留在那里。
2016-04-21 20:32:28 +08:00
默认为保留最近 5 条通知,开发者可通过调用此 API 来定义为不同的数量。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.setLatestNotificationNum(num)
```
2016-03-11 11:19:42 +08:00
2016-04-21 20:32:28 +08:00
#### 参数说明
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
- num: 保存的条数。
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
## 本地通知
### API - addLocalNotification, removeLocalNotification, clearLocalNotifications
本地通知 API 不依赖于网络,无网条件下依旧可以触发。
2015-04-14 09:58:44 +08:00
本地通知与网络推送的通知是相互独立的,不受保留最近通知条数上限的限制。
2015-04-14 09:58:44 +08:00
本地通知的定时时间是自发送时算起的,不受中间关机等操作的影响。
2015-04-14 09:58:44 +08:00
三个接口的功能分别为:添加一个本地通知,清除一个本地通知,清除所有的本地通知。
2015-04-14 09:58:44 +08:00
#### 接口定义
2015-04-14 09:58:44 +08:00
2017-09-22 21:15:37 +08:00
```js
window.JPush.addLocalNotification(builderId, content, title, notificationID, broadcastTime, extras)
window.JPush.removeLocalNotification(notificationID)
window.JPush.clearLocalNotifications() // 同时适用于 iOS
```
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
#### 参数说明
2015-04-14 09:58:44 +08:00
2016-04-21 20:32:28 +08:00
- builderId: 设置本地通知样式。
- content: 设置本地通知的 content。
- title: 设置本地通知的 title。
2017-09-22 21:15:37 +08:00
- notificationID: 设置本地通知的 ID不要为 0
2016-04-21 20:32:28 +08:00
- broadcastTime: 设置本地通知触发时间,为距离当前时间的数值,单位是毫秒。
2017-09-22 21:15:37 +08:00
- extras: 设置额外的数据信息 extras 为 json 字符串。