在某些应用中经常会遇到输入框在最下面,当录入文字时需要将输入框拉到上面,不然键盘无法显示,而且随着输入的文字越来越多,也需要改变输入框的显示区域,这里用到了textview,因为textfild不会拐弯啊。网络上有很多很好的demo,但功能貌似过多,而且对于看别人代码头疼的我们面对那么多界面一下子就瘫了,于是还在研究textview的代理自己实现的好。我定义了如下视图布局
灰色部分为输入框,当点击输入框,输入框会向上弹出,键盘从下面弹出来,紫色button按键也随着输入框一起向上,布局代码如下
千万要记得设置textview的代理。点击输入框实现的改变如下
键盘出来了,回复框和button都上去了。主要在下面的代理里添加了改变fram'的方法
做了一个动画,键盘的高度是216再加上textview本身的高度最后动画完成刚好衔接好。textview和button必须保持在同一高度上要一起动。当输入的时候textview的显示区域也要跟着一起变
输了那么多,textview也跟着长了,包括button,看看是怎么实现的
这里改变的主要是origin.y的值,就是纵坐标,textview还要改变本身的高度
输入完了,当点击确定,输入框如button又回到最初的状态,键盘也消失了。
下面是在button里的操作
这里因为有其他的代码没有切到键盘的响应,熊孩子自己补上