iOS鍵盤彈出遮擋輸入框的解決方法
更新時間:2021年01月27日 14:15:22 作者:cungudafa
這篇文章主要為大家詳細介紹了iOS鍵盤彈出遮擋輸入框的解決方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文為大家分享了iOS鍵盤彈出遮擋輸入框的解決方法,供大家參考,具體內容如下
問題:輸入框被鍵盤遮擋
期望效果:輸入框位于鍵盤上方

解決思路:
監(jiān)聽鍵盤出現(xiàn)和消失的狀態(tài),當鍵盤出現(xiàn)時,當前視圖上移,當輸入完成收起鍵盤時,視圖回到初始狀態(tài)。
難點:視圖向上平移的距離

原理都差不多,oc版參考代碼:
self.phoneInput = [UITextField new];
self.phoneInput.placeholder = @"請輸入...";
[self.view addSubview:self.phoneInput];
///鍵盤彈出 處理遮擋問題
- (void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(keyboardWillShow:)
name:UIKeyboardWillShowNotification
object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(keyboardWillHide:)
name:UIKeyboardWillHideNotification
object:nil];
}
- (void)keyboardWillShow:(NSNotification *)notification
{
//獲取處于焦點中的view
NSArray *textFields = @[self.phoneInput];
UIView *focusView = nil;
for (UITextField *view in textFields) {
if ([view isFirstResponder]) {
focusView = view;
break;
}
}
if (focusView) {
//獲取鍵盤彈出的時間
double duration = [notification.userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue];
//獲取鍵盤上端Y坐標
CGFloat keyboardY = [notification.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue].origin.y;
//獲取輸入框下端相對于window的Y坐標
CGRect rect = [focusView convertRect:focusView.bounds toView:[[[UIApplication sharedApplication] delegate] window]];
CGPoint tmp = rect.origin;
CGFloat inputBoxY = tmp.y + focusView.frame.size.height;
//計算二者差值
CGFloat ty = keyboardY- inputBoxY;
NSLog(@"position keyboard: %f, inputbox: %f, ty: %f", keyboardY, inputBoxY, ty);
//差值小于0,做平移變換
[UIView animateWithDuration:duration animations:^{
if (ty < 0) {
self.view.transform = CGAffineTransformMakeTranslation(0, ty);
}
}];
}
}
- (void)keyboardWillHide:(NSNotification *)notification
{
//獲取鍵盤彈出的時間
double duration = [notification.userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue];
//還原
[UIView animateWithDuration:duration animations:^{
self.view.transform = CGAffineTransformMakeTranslation(0, 0);
}];
}
///<UITextFieldDelegate>
///UITextFieldDelegate編輯完成,視圖恢復原狀
-(void)textFieldDidEndEditing:(UITextField *)textField
{
self.view.frame =CGRectMake(0, 0, [[UIScreen mainScreen] bounds].size.width,[[UIScreen mainScreen] bounds].size.height);
}
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
iOS中的表單按鈕選項UIActionSheet常用方法整理
UIActionSheet經(jīng)常被用來制作各種彈出的選項,這里我們就來看一下iOS中的表單按鈕選項UIActionSheet常用方法整理,需要的朋友可以參考下2016-06-06
IOS 波紋進度(waveProgress)動畫實現(xiàn)
這篇文章主要介紹了IOS 紋進度(waveProgress)動畫實現(xiàn)的相關資料,需要的朋友可以參考下2016-09-09
Ios蘋果app應用程序開發(fā)者如何獲取IPA簽名證書詳解
這篇文章主要為大家介紹了Ios蘋果app應用程序開發(fā)者如何獲取IPA簽名證書詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11

