简单的环信单聊(用于商城聊天)

简介: 简单的环信单聊(用于商城聊天)

这里的集成是带语音的


1.导入我整理过JoanKing环信整理文件 密码: 29m8
2.在pch文件导入

#ifdef __OBJC__
  /**
   *   环信的设置
   */
  #import "EMSDKFull.h"
  #import "EaseUI.h"
  #import "ChatViewController.h"
  #endif
3.导入库


1.SDK 包含实时语音依赖库有:

CoreMedia.framework
 AudioToolbox.framework
 AVFoundation.framework
 MobileCoreServices.framework
 ImageIO.framework
 libc++.dylib
 libz.dylib
 libstdc++.6.0.9.dylib
 libsqlite3.dylib
 libiconv.dylib

(如果使用的是 xcode7,后缀为 tbd。)


第 2 步:SDK 不支持 bitcode,设置:Xcodeproj->Build Settings->Enable Bitcode 设置为 NO。


image.png


4.代码配置



  • 1.先说AppDelegate.m里面


/*
   环信
 */
#import "EMSDK.h"
  • 下面的两个变量你们需要注册环信的开发者平台账号,再创建应用来获取
    appkey:@"注册相应应用的APPkey"


apnsCertName:@"推送证书的名字"

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
//AppKey:注册的AppKey,详细见下面注释。
//apnsCertName:推送证书名(不需要加后缀),详细见下面注释。
EMOptions *options = [EMOptions optionsWithAppkey:@"注册相应应用的APPkey"];
options.apnsCertName = @"推送证书的名字";
[[EMClient sharedClient] initializeSDKWithOptions:options];
//设置回调监听代理(设置自动登录之后才能在退出后台进行获取聊天的列表)
[[EMClient sharedClient] addDelegate:self delegateQueue:nil];
BOOL isAutoLogin = [EMClient sharedClient].options.isAutoLogin;
if (isAutoLogin) {
    NSLog(@"123==重新登录成功");
}
/*
 EaseUI的使用
 */
[[EaseSDKHelper shareHelper] hyphenateApplication:application
                    didFinishLaunchingWithOptions:launchOptions
                                           appkey:@"注册相应应用的APPkey"
                                     apnsCertName:@"推送证书的名字"
                                      otherConfig:@{kSDKConfigEnableConsoleLogger:[NSNumber numberWithBool:YES]}];
//代码注册离线推送
//iOS8 注册APNS
if ([application respondsToSelector:@selector(registerForRemoteNotifications)]) {
    [application registerForRemoteNotifications];
    UIUserNotificationType notificationTypes = UIUserNotificationTypeBadge |
    UIUserNotificationTypeSound |
    UIUserNotificationTypeAlert;
    UIUserNotificationSettings *settings = [UIUserNotificationSettings settingsForTypes:notificationTypes categories:nil];
    [application registerUserNotificationSettings:settings];
}
else{
    UIRemoteNotificationType notificationTypes = UIRemoteNotificationTypeBadge |
    UIRemoteNotificationTypeSound |
    UIRemoteNotificationTypeAlert;
    [[UIApplication sharedApplication] registerForRemoteNotificationTypes:notificationTypes];
}
   /*
    *  推送的方法: - (void)didReceiveMessages:(NSArray *)aMessages{}
    */
}
// 将得到的deviceToken传给SDK
- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken {
   /**
    *  环信的离线推送
    */
    [[EMClient sharedClient] bindDeviceToken:deviceToken];
}
// APP进入后台
 - (void)applicationDidEnterBackground:(UIApplication *)application
{
    [[EMClient sharedClient] applicationDidEnterBackground:application];
}
// APP将要从后台返回
- (void)applicationWillEnterForeground:(UIApplication *)application
{
   [[EMClient sharedClient] applicationWillEnterForeground:application];
}
  • 2.注册方法

EMError *error = [[EMClient sharedClient] registerWithUsername:@"注册的账号" password:@"注册的秘密"];
    if (error==nil)
    {
          NSLog(@"注册成功");
    }
  • 3.登陆
/**
  *   环信登陆成功才算成功
  */
 EMError *error = [[EMClient sharedClient] loginWithUsername:myId password:@"dft"];
 if (!error)
 {
      NSLog(@"登录成功);
      //设置自动登录
      [[EMClient sharedClient].options setIsAutoLogin:YES];
      // 成功后跳转页面
   }
  • 4.与指定用户进行聊天
导入#import "ChatViewController.h"
#pragma mark  与个人的聊天
-(void)clicKPerson
{
     NSString *zy_id = @"62"; //以用户名字来进行聊天
   /*
    *  设置商家的单聊模式
    */
  ChatViewController *chatViewController = [[ChatViewController alloc]initWithConversationChatter:zy_id conversationType:EMConversationTypeChat];
  chatViewController.title =zy_id;
   [self.navigationController pushViewController:chatViewController animated:YES];
}

5.获取聊天列表(跳转进入)

#pragma mark  聊天列表的转入
-(void)clicKchat{
  EaseConversationListViewController *easeConversationListViewController = [EaseConversationListViewController new];
  [self.navigationController pushViewController:easeConversationListViewController animated:YES];
 }

到这里你就完成一个聊天的流程以及推送的功能


5.在此我再加一个用户用其他手机登陆的提示按钮(下次在写),记得点喜欢哦!!!

目录
相关文章
|
消息中间件 NoSQL API
环信实现聊天功能
环信实现聊天功能
95 0
|
5月前
|
开发工具
抖音sdk接口,抖音粉丝或好友收发消息
抖音sdk接口,抖音粉丝或好友收发消息
|
5月前
|
API
企业微信api接口调用-企业微信好友收发消息
企业微信api接口调用-企业微信好友收发消息
|
Java API 开发工具
极光:手机APP消息推送平台
简单来说:极光推送是一个免费的开源的手机APP消息推送平台(类似帅哥美女们常用的购物APP某宝、某东等,一些优惠券消息后台推送到你们手机上)。
841 0
极光:手机APP消息推送平台
|
API C#
C# 企业微信消息推送对接
C# 企业微信消息推送对接
987 0
C# 企业微信消息推送对接
微信 - 微信语音转发好友 / 朋友圈方法
微信 - 微信语音转发好友 / 朋友圈方法
223 0
微信 - 微信语音转发好友 / 朋友圈方法
|
Android开发 iOS开发
粉丝福利 | 秒 get 支付宝同款扫码组件
源自支付宝的扫码组件,全网免费接入
3343 0
粉丝福利 | 秒 get 支付宝同款扫码组件
|
机器学习/深度学习 自然语言处理 算法
天猫精灵如何和我们聊天?
天猫精灵已经走过几年的历史,在这几年中,天猫精灵变得更加智能,其中的体现之一是交互方式变得越来越自然。本文将介绍天猫精灵的全双工自然对话交互方式。
2472 0
天猫精灵如何和我们聊天?