转载自:http://blog.csdn.net/kangx6/article/details/7750765

前两篇介绍了如何通过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的内容

源码下载

基于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来发送消息和接收消息,这一篇我们主要介绍如何来美化我们的聊天程序,看一下最终效果呢,当然源程序也会在最后放出 好了,我们来看一下我们写的程序 这里我们自定义了TableVi ...

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

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

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

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

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

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

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

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

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

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

  9. QT学习:基于TCP的网络聊天室程序

    TCP与UDP的差别如图: 一.TCP工作原理 如下图所示,TCP能够为应用程序提供可靠的通信连接,使一台计算机发出的字节流无差错 地送达网络上的其他计算机.因此,对可靠性要求高的数据通信系统往往使用 ...

最新文章

  1. 人体关键点颜色和预处理
  2. 空客fctm避免已识别风险_最远可航行15000公里,南航首架空客A350飞机首航,将先飞广州-上海航线再飞国际...
  3. Centos Apache服务搭建
  4. windows/linux服务器上java使用openoffice将word文档转换为PDF(亲测可用)
  5. shell:多个文件按行合并
  6. 海洋分享lol皮肤插件_LOL战斗之夜客户端BUG频出服务器爆满!如何提前领取皮肤?...
  7. C语言的延时程序怎么改,C语言编程,怎么用按键来改变延时的长短?
  8. mysql 64位更改密码_win10卸载原mysql安装64位mysql5.7并修改root密码
  9. js中子父级页面相互调用
  10. Servlet/JSP面试题目-----近期总结
  11. [源码和文档分享]基于QT实现的alpha-beta剪枝算法搜索的象棋人机博弈游戏
  12. 科研画图——流程图软件draw.io
  13. MySQL--通过mysqladmin命令修改密码提示:single quotes were not trimmed line client(Windows)
  14. oms系统应用服务器,OMS、WMS、TMS、ERP之间的关系
  15. 大数据告诉你,其实中国电影票房的最强锦鲤,不是吴京
  16. WIA的使用及自定义可拖拽大小的picturebox
  17. 解决Openwrt安装插件提示一下错误的办法
  18. 用JS操作FRAME中的IFRAME及其内容
  19. 荣耀30sr升级鸿蒙,荣耀30和V30系列将首批搭载Magic UI 4.0,后续支持升级为鸿蒙系统...
  20. xctf攻防世界pwn基础题解(新手食用)

热门文章

  1. CES Asia专题|栩栩如生!Artec3D现场展示其3D扫描技术
  2. 去除pplive广告
  3. 毕业论文如何引用自己写的博客?
  4. 手把手的教你在windows上安装cygwin教程以及验证是否安装成功
  5. CSS奇怪但偶尔实用的技巧
  6. 大数据面试之kafka重点(二)
  7. SSLOJ1786 麻将游戏
  8. MOS管的工作原理浅显易懂
  9. 装机员 GHOST WIN XP SP3 装机版2016
  10. erlang rebar 配置mysql_Erlang Rebar 使用指南之一:入门篇