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

本文首发地址

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

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

如图1

iOS解决呼出键盘遮挡页面问题(装逼模式一)_第1张图片
firstVideo.gif

两个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(洲洲哥学院)
欢迎各位一块学习,提高逼格!
也可以添加洲洲哥的微信公众号
有更多干货在公众号上,请关注哦,不定期推送哦

iOS解决呼出键盘遮挡页面问题(装逼模式一)_第2张图片
qrcode_for_gh_30975e020db5_258.jpg

你可能感兴趣的:(iOS解决呼出键盘遮挡页面问题(装逼模式一))