- 今年刚从学校毕业,兴冲冲的踏入到程序员的行业,相比各种大神我大概是新嫩的不能再新嫩了.好了闲话不多说,上干货.极光的IM推出的时间非常的短暂,初次了解到极光还是极光的推送.因为是第一次接触到即时通讯,向好几个前辈请教了很多,磕磕绊绊看官方文档和demo,总算写了点东西出来.
//这个是创建最初的单聊的会话,因为实际情况我并不需要团队,如有需要可以另行创建
[JMSGConversation createSingleConversationWithUsername:self.userID completionHandler:^(id resultObject, NSError *error) {
if (error == nil) {
if ([resultObject isKindOfClass:[JMSGConversation class]]) {
chatVC *vc = [[chatVC alloc] initWithConversation:resultObject];
vc.userDict = self.resourceDict;
[self.navigationController pushViewController:vc animated:YES];
}
}
}];
- 之后就是非常常规的使用方法创建自己想要的发送的消息了.我这边粗略的就写上语音,文字,图片的三种.我记得极光并不支持的视频的发送.
关于这三种基本的信息聊天发送,基本上就这几个步骤:首先指定一个指针变量指向实例化对象, 即
JMSGTextContent *textContent = [[JMSGTextContent alloc] initWithText:textField.text];
然后数据的提取,赋值
messageModel *model = [[messageModel alloc] init];
//此接口创建消息后, SDK 会进行落地, 包括: 消息保存数据库, 媒体文件保存到文件系统.这意味着, 这个创建后的消息对象, App 可以用来放到 UI 上展示.相关具体详细的有兴趣可以去极光的官网上下载demo看下.
message = [_conversation createMessageWithContent:textContent];
//这里的sendMessage就是极光的接口方法了, 通过这个发送消息
[_conversation sendMessage:message];
[model setChatModelWith:message conversationType:_conversation];
最后添加到cell里面显示
[self addMessage:model];
具体的方法我比较的偷懒,关于文字的发送我直接写在了textField里面
#pragma - mark text field delegate
-(BOOL)textFieldShouldReturn:(UITextField *)textField{
NSLog(@"return");
if (textField.text.length == 0) {
return NO;
}
JMSGMessage *message = nil;
JMSGTextContent *textContent = [[JMSGTextContent alloc] initWithText:textField.text];
messageModel *model = [[messageModel alloc] init];
message = [_conversation createMessageWithContent:textContent];
[_conversation sendMessage:message];
[model setChatModelWith:message conversationType:_conversation];
[self addMessage:model];
model.isSelf = NO;
textField.text = nil;
return YES;
}
这样最基本的文字消息就发送出去了, 剩下的就是在cell里的显示布局,我写了一个最简单的排版,就当抛砖引玉了
if (_msg.message.contentType == kJMSGContentTypeText) {
msgabel.hidden = NO;
_voiceConent.hidden = YES;
_imageConent.hidden = YES;
[self dialog];
JMSGTextContent *textContent = (JMSGTextContent *)_msg.message.content;
msgabel.text = textContent.text;
[self textLayout];
}
- (void)textLayout {
//字体大小,文字多少,行数,分行模式
//图片的拉伸
backBg.image = [backBg.image stretchableImageWithLeftCapWidth:backBg.image.size.width * 0.5 topCapHeight:backBg.image.size.height * 0.7];
//设置段落样式
NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
style.lineBreakMode = NSLineBreakByWordWrapping;
// 根据内容动态获取高度 属性字符串,属性字典
CGRect rect3 = [msgabel.text boundingRectWithSize:CGSizeMake(WIDTH - 170 , MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{
NSFontAttributeName : [UIFont systemFontOfSize:14],
NSParagraphStyleAttributeName : style
} context:nil];
CGFloat fixWidth = MAX(rect3.size.width, 10);
//第一个是自己的,第二个是收到的消息
backBg.frame = !self.msg.isSelf ? CGRectMake((WIDTH - 65 - MIN(WIDTH - 140, rect3.size.width + 50)) + 20, 10, (MIN(WIDTH - 139, rect3.size.width + 50)) - 20, rect3.size.height + 20) : CGRectMake(65, 10, (MIN(WIDTH - 139, fixWidth + 20)) + 20, rect3.size.height + 20);
//第一个是自己发送的 第二个是收到消息的
msgabel.frame = !self.msg.isSelf ? CGRectMake(10, -3, backBg.frame.size.width - 20, backBg.frame.size.height) : CGRectMake(20, 0, backBg.frame.size.width - 15, backBg.frame.size.height) ;
[self heardView];
}
基本上相应的一些UI我相信不同公司都有不同的设计的,我就不多说了.因为创业公司,并没有相关的人员,关于视觉的设计我就兼职了 (实际效果果然是突出了简单粗暴几个字.反正该有的功能都有了,我的审美就这样了!!!!!)
- 语音和图片代码都是比较相似的,我就不放出来占版面了.这里我主要是想说下我遇到的一些需要注意的地方.
相机的调用,具体的情况就是你调用相机拍出来的照片照片发送出去就会旋转90°.网上有种说法是当照片大小超过2M就会旋转
image = [info objectForKey:UIImagePickerControllerOriginalImage];
当你写了这一句的时候,你就要计算相机用不同方式拍的照片,手动的把照片进行平移变换.非常遗憾的是我折腾了半天,并没有成功.
如果有大神可以为我解惑的话我感激不尽!!!!这个很关键
后来查了文档问了小伙伴,决定把png格式的图片换成JPEG格式来上传,用以规避照片的Original值.
剩下的也就语音播放了,注意取值正确应该没有什么大的问题.
- 因为第一次接触即时通讯,我也就搭建了这么个最基本的架子,缺的东西海了去了,正在慢慢补充回去.之后的有关即时通讯我会保持更新的~~~~让之后和我一样的新人们能有个方向.
谢谢