IOS键盘输入屏幕上移

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了IOS键盘输入屏幕上移相关的知识,希望对你有一定的参考价值。

ios开法中经常会遇到键盘遮挡屏幕的事情(比如输入账号密码验证码等等),就使得原本都不大的屏幕直接占了一半甚至更多的位置,这倒无所谓,关键是挡住了下面的按钮。这样的话按钮的事件也就触发不了,最好的解决办法就是当输入这些信息的时候让整个屏幕上移一个键盘的位置,或者上移到指定的位置。

首先一般输入的话都用的是UITextField,所以要监听用户什么时候开始输入和什么时候结束输入,直接设置代理代理就行了,要遵受

UITextFieldDelegate协议。

//遵循协议

@interface ViewController ()<UITextFieldDelegate>

//设置属性

@property(nonatomic,strong)UITextField* UITF;

//设置代理

 UITF.delegate=self;

//代理方法

//键盘弹出时屏幕上移

-( void )textFieldDidBeginEditing:(UITextField *)textField

{

  //假如多个输入,比如注册和登录,就可以根据不同的输入框来上移不同的位置,从而更加人性化

    //键盘高度216

    //滑动效果(动画)

    NSTimeInterval animationDuration = 0.30f;

    [UIView beginAnimations:@ "ResizeForKeyboard"  context:nil];

    [UIView setAnimationDuration:animationDuration];

    //将视图的Y坐标向上移动,以使下面腾出地方用于软键盘的显示

    self.view.frame = CGRectMake(0.0f, -100.0f/*屏幕上移的高度,可以自己定*/, self.view.frame.size.width, self.view.frame.size.height); 

    [UIView commitAnimations];

}

//取消第一响应,也就是输入完毕,屏幕恢复原状

-( void )textFieldDidEndEditing:(UITextField *)textField

{

    //滑动效果

    NSTimeInterval animationDuration = 0.30f;

    [UIView beginAnimations:@ "ResizeForKeyboard"  context:nil];

    [UIView setAnimationDuration:animationDuration];

    //恢复屏幕

    self.view.frame = CGRectMake(0.0f, 0.0f, self.view.frame.size.width, self.view.frame.size.height);

    [UIView commitAnimations];

}

接下来说一下取消第一响应。

一般都是在当前View上添加一个点击手势即可,这样的话就可以取消键盘的第一响应,但是这样的话有一个弊端,比如:因为注册登录页面当屏幕上移时,

就会显示注册或登录的页面,如果添加点击手势的话那么就会覆盖掉按钮的点击事件,也就是明明看到了按钮,但是点击却没反应,那么怎么办呢?

如何实现注册登录的按钮事件都在,点击其他的地方还能取消键盘的第一响应。

其实很简单,我的解决办法是这样的

创建一个按钮,和屏幕一样大,所有的控件全部都放到这个按钮上,而这个按钮的点击事件就是取消输入框的第一响应。这样就可以了。

 

 

 


以上是关于IOS键盘输入屏幕上移的主要内容,如果未能解决你的问题,请参考以下文章

iOS-监听键盘输入,视图整体上移或恢复-避免输入遮挡

[Cordova/Phonegap] Cordova iOS 应用在第三方输入法的键盘弹出(点击输入框)时,页面不上移,导致输入框被键盘遮挡 的解决办法

iOS-当输入框被键盘遮挡时让整个view上移

iOS - 键盘显示时顶部单元格从屏幕上移开

【iOS】解决键盘收起时页面上移的问题

当网页点击tab键切换输入的文本框时,整个网页会出现上移的情况?如何解决....急急.......