IMSDK
即时通信 IM 提供全球接入、单聊、群聊、消息推送、资料关系链托管、账号鉴权等全方位解决方案,并提供完备的 App 接入、后台管理接口。
V2TIMOfflinePushInfo

Public 成员函数

 V2TIMOfflinePushInfo ()
 
String getTitle ()
 
void setTitle (String title)
 
String getDesc ()
 
void setDesc (String description)
 
void setExt (byte[] ext)
 
byte [] getExt ()
 
void disablePush (boolean disable)
 
boolean isDisablePush ()
 
void setIOSSound (String sound)
 
void setAndroidSound (String sound)
 
String getAndroidSound ()
 
void setIgnoreIOSBadge (boolean ignoreIOSBadge)
 
void setIOSPushType (int iosPushType)
 
void setIOSInterruptionLevel (String level)
 
void enableIOSBackgroundNotification (boolean enable)
 
void setAndroidOPPOChannelID (String channelID)
 
void setAndroidFCMChannelID (String channelID)
 
void setAndroidXiaoMiChannelID (String channelID)
 
void setAndroidVIVOClassification (int classification)
 
void setAndroidVIVOCategory (String category)
 
void setAndroidHuaWeiCategory (String category)
 
void setAndroidOPPOCategory (String category)
 
void setAndroidOPPONotifyLevel (int level)
 
void setAndroidHonorImportance (String importance)
 
void setAndroidHuaWeiImage (String imageUrl)
 
void setAndroidHonorImage (String imageUrl)
 
void setAndroidFCMImage (String imageUrl)
 
void setIOSImage (String imageUrl)
 
void setHarmonyImage (String imageUrl)
 
void setHarmonyCategory (String category)
 
void setIgnoreHarmonyBadge (boolean ignoreHarmonyBadge)
 

静态 Public 属性

static final String IOS_OFFLINE_PUSH_NO_SOUND = "push.no_sound"
 
static final String IOS_OFFLINE_PUSH_DEFAULT_SOUND = "default"
 
static final int IOS_OFFLINE_PUSH_TYPE_APNS = 0
 
static final int IOS_OFFLINE_PUSH_TYPE_VOIP = 1
 

构造及析构函数说明

◆ V2TIMOfflinePushInfo()

成员函数说明

◆ getTitle()

String getTitle ( )
inline

获取离线推送通知标题

返回
通知标题

◆ setTitle()

void setTitle ( String  title)
inline

设置离线推送展示标题。

参数
title通知栏标题

◆ getDesc()

String getDesc ( )
inline

获取离线推送通知内容

返回
通知内容

◆ setDesc()

void setDesc ( String  description)
inline

设置离线推送展示内容。

注意
自定义消息进行离线推送,必须设置此字段内容
参数
description通知栏内容

◆ setExt()

void setExt ( byte []  ext)
inline

设置离线推送透传的扩展字段。

参数
ext通知栏透传信息

◆ getExt()

byte [] getExt ( )
inline

获取离线推送透传的扩展字段。

◆ disablePush()

void disablePush ( boolean  disable)
inline

是否关闭推送(默认开启推送)。

参数
disabletrue:关闭;false:打开

◆ isDisablePush()

boolean isDisablePush ( )
inline

获取是否关闭离线推送状态。

返回
关闭状态。true:关闭;false:打开

◆ setIOSSound()

void setIOSSound ( String  sound)
inline

离线推送声音设置(仅对 iOS 生效)。 当 sound = IOS_OFFLINE_PUSH_NO_SOUND,表示接收时不会播放声音。 当 sound = IOS_OFFLINE_PUSH_DEFAULT_SOUND,表示接收时播放系统声音。 如果要自定义 iOSSound,需要先把语音文件链接进 Xcode 工程,然后把语音文件名(带后缀)设置给 iOSSound。

参数
soundiOS 声音路径

◆ setAndroidSound()

void setAndroidSound ( String  sound)
inline

离线推送声音设置(仅对 Android 生效, IMSDK 6.1 及以上版本支持)。 只有华为和谷歌手机支持设置声音提示,小米手机设置声音提示,请您参照:https://dev.mi.com/console/doc/detail?pId=1278%23_3_0 另外,谷歌手机 FCM 推送在 Android 8.0 及以上系统设置声音提示,必须调用 setAndroidFCMChannelID 设置好 channelID,才能生效。

参数
soundAndroid 工程里 raw 目录中的铃声文件名,不需要后缀名。

◆ getAndroidSound()

String getAndroidSound ( )
inline

获取离线推送 Android 声音设置

◆ setIgnoreIOSBadge()

void setIgnoreIOSBadge ( boolean  ignoreIOSBadge)
inline

离线推送忽略 badge 计数(仅对 iOS 生效), 如果设置为 true,在 iOS 接收端,这条消息不会使 APP 的应用图标未读计数增加。

参数
ignoreIOSBadgeiOS 应用图标未读计数状态。true:忽略;false:开启

◆ setIOSPushType()

void setIOSPushType ( int  iosPushType)
inline

iOS 离线推送的类型(仅对 iOS 生效)

参数
iosPushTypeIOS_OFFLINE_PUSH_TYPE_APNS:普通的 APNs 推送; IOS_OFFLINE_PUSH_TYPE_VOIP:VoIP 推送,默认取值为 IOS_OFFLINE_PUSH_TYPE_APNS

◆ setIOSInterruptionLevel()

void setIOSInterruptionLevel ( String  level)
inline

iOS 离线推送的通知级别 (iOS 15 及以上支持)

参数
level通知级别 "passive",不会发出声音、振动或横幅提示,只会静默地出现在通知中心。适用于不紧急的信息,例如应用内的社交活动更新或推荐内容。 "active", 会发出声音或振动,并显示横幅提示。适用于一般的重要通知,例如消息提醒、日历事件等。(默认类型) "time-sensitive",会发出声音或振动,并显示横幅提示,这种级别的通知会打扰用户,即使用户启用了“专注模式”(Focus Mode)。适用于需要用户立即关注的紧急通知,例如安全警报、重要的时间提醒等。打开需要在苹果开发者平台和 xcode 项目中增加相应的配置。 "critical", 会发出声音或振动,并显示横幅提示。这种级别的通知会打扰用户,即使设备处于静音模式。适用于极其重要的紧急通知,例如公共安全警报、严重的健康警告等。打开需要向 Apple 特殊申请。

◆ enableIOSBackgroundNotification()

void enableIOSBackgroundNotification ( boolean  enable)
inline

设置 iOS 后台透传消息(仅对 iOS 生效)

注意
设置打开后,离线接收会唤起应用并透传消息内容 ext

◆ setAndroidOPPOChannelID()

void setAndroidOPPOChannelID ( String  channelID)
inline

离线推送设置 OPPO 手机 8.0 系统及以上的渠道 ID。

参数
channelIDOPPO 手机的渠道 ID

◆ setAndroidFCMChannelID()

void setAndroidFCMChannelID ( String  channelID)
inline

离线推送设置 FCM 通道手机 8.0 系统及以上的渠道 ID。

参数
channelIDFCM 推送的渠道 ID

◆ setAndroidXiaoMiChannelID()

void setAndroidXiaoMiChannelID ( String  channelID)
inline

离线推送设置小米手机 8.0 系统及以上的渠道 ID。

参数
channelID小米推送的渠道 ID

◆ setAndroidVIVOClassification()

void setAndroidVIVOClassification ( int  classification)
inline

离线推送设置 VIVO 推送消息分类 (待废弃接口,VIVO 推送服务于 2023 年 4 月 3 日优化消息分类规则,推荐使用 setAndroidVIVOCategory 设置消息类别)

参数
classificationVIVO 手机离线推送消息分类,0:运营消息 1:系统消息,默认取值为 1

◆ setAndroidVIVOCategory()

void setAndroidVIVOCategory ( String  category)
inline

离线推送设置 VIVO 推送消息类别,详见:https://dev.vivo.com.cn/documentCenter/doc/359。(VIVO 推送服务于 2023 年 4 月 3 日优化消息分类规则,推荐使用 setAndroidVIVOCategory 设置消息类别,不需要再关注和设置 setAndroidVIVOClassification)

参数
categoryvivo 推送消息类别

◆ setAndroidHuaWeiCategory()

void setAndroidHuaWeiCategory ( String  category)
inline

离线推送设置华为推送消息分类,详见:https://developer.huawei.com/consumer/cn/doc/development/HMSCore-Guides/message-classification-0000001149358835

参数
category华为推送消息分类

◆ setAndroidOPPOCategory()

void setAndroidOPPOCategory ( String  category)
inline

离线推送设置 OPPO 推送消息分类,详见:https://open.oppomobile.com/new/developmentDoc/info?id=13189

参数
categoryOPPO 推送消息分类 1、通讯与服务类型有:"IM","ACCOUNT"等 2、内容与营销类型有:"NEWS","CONTENT"等

◆ setAndroidOPPONotifyLevel()

void setAndroidOPPONotifyLevel ( int  level)
inline

离线推送设置 OPPO 推送通知栏消息提醒等级,详见:https://open.oppomobile.com/new/developmentDoc/info?id=13189

注意
使用生效前,需要先 setAndroidOPPOCategory 指定 category 为 IM 类消息
参数
levelOPPO 通知栏消息提醒等级 1 通知栏 2 通知栏 + 锁屏 (默认) 16 通知栏 + 锁屏 + 横幅 + 震动 + 铃声

◆ setAndroidHonorImportance()

void setAndroidHonorImportance ( String  importance)
inline

离线推送设置 Honor 推送消息分类,详见:https://developer.honor.com/cn/docs/11002/guides/notification-class

参数
importanceHonor 推送消息分类 "NORMAL", 表示消息为服务通讯类 "LOW", 表示消息为资讯营销类

◆ setAndroidHuaWeiImage()

void setAndroidHuaWeiImage ( String  imageUrl)
inline

设置华为设备离线推送的通知图片

参数
imageUrl使用的协议必须是 HTTPS 协议,取值样例:https://example.com/image.png
注意
说明: 图片文件须小于 512KB,规格建议为 40dp x 40dp,弧角大小为 8dp。超出建议规格的图片会存在图片压缩或图片显示不全的情况。图片格式建议使用 JPG/JPEG/PNG。

◆ setAndroidHonorImage()

void setAndroidHonorImage ( String  imageUrl)
inline

设置荣耀设备离线推送的通知图片

参数
imageUrl使用的协议必须是 HTTPS 协议,取值样例:https://example.com/image.png
注意
说明: 图标文件大小须小于 100KB,图标建议规格大小:160px x 160px,弧角大小为 32px,超出规格大小的图标会存在图片压缩或显示不全的情况。

◆ setAndroidFCMImage()

void setAndroidFCMImage ( String  imageUrl)
inline

设置 Google FCM 设备离线推送的通知图片,未展开消息时显示为大图标,展开消息后展示为大图片

参数
imageUrl使用的协议必须是 HTTPS 协议,取值样例:https://example.com/image.png
注意
说明: 图标文件大小须小于 1 MB,超出规格大小的图标会存在图片压缩或显示不全的情况。

◆ setIOSImage()

void setIOSImage ( String  imageUrl)
inline

设置 APNs 离线推送的通知图片, 借助 iOS 10 Service Extension 特性,可以下载并展示在弹窗上

参数
imageUrl使用的协议必须是 HTTPS 协议,取值样例:https://example.com/image.png
注意
限制说明: 支持 JPEG、GIF、PNG,大小不超过 10 MB
使用说明:
  • 需要在 IM 控制台打开 mutable-content 属性,支持 iOS 10 Service Extension 特性
  • 获取 imageUrl 资源的 key 值是 "image"

◆ setHarmonyImage()

void setHarmonyImage ( String  imageUrl)
inline

设置鸿蒙设备离线推送的通知图片

参数
imageUrl使用的协议必须是HTTPS协议,取值样例:https://example.com/image.png。
注意
说明: 支持图片格式为png、jpg、jpeg、heif、gif、bmp,图片长*宽 < 25000像素

◆ setHarmonyCategory()

void setHarmonyCategory ( String  category)
inline

设置鸿蒙设备离线推送通知消息类别,详见:https://developer.huawei.com/consumer/cn/doc/HMSCore-Guides/message-classification-0000001149358835

参数
category鸿蒙推送消息分类

◆ setIgnoreHarmonyBadge()

void setIgnoreHarmonyBadge ( boolean  ignoreHarmonyBadge)
inline

离线推送忽略 badge 计数(仅对 Harmony 生效), 如果设置为 true,在 Harmony 接收端,这条消息不会使 APP 的应用图标未读计数增加。

参数
ignoreHarmonyBadgeHarmony 应用图标未读计数状态。true:忽略;false:开启

结构体成员变量说明

◆ IOS_OFFLINE_PUSH_NO_SOUND

final String IOS_OFFLINE_PUSH_NO_SOUND = "push.no_sound"
static

◆ IOS_OFFLINE_PUSH_DEFAULT_SOUND

final String IOS_OFFLINE_PUSH_DEFAULT_SOUND = "default"
static

◆ IOS_OFFLINE_PUSH_TYPE_APNS

final int IOS_OFFLINE_PUSH_TYPE_APNS = 0
static

◆ IOS_OFFLINE_PUSH_TYPE_VOIP

final int IOS_OFFLINE_PUSH_TYPE_VOIP = 1
static