类似微信输入框,评论View,随着文字增加,textView自增长高度
Demo效果
data:image/s3,"s3://crabby-images/378ae/378ae164cae504d8a9c224c1ae95ec30da085afc" alt=""
Demo演示
1.添加底部View,到最底部
- 1.1 底部View都是显示到最下面,并且都是固定死的,采用Xib或者storyboard搭建
data:image/s3,"s3://crabby-images/e23ad/e23adb2be7c0419623ae29a8bda5fc28548a3a1a" alt=""
2.搭建底部View
data:image/s3,"s3://crabby-images/bbc12/bbc12f7ac53ecfdcaac1023384d45c64c9b0b73b" alt=""
data:image/s3,"s3://crabby-images/09714/097142de43058134ea61c9956542edbcf2e2558e" alt=""
3.拖线
- 3.1 获取底部View距离底部的约束,做键盘弹出效果,底部View随着键盘弹出,而往上移动效果
// 监听键盘弹出
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillChangeFrame:) name:UIKeyboardWillChangeFrameNotification object:nil];
// 键盘弹出会调用
- (void)keyboardWillChangeFrame:(NSNotification *)note
{
// 获取键盘frame
CGRect endFrame = [note.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue];
// 获取键盘弹出时长
CGFloat duration = [note.userInfo[UIKeyboardAnimationDurationUserInfoKey] floatValue];
// 修改底部视图距离底部的间距
_bottomCons.constant = _bottomCons.constant == 0?endFrame.size.height:0;
// 约束动画
[UIView animateWithDuration:duration animations:^{
[self.view layoutIfNeeded];
}];
}
- 3.2 获取底部View高度的约束,当文字修改,去修改底部View整体高度
data:image/s3,"s3://crabby-images/4d534/4d53426ee31cae6dc09ccc02f7d42d823d916e66" alt=""
- 3.3 获取文本框输入框
data:image/s3,"s3://crabby-images/9af3c/9af3cf0b9410648bef0348064aef46566a0666a4" alt=""
4.监听文本输入框,文字高度改变
- 修改底部高度约束就好了
// 监听文本框文字高度改变
_inputView.yz_textHeightChangeBlock = ^(NSString *text,CGFloat textHeight){
// 文本框文字高度改变会自动执行这个block,修改底部View的高度
// 设置底部条的高度 = 文字高度 + textView距离上下间距高度(10 = 上(5)下(5)间距总和)
_bottomHCons.constant = textHeight + 10;
};
源码
点击这下载源代码
网友评论