美文网首页
聊天页面

聊天页面

作者: nothing_c | 来源:发表于2016-11-01 00:26 被阅读38次

聊天气泡

//self.title = @"☀️☀️☀️";

//self.navigationController.navigationBar.barTintColor = [UIColor colorWithRed:85/225.0 green:105/225.0 blue:77/225.0 alpha:0.2];

//消除导航栏的东西

[self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:0];

//消除导航栏下的分隔线

self.navigationController.navigationBar.shadowImage = [UIImage new];

self.automaticallyAdjustsScrollViewInsets = NO;

self.view.backgroundColor = [UIColor whiteColor];

table = [[UITableView alloc] initWithFrame:CGRectMake(0, 0,WIDTH,HIGHT) style:UITableViewStyleGrouped];

[table registerClass:[UITableViewCell class] forCellReuseIdentifier:@"cell"];

table.backgroundView = [[UIView alloc] initWithFrame:CGRectMake(0, 0,WIDTH,HIGHT)];

UIImageView * backgroundImageView = [[UIImageView alloc] initWithFrame:CGRectMake(0,0,WIDTH,HIGHT)];

backgroundImageView.image = [UIImage imageNamed:@"7.jpg"];

[table.backgroundView addSubview:backgroundImageView];

[backgroundImageView release];

table.delegate = self;

table.dataSource = self;

[self.view addSubview:table];

table.showsVerticalScrollIndicator = NO;

table.separatorStyle = UITableViewCellSeparatorStyleNone;

[self setInputView];

dataArray = [[NSMutableArray alloc] init];

}

-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

return dataArray.count;

}

-(CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section {

return0.1;

}

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

UITableViewCel l* cell = [tableView dequeueReusableCellWithIdentifier:@"cell"];

cell.backgroundColor = [UIColor clearColor];

cell.selectionStyle =UITableViewCellSelectionStyleNone;

if(cell) {

UIView * oldView = [cell viewWithTag:101];

[oldView removeFromSuperview];

}

UIView * newView = [dataArray objectAtIndex:indexPath.row];

[cell addSubview:newView];

return cell;

}

-(void)setInputView {

inputView = [[UIView alloc] initWithFrame:CGRectMake(0,HIGHT- 44,WIDTH, 44)];

[self.view addSubview:inputView];

tf = [[UITextField alloc] initWithFrame:CGRectMake(10, 2,WIDTH- 65, 40)];

tf.backgroundColor = [UIColor clearColor];

//tf.textAlignment = NSTextAlignmentCenter;

tf.clearButtonMode=UITextFieldViewModeWhileEditing;

tf.borderStyle = UITextFieldViewModeAlways;

tf.delegate = self;

[tfa ddTarget:selfaction:@selector(keyboardDown) forControlEvents:UIControlEventEditingDidEndOnExit];

[inputView addSubview:tf];

[tf release];

UIButton* bt = [[UIButton alloc] initWithFrame:CGRectMake(WIDTH- 50, 2, 40, 40)];

bt.layer.cornerRadius = 12;

bt.layer.masksToBounds =YES;

[bt setBackgroundImage:[UIImage imageNamed:@"7.jpg"] forState:UIControlStateNormal];

[bt addTarget:self action:@selector(SendMessage) forControlEvents:UIControlEventTouchUpInside];

[inputView addSubview:bt];

[bt release];

}

-(void)textFieldDidBeginEditing:(UITextField *)textField {

[UIView beginAnimations:nilcontext:nil];

[UIView setAnimationDuration:0.33];

table.frame = CGRectMake(0, 0,WIDTH,HIGHT-216-36-5);

inputView.frame = CGRectMake(0,HIGHT-216-36-5-44,WIDTH, 44);

[UIView commitAnimations];

control = [[UIControl alloc] initWithFrame:[[UIScreenmainScreen]bounds]];

[control addTarget:self action:@selector(keyboardDown) forControlEvents:UIControlEventTouchUpInside];

[self.view insertSubview:controlbelowSubview:inputView];

if(dataArray.count> 0) {

NSIndexPath * path = [NSIndexPath indexPathForRow:dataArray.count- 1 inSection:0];

[table scrollToRowAtIndexPath:path atScrollPosition:UITableViewScrollPositionBottom animated:YES];

}

}

-(void)keyboardDown {

[control removeFromSuperview];

[self.view endEditing:YES];

[UIView beginAnimations:nilcontext:nil];

[UIView setAnimationDuration:0.15];

table.frame = CGRectMake(0, 0,WIDTH,HIGHT);

inputView.frame = CGRectMake(0,HIGHT-44,WIDTH, 44);

[UIView commitAnimations];

}

-(void)SendMessage {

//判断如果文本框无输入内容就返回跳出这个方法

if([tf.text isEqualToString:@""]) {

return;

}

isMe = !isMe;

//三目运算

NSString* isMeStr = isMe == YES?@"�":@"☀️";

NSString * inputMessageStr = tf.text;

//换行符\n 20

NSString * showMessage = [NSString stringWithFormat:@"%@ :\n%@",isMeStr,inputMessageStr];

CGRectrect  = [showMessage boundingRectWithSize:CGSizeMake(170, 500) options:NSStringDrawingUsesFontLeading | NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:17]} context:nil];

CGFloat height = rect.size.height+ 20;

CGFloat X = isMe == YES?WIDTH- 250: 10;

UIView * messageView = [[UIView alloc] initWithFrame:CGRectMake(X, 0, 240, height + 20 +40)];

messageView.tag = 101;

NSString* imageName = isMe == YES?@"bubbleSelf":@"bubble";

CGFloatI = isMe == YES? 15 : 25;

UIImageView * imageView = [[UIImageView alloc] initWithFrame:CGRectMake(I, 0, 200, height + 20)];

UIImage* oldImage = [UIImage imageNamed:imageName];

UIImage* newImage = [oldImage stretchableImageWithLeftCapWidth:20 topCapHeight:10];

imageView.image = newImage;

[messageView addSubview:imageView];

[imageView release];

UILabel* lb = [[UILabel alloc] initWithFrame:CGRectMake(I+10,5, 170, height)];

lb.text = showMessage;

lb.numberOfLines = 0;

[messageView addSubview:lb];

[lb release];

CGFloatH = isMe == YES? messageView.frame.size.width- 40:0;

UIView* headImage = [[UIView alloc] initWithFrame:CGRectMake(H, messageView.frame.size.height-40, 40, 40)];

headImage.layer.cornerRadius = 20;

headImage.layer.masksToBounds =YES;

UIImageView* Head = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, 40, 40)];

Head.image = [UIImageimageNamed:@"5.jpg"];

[headImage addSubview:Head];

[Head release];

[messageView addSubview:headImage];

[headImagerelease];

[dataArrayaddObject:messageView];

[messageView release];

[table reloadData];

NSIndexPath * path = [NSIndexPath indexPathForRow:dataArray.count- 1inSection:0];

[table scrollToRowAtIndexPath:path atScrollPosition:UITableViewScrollPositionBottom animated:YES];

tf.text = nil;

}

-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {

UIView * V = dataArray[indexPath.row];

return V.frame.size.height+22;

}

相关文章

  • 聊天页面

    聊天气泡 //self.title = @"☀️☀️☀️"; //self.navigationControlle...

  • android 聊天页面

    公司想做一个客服系统,要求聊天内容要对外保密,不允许用第三方SDK,这要求也是略严格了,搜索了一下网上的博客,质量...

  • 我的app作品展示

    2.账号管理页面 3.购物页面 4.聊天页面 5.我的页面 6.登录页面 功能:xmpp即时聊天(iphone对i...

  • 简单的聊天页面

    本来公司一直想写商城的项目,可是后台又在做催收系统,这个做完才能开始这个项目。看了一下商城的里面有个简单的和客服聊...

  • 聊天页面网络请求

    Json转模型 前面我们在聊天页面发送网络请求[https://www.jianshu.com/p/2f07616...

  • 右手Redis(Redis实践)

    用Redis开发一个聊天室网站 开发一个建议聊天室网站。这个网站分为两个页面----登录页面与聊天室页面。 1.检...

  • CDChatList

    Github.com 高性能的聊天页面解决方案对聊天列表的高度封装,可灵活配置页面样式 聊天界面其实大同小异,所以...

  • 第三方聊天---环信

    环信 聊天 配置 注册登录 好友 会话 消息 群组 聊天页面 聊天室 通话 多设备

  • 关于android 聊天页面 类似泡泡包裹聊天内容的实现

    本文 附加的代码 demo 就是实现聊天页面类似微信,陌陌等聊天信息被泡泡包裹。使得页面展示美观专业。 demo中...

  • 环信聊天对话页面双方头像以及名称

    环信聊天页面对方以及自己的头像和昵称/名称,两种方式1.在自己的聊天页面“ChatViewController.m...

网友评论

      本文标题:聊天页面

      本文链接:https://www.haomeiwen.com/subject/crtmuttx.html