前两篇介绍了如何通过XMPP来发送消息和接收消息,这一篇我们主要介绍如何来美化我们的聊天程序,看一下最终效果呢,当然源程序也会在最后放出

好了,我们来看一下我们写的程序

这里我们自定义了TableViewCell

一行是显示发布日期,一行是显示发送的消息,还有一个是背景

[java] view plaincopy
  1. -(id)initWithStyle:(UITableViewCellStyle)style reuseIdentifier:(NSString *)reuseIdentifier{
  2. self = [super initWithStyle:style reuseIdentifier:reuseIdentifier];
  3. if (self) {
  4. //日期标签
  5. senderAndTimeLabel = [[UILabel alloc] initWithFrame:CGRectMake(10, 5, 300, 20)];
  6. //居中显示
  7. senderAndTimeLabel.textAlignment = UITextAlignmentCenter;
  8. senderAndTimeLabel.font = [UIFont systemFontOfSize:11.0];
  9. //文字颜色
  10. senderAndTimeLabel.textColor = [UIColor lightGrayColor];
  11. [self.contentView addSubview:senderAndTimeLabel];
  12. //背景图
  13. bgImageView = [[UIImageView alloc] initWithFrame:CGRectZero];
  14. [self.contentView addSubview:bgImageView];
  15. //聊天信息
  16. messageContentView = [[UITextView alloc] init];
  17. messageContentView.backgroundColor = [UIColor clearColor];
  18. //不可编辑
  19. messageContentView.editable = NO;
  20. messageContentView.scrollEnabled = NO;
  21. [messageContentView sizeToFit];
  22. [self.contentView addSubview:messageContentView];
  23. }
  24. return self;
  25. }

定义好,在UITableViewCell中将Cell改成我们自己定义的Cell

[java] view plaincopy
  1. -(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
  2. static NSString *identifier = @"msgCell";
  3. KKMessageCell *cell =(KKMessageCell *)[tableView dequeueReusableCellWithIdentifier:identifier];
  4. if (cell == nil) {
  5. cell = [[KKMessageCell alloc] initWithStyle:UITableViewCellStyleValue1 reuseIdentifier:identifier];
  6. }
  7. NSMutableDictionary *dict = [messages objectAtIndex:indexPath.row];
  8. //发送者
  9. NSString *sender = [dict objectForKey:@"sender"];
  10. //消息
  11. NSString *message = [dict objectForKey:@"msg"];
  12. //时间
  13. NSString *time = [dict objectForKey:@"time"];
  14. CGSize textSize = {260.0 ,10000.0};
  15. CGSize size = [message sizeWithFont:[UIFont boldSystemFontOfSize:13] constrainedToSize:textSize lineBreakMode:UILineBreakModeWordWrap];
  16. size.width +=(padding/2);
  17. cell.messageContentView.text = message;
  18. cell.accessoryType = UITableViewCellAccessoryNone;
  19. cell.userInteractionEnabled = NO;
  20. UIImage *bgImage = nil;
  21. //发送消息
  22. if ([sender isEqualToString:@"you"]) {
  23. //背景图
  24. bgImage = [[UIImage imageNamed:@"BlueBubble2.png"] stretchableImageWithLeftCapWidth:20 topCapHeight:15];
  25. [cell.messageContentView setFrame:CGRectMake(padding, padding*2, size.width, size.height)];
  26. [cell.bgImageView setFrame:CGRectMake(cell.messageContentView.frame.origin.x - padding/2, cell.messageContentView.frame.origin.y - padding/2, size.width + padding, size.height + padding)];
  27. }else {
  28. bgImage = [[UIImage imageNamed:@"GreenBubble2.png"] stretchableImageWithLeftCapWidth:14 topCapHeight:15];
  29. [cell.messageContentView setFrame:CGRectMake(320-size.width - padding, padding*2, size.width, size.height)];
  30. [cell.bgImageView setFrame:CGRectMake(cell.messageContentView.frame.origin.x - padding/2, cell.messageContentView.frame.origin.y - padding/2, size.width + padding, size.height + padding)];
  31. }
  32. cell.bgImageView.image = bgImage;
  33. cell.senderAndTimeLabel.text = [NSString stringWithFormat:@"%@ %@", sender, time];
  34. return cell;
  35. }

在这个Cell里设置了发送的消息的背景图和接收消息的背景图

这里在字典里有一个"time"

这是我们接收和发送消息的时间

[java] view plaincopy
  1. +(NSString *)getCurrentTime{
  2. NSDate *nowUTC = [NSDate date];
  3. NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];
  4. [dateFormatter setTimeZone:[NSTimeZone localTimeZone]];
  5. [dateFormatter setDateStyle:NSDateFormatterMediumStyle];
  6. [dateFormatter setTimeStyle:NSDateFormatterMediumStyle];
  7. return [dateFormatter stringFromDate:nowUTC];
  8. }

在AppDelegate.m中

将我们收到消息的内容也做一下调整

[java] view plaincopy
  1. - (void)xmppStream:(XMPPStream *)sender didReceiveMessage:(XMPPMessage *)message{
  2. //   ......
  3. NSMutableDictionary *dict = [NSMutableDictionary dictionary];
  4. [dict setObject:msg forKey:@"msg"];
  5. [dict setObject:from forKey:@"sender"];
  6. //消息接收到的时间
  7. [dict setObject:[Statics getCurrentTime] forKey:@"time"];
  8. ......
  9. }

最后我们再设置一下每一行显示的高度

[java] view plaincopy
  1. //每一行的高度
  2. -(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
  3. NSMutableDictionary *dict  = [messages objectAtIndex:indexPath.row];
  4. NSString *msg = [dict objectForKey:@"msg"];
  5. CGSize textSize = {260.0 , 10000.0};
  6. CGSize size = [msg sizeWithFont:[UIFont boldSystemFontOfSize:13] constrainedToSize:textSize lineBreakMode:UILineBreakModeWordWrap];
  7. size.height += padding*2;
  8. CGFloat height = size.height < 65 ? 65 : size.height;
  9. return height;
  10. }

,对了,在发送消息的时候,别忘了也加上

[java] view plaincopy
  1. - (IBAction)sendButton:(id)sender {
  2. //本地输入框中的信息
  3. ......
  4. if (message.length > 0) {
  5. .....
  6. NSMutableDictionary *dictionary = [NSMutableDictionary dictionary];
  7. [dictionary setObject:message forKey:@"msg"];
  8. [dictionary setObject:@"you" forKey:@"sender"];
  9. [dictionary setObject:[Statics getCurrentTime] forKey:@"time"];
  10. [messages addObject:dictionary];
  11. //重新刷新tableView
  12. [self.tView reloadData];
  13. }
  14. }

好了,这里关于XMPP发送消息的教程就结束了,以后我们会详细介绍其他关于XMPP的内容

源码下载

[iPhone高级] 基于XMPP的IOS聊天客户端程序(IOS端三)相关推荐

  1. [iPhone高级] 基于XMPP的IOS聊天客户端程序(IOS端一)

    介绍完了服务器,这篇我们就要介绍重点了,写我们自己的IOS客户端程序 先看一下我们完成的效果图 首先下载xmppframework这个框架,下载 点ZIP下载 接下来,用Xcode新建一个工程 将以下 ...

  2. 基于XMPP的IOS聊天客户端程序(IOS端一)

    转载自:http://blog.csdn.net/kangx6/article/details/7740135 介绍完了服务器,这篇我们就要介绍重点了,写我们自己的IOS客户端程序 先看一下我们完成的 ...

  3. [iPhone高级] 基于XMPP的IOS聊天客户端程序(IOS端二)

    接上一章的,这一章我们着重介绍XMPP 为了方便程序调用,我们把XMPP的一些主要方法写在AppDelegate中 在AppDelegate.m下这几个方法为: [java] view plainco ...

  4. 基于XMPP的IOS聊天客户端程序(IOS端三)

    转载自:http://blog.csdn.net/kangx6/article/details/7750765 前两篇介绍了如何通过XMPP来发送消息和接收消息,这一篇我们主要介绍如何来美化我们的聊天 ...

  5. 基于XMPP的IOS聊天客户端程序(IOS端二)

    转载自:http://blog.csdn.net/kangx6/article/details/7744304 接上一章的,这一章我们着重介绍XMPP 为了方便程序调用,我们把XMPP的一些主要方法写 ...

  6. [iPhone高级] 基于XMPP的IOS聊天客户端程序(XMPP服务器架构)

    最近看了关于XMPP的框架,以文本聊天为例,需要发送的消息为: [html] view plaincopy <message type="chat" from="k ...

  7. 基于XMPP的IOS聊天客户端程序(XMPP服务器架构)

    最近看了关于XMPP的框架,以文本聊天为例,需要发送的消息为: <message type="chat" from="kang@server.com" t ...

  8. 基于SMTP协议的电子邮件客户端程序

    基于SMTP协议的电子邮件客户端程序 电子邮件的完整传输过程: ​ 发件人 -> MUA -> MTA -> MTA -> 若干个MTA -> MDA <- MUA ...

  9. 基于 JavaFX 开发的聊天客户端 OIM-即时通讯

    OIM 详细介绍 一.简介 OIM是一套即时通讯的聊天系统,在这里献给大家,一方面希望能够帮助对即时通讯有兴趣研究的朋友,希望我们能够共同进步,另一个就是希望能够帮助到需要即时通讯系统的朋友或者企业, ...

最新文章

  1. xcode6 dyld_sim is not owned by root
  2. 搭建一个免费的,无限流量的Blog----github Pages和Jekyll入门
  3. 第三讲,我们来谈谈:“二进制的负数”
  4. 一种storyboard+swift实现页面跳转的方法
  5. 02.Android之IPC机制问题
  6. mysql 大量列 动态变量_aardio动态mysql变量设置
  7. java 文件url地址_简单的解析文件,取URL地址,并根据地址抓下页面
  8. #include,#import ,@class 有什么区别?
  9. Android开发笔记(一百二十二)循环器视图RecyclerView
  10. 中国1,2,4-三氟苯市场趋势报告、技术动态创新及市场预测
  11. pp加速器各种问题官方最新回答
  12. 使用linaro工具链编译ARM64架构内核
  13. 阿尔伯塔大学计算机科学是哪个校区,阿尔伯塔大学优势专业是什么?
  14. Python多线程进程协程
  15. ios不能保存png_AnyTrans for iOS for Mac (强大的ios设备管理工具)
  16. 塞拉利昂一公司计划投资10亿美元用于建设光伏农业项目
  17. HCIA Storage部分题库
  18. centos7升级GLIBC版本
  19. 影响未来的十大网络技术
  20. 爬虫系列,(4),playwright使用说明

热门文章

  1. linux内核全局变量重定位,关于可重定位文件中全局变量的一个重定位疑惑,借各位牛刀一用^...
  2. php三个数字比较大小排序,php中常用的4种实现数字大小排序的冒泡选择等算法函数代码...
  3. 安装hmmlearn
  4. KBQA相关论文分类整理:简单KBQA和复杂KBQA
  5. 天池大赛通用目标检测的对抗攻击方法一览
  6. CVPR 2020 | 自适应聚合网络AANet:更高效的立体匹配
  7. 今晚直播 | 清华大学NLP组秦禹嘉:基于自然语言解释的数据增强
  8. 基于Conditional Layer Normalization的条件文本生成
  9. 每周一起读 #02 | ICML 2019:基于粒子的变分推断加速方法
  10. 挂代理无法访问网页了怎么办_微信H5网页授权