iOS解决呼出键盘遮挡页面问题(装逼模式一)

本文首发地址

装逼模式开启—>用UITextFieldDelegate代理来解决

键盘遮挡最常见的可能就是在登录界面了,无论有多少个textfiled,不论是在VC的任何位置。都有可能造成键盘呼出来时,遮挡输入框。

如图1

两个TextField在VC的下部如何让键盘呼出的时候刚好在你点击TextFiled的下面呢?

装逼模式代码开始!!!

首先要写上UITextFieldDelegate代理协议,,,切记!!!

1:添加文本输入框

申明两个属性


@property (nonatomic, weak) UITextField * userNameText;

@property (nonatomic, weak) UITextField * userPwdText;

复制代码
UITextField * userNameText = [AutolayoutView autolayoutTextFieldWithPlaceholder:@"账号"];

userNameText.delegate = self;

[self.view addSubview:userNameText];

self.userNameText = userNameText;

UITextField * userPwdText = [AutolayoutView autolayoutTextFieldWithPlaceholder:@"密码"];

userPwdText.delegate = self;

[self.view addSubview:userPwdText];

self.userPwdText = userPwdText;
复制代码

2:实现代理方法

此处主要解决

// 当前点击textfield的坐标的Y值 + 当前点击textFiled的高度 - (屏幕高度- 键盘高度 - 键盘上tabbar高度)

// 在这一部 就是了一个 当前textfile的的最大Y值 和 键盘的最全高度的差值,用来计算整个view的偏移量

- (void)textFieldDidBeginEditing:(UITextField *)textField

{

NSLog(@"textFieldDidBeginEditing");

CGRect frame = textField.frame;

CGFloat heights = self.view.frame.size.height;

// 当前点击textfield的坐标的Y值 + 当前点击textFiled的高度 - (屏幕高度- 键盘高度 - 键盘上tabbar高度)

// 在这一部 就是了一个 当前textfile的的最大Y值 和 键盘的最全高度的差值,用来计算整个view的偏移量

int offset = frame.origin.y + 42- ( heights - 216.0-35.0);//键盘高度216

NSTimeInterval animationDuration = 0.30f;

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

[UIView setAnimationDuration:animationDuration];

float width = self.view.frame.size.width;

float height = self.view.frame.size.height;

if(offset > 0)

{

CGRect rect = CGRectMake(0.0f, -offset,width,height);

self.view.frame = rect;

}

[UIView commitAnimations];

}
复制代码

3:点击空白处的时候让其回到原来位置

/**

*  textField 取消选中状态

*

*/

-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event

{

NSLog(@"touchesBegan");

[self.view endEditing:YES];

NSTimeInterval animationDuration = 0.30f;

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

[UIView setAnimationDuration:animationDuration];

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

self.view.frame = rect;

[UIView commitAnimations];

}
复制代码

还有点击键盘的return键的时候恢复原状就要在

- (BOOL)textFieldShouldReturn:(UITextField *)textField;里头处理。
复制代码

切记一定要判断当前的textile是否是你点击的self.userNameText了。在让他恢复原状

如有问题可添加我的QQ:1290925041 还可添加QQ群:234812704(洲洲哥) 欢迎各位一块学习,提高逼格! 也可以添加洲洲哥的微信公众号 有更多干货在公众号上,请关注哦,不定期推送哦

转载于:https://juejin.im/post/5c4c11055188250f6f0cf352

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值