iOS鍵盤彈出遮擋輸入框的解決方法
本文為大家分享了iOS鍵盤彈出遮擋輸入框的解決方法,供大家參考,具體內(nèi)容如下
問(wèn)題:輸入框被鍵盤遮擋
期望效果:輸入框位于鍵盤上方
解決思路:
監(jiān)聽(tīng)鍵盤出現(xiàn)和消失的狀態(tài),當(dāng)鍵盤出現(xiàn)時(shí),當(dāng)前視圖上移,當(dāng)輸入完成收起鍵盤時(shí),視圖回到初始狀態(tài)。
難點(diǎn):視圖向上平移的距離
原理都差不多,oc版參考代碼:
self.phoneInput = [UITextField new]; self.phoneInput.placeholder = @"請(qǐng)輸入..."; [self.view addSubview:self.phoneInput]; ///鍵盤彈出 處理遮擋問(wèn)題 - (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 { //獲取處于焦點(diǎn)中的view NSArray *textFields = @[self.phoneInput]; UIView *focusView = nil; for (UITextField *view in textFields) { if ([view isFirstResponder]) { focusView = view; break; } } if (focusView) { //獲取鍵盤彈出的時(shí)間 double duration = [notification.userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue]; //獲取鍵盤上端Y坐標(biāo) CGFloat keyboardY = [notification.userInfo[UIKeyboardFrameEndUserInfoKey] CGRectValue].origin.y; //獲取輸入框下端相對(duì)于window的Y坐標(biāo) CGRect rect = [focusView convertRect:focusView.bounds toView:[[[UIApplication sharedApplication] delegate] window]]; CGPoint tmp = rect.origin; CGFloat inputBoxY = tmp.y + focusView.frame.size.height; //計(jì)算二者差值 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 { //獲取鍵盤彈出的時(shí)間 double duration = [notification.userInfo[UIKeyboardAnimationDurationUserInfoKey] doubleValue]; //還原 [UIView animateWithDuration:duration animations:^{ self.view.transform = CGAffineTransformMakeTranslation(0, 0); }]; } ///<UITextFieldDelegate> ///UITextFieldDelegate編輯完成,視圖恢復(fù)原狀 -(void)textFieldDidEndEditing:(UITextField *)textField { self.view.frame =CGRectMake(0, 0, [[UIScreen mainScreen] bounds].size.width,[[UIScreen mainScreen] bounds].size.height); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
詳解iOS WebDriverAgent 環(huán)境搭建
這篇文章主要介紹了詳解iOS WebDriverAgent 環(huán)境搭建,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01iOS點(diǎn)擊推送消息跳到應(yīng)用指定頁(yè)面方法
現(xiàn)在的推送用的越來(lái)越頻繁,幾乎每個(gè)應(yīng)用都開始用到了。這篇文章主要介紹了iOS點(diǎn)擊推送消息跳到應(yīng)用指定頁(yè)面方法,有需要的可以了解一下。2016-11-11iOS UICollectionView刷新時(shí)閃屏的解決方法
本篇文章主要介紹了iOS UICollectionView刷新時(shí)閃屏的解決方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11iOS App開發(fā)中的UIStackView堆疊視圖使用教程
UIStackView是iOS9以來(lái)新增加的組件,使我們能夠?qū)IView子類對(duì)象進(jìn)行靈活排版,這里我們就來(lái)看一下iOS App開發(fā)中的UIStackView堆疊視圖使用教程2016-07-07快速解決低版本Xcode不支持高版本iOS真機(jī)調(diào)試的問(wèn)題方法
這篇文章主要介紹了快速解決低版本Xcode不支持高版本iOS真機(jī)調(diào)試的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02iOS 仿百度外賣-首頁(yè)重力感應(yīng)的實(shí)例
這篇文章主要介紹了iOS 仿百度外賣-首頁(yè)重力感應(yīng)的實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-01-01