====== 环信红包接入文档(iOS) ======= 新开商户可免费发送累计5000元总额的红包,超过5000元后,红包功能自动关闭,直到商户付费购买增值服务“红包功能”后,该功能重新开启,购买增值服务请咨询环信商务经理。 ===== 集成概述 ===== * 红包SDK分为两个版本,即**钱包版红包SDK**与**支付宝版红包SDK**。 * 使用钱包版红包SDK的用户,可以使用银行卡支付或支付宝支付等第三方支付来发红包;收到的红包金额会进入到钱包余额,并支持提现到绑定的银行卡。 * 使用支付宝版红包SDK的用户,发红包仅支持支付宝支付;收到的红包金额即时入账至绑定的支付宝账号 * 请选择希望接入的版本并下载对应的SDK进行集成,钱包版红包SDK与支付宝版红包SDK集成方式相同。 * 需要注意的是如果已经集成了钱包版红包SDK,暂不支持切换到支付宝版红包SDK(两个版本不支持互通)。 * [[https://github.com/YunzhanghuOpen/Redpacket-Demo-iOS|集成演示Demo]],开发者可以通过此Demo了解iOS红包SDK的集成,集成方式仅供参考。 ===== 红包开源模块 ===== {{:im:300iosclientintegration:ios_redpacket_open.jpeg|}} ==== 红包开源模块介绍 ==== ''RedpacketAliPay'' * 为**支付宝版SDK**处理支付宝授权和支付宝支付回调 ''RedpacketJDPay'' * 为**钱包版SDK**处理支付宝支付回调 ''RedpacketCell'' * 红包SDK内的红包卡片样式 ''RedpacketCellResource.bundle'' * 红包开源部分的资源文件 ''RedpacketChatViewController'' * 继承自''ChatViewController'' * 包含发红包收红包功能 * 单聊红包包含**小额随机红包**和**普通红包** * 群红包包含**定向红包**,**普通红包**和**拼手气红包** * 收红包可以接受各种红包类型包含**营销红包** ''RedpacketUserConfig'' 红包SDK初始化文件 * 实现红包SDK注册 * 实现当前用户获取 * 实现红包SDK初始化和红包IM消息和透传消息处理 ===== Cocoapods支持 ===== 环信Demo分为2个Target\\ {{:im:300iosclientintegration:ios_redpacket_targets.jpeg|}} ''ChatDemo-UI3.0'' 默认支持支付宝版红包SDK ''ChatDemo-UI3.0-JDPay'' 支持钱包版SDK 修改''Podfile''支持两个红包SDK版本 target 'ChatDemo-UI3.0' do ... ... pod 'RedpacketAliAuthLib' # 支付宝版红包SDK end target 'ChatDemo-UI3.0-JDPay' do ... ... pod 'RedpacketLib' # 钱包版红包SDK end ===== 红包功能开关 ===== 在''ChatDemo-UI3.0-Prefix.pch''文件中有如下宏定义, 注销掉此宏定义则可以关闭红包功能。 #define REDPACKET_AVALABLE ===== 集成准备 ===== ==== 导入SDK ==== === 导入开源模块 === 请在环信Demo中获取''RedpacketSDK''开源部分 在工程中导入''RedpacketSDK''开源模块 === 通过Pod更新红包SDK === 修改Podfile,如果是支付宝版SDK则加入**pod 'RedpacketAliAuthLib'** 如果是钱包版SDK则加入**pod 'RedpacketLib'** ==== 通过环信APPKey配置商户信息 ==== 修改文件''Appdelegate.m'' - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions ... ... #ifdef REDPACKET_AVALABLE /** * TODO: 通过环信的AppKey注册红包 */ [[RedPacketUserConfig sharedConfig] configWithAppKey:EaseMobAppKey]; #endif ... ... ===== 聊天页面实现发红包 ===== 用带有收发红包功能的''RedPacketChatViewController''替换EaseUI的''ChatViewController'' ===== 零钱页(钱包版SDK)或者红包记录页(支付宝版SDK)===== 支付宝版为红包记录 钱包版为零钱页 在''SettingsViewController.m''中增加此功能 - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath { ... ... #ifdef REDPACKET_AVALABLE if (indexPath.section == 0) { cell.textLabel.text = @"零钱"; #ifdef AliAuthPay cell.textLabel.text = @"红包记录"; #endif }else if (indexPath.section == 1) { #else if (indexPath.section == 0) { #endif ... ... } - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { [tableView deselectRowAtIndexPath:indexPath animated:YES]; #ifdef REDPACKET_AVALABLE if (indexPath.section == 0) { /** 如果是钱包版SDK则是零钱页,如果是支付宝版SDK则是红包记录页*/ [RedpacketViewControl presentChangePocketViewControllerFromeController:self]; return; } #endif ... ... ==== 消息处理 ==== 修改文件''ChatDemoHelper.m'' === 监听消息 === - (void)initHelper { #ifdef REDPACKET_AVALABLE [[RedPacketUserConfig sharedConfig] beginObserveMessage]; #endif ... ... } === 屏闭红包被抢消息的通知 === #ifdef REDPACKET_AVALABLE /** * 屏蔽红包被抢消息的提示 */ NSDictionary *dict = message.ext; needShowNotification = (dict && [dict valueForKey:RedpacketKeyRedpacketTakenMessageSign]) ? NO : needShowNotification; #endif ---- 上一页:[[im:300iosclientintegration:73privatecloud|私有云SDK集成配置]] 下一页:[[im:300iosclientintegration:apns|APNs推送]]