内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

iOS中表單列表樣式鍵盤被遮擋如何解決-創(chuàng)新互聯(lián)

這篇文章將為大家詳細講解有關iOS中表單列表樣式鍵盤被遮擋如何解決,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

目前創(chuàng)新互聯(lián)已為上千余家的企業(yè)提供了網站建設、域名、網頁空間、網站托管運營、企業(yè)網站設計、龍安網站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。

具體實現(xiàn)分以下幾步:

  • 監(jiān)聽鍵盤彈起和收起事件

  • 計算鍵盤高度

  • 計算contentoffset的y值要改變的差值并修改contentoffset的值

  • 滑動列表時收起鍵盤

  • 鍵盤收起時還原contentoffset的值

iOS中表單列表樣式鍵盤被遮擋如何解決
圖1

下面一起來通過代碼實現(xiàn)這個5步

第一步__設置監(jiān)聽

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardAction:) name:UIKeyboardWillShowNotification object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardAction:) name:UIKeyboardWillHideNotification object:nil];

第二步__計算高度

// 鍵盤監(jiān)聽事件
- (void)keyboardAction:(NSNotification*)sender{
 NSDictionary *useInfo = [sender userInfo];
 NSValue *value = [useInfo objectForKey:UIKeyboardFrameEndUserInfoKey];
 //鍵盤高度
 CGFloat height = [value CGRectValue].size.height;
 if ([sender.name isEqualToString:UIKeyboardWillShowNotification]) {
   //鍵盤彈起時
 } else {
   //鍵盤收起時
 } 
}

第三步__計算contentoffset的y值要改變的差值并修改contentoffset的值

我們以點擊第7個輸入框為例,當點擊第7個輸入框的時候,我們想要的效果是讓第7個輸入框跑到鍵盤上邊,如圖2所示

iOS中表單列表樣式鍵盤被遮擋如何解決

圖2

那么這里我們就要計算一下需要向上移動的距離delta=3-(2-1),2是list的高度,1是鍵盤的高度,3是第7個輸入框所在cell的maxY值-當前l(fā)ist的contentoffset的y值,如圖3,

iOS中表單列表樣式鍵盤被遮擋如何解決

圖3

1和2我們很好獲得,重點是獲取3的值,我們只要獲取到第7個輸入框所在cell的實例,然后通過CGRectGetMaxY(cell.frame)即可獲得此值。下邊是獲取到cell實例的代碼

- (UICollectionViewCell *)firstResponderCell {
 __block UICollectionViewCell *cell = nil;
 [self.collectionView.visibleCells enumerateObjectsUsingBlock:^(__kindof UICollectionViewCell * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
  UICollectionViewCell *visibleCell = obj;
  //焦點所在的textField
  if (visibleCell.textField.isFirstResponder) {
   cell = visibleCell;
  }
 }];
 return cell;
}

計算差值改變contentoffset

// 鍵盤監(jiān)聽事件
- (void)keyboardAction:(NSNotification*)sender{
 NSDictionary *useInfo = [sender userInfo];
 NSValue *value = [useInfo objectForKey:UIKeyboardFrameEndUserInfoKey];
 //鍵盤高度
 CGFloat keyboardHeight = [value CGRectValue].size.height;
 //列表的高度
 CGFloat collectionViewHeight = self.collectionView.frame.size.height;
 if ([sender.name isEqualToString:UIKeyboardWillShowNotification]) {
  //鍵盤彈出時
  //獲取輸入框焦點所在的cell
  UICollectionViewCell *cell = [self firstResponderCell];
  if (cell) {
   //cell的maxY值
   CGFloat cellMaxY = CGRectGetMaxY(cell.frame)- self.collectionView.contentOffset.y;
   //差值 = 3 -(2-1)
   if (cellMaxY > collectionViewHeight-keyboardHeight) {
    //記錄delta值,鍵盤收起恢復原來位置時使用
    self.delta = cellMaxY-(collectionViewHeight-keyboardHeight);
    self.collectionView.contentOffset = CGPointMake(0, self.collectionView.contentOffset.y+self.delta);
   }
  }
 } else {
   //鍵盤收起時
 }
 
}

第四步__滑動列表時收起鍵盤

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView {
 UICollectionViewCell *cell = [self firstResponderCell];
 if (cell) {
  [cell.textField resignFirstResponder];  
 }
}

第五步__鍵盤收起時還原contentoffset的值

// 鍵盤監(jiān)聽事件
- (void)keyboardAction:(NSNotification*)sender{
 NSDictionary *useInfo = [sender userInfo];
 NSValue *value = [useInfo objectForKey:UIKeyboardFrameEndUserInfoKey];
 //鍵盤高度
 CGFloat keyboardHeight = [value CGRectValue].size.height;
 //列表的高度
 CGFloat collectionViewHeight = self.collectionView.frame.size.height;
 if ([sender.name isEqualToString:UIKeyboardWillShowNotification]) {
  //鍵盤出現(xiàn)時
 } else {
  //鍵盤收起時
  //根據(jù)self.delta復原
  self.collectionView.contentOffset = CGPointMake(0, self.collectionView.contentOffset.y-self.delta);
  self.delta = 0
 }
}

關于iOS中表單列表樣式鍵盤被遮擋如何解決就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站www.rwnh.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

本文題目:iOS中表單列表樣式鍵盤被遮擋如何解決-創(chuàng)新互聯(lián)
網頁網址:http://www.rwnh.cn/article14/csdpde.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供域名注冊、自適應網站、關鍵詞優(yōu)化、電子商務、網站收錄響應式網站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

網站托管運營
吴川市| 青州市| 岳西县| 南平市| 南宫市| 高淳县| 贺兰县| 托克托县| 南投县| 怀远县| 新民市| 长岛县| 栖霞市| 富蕴县| 波密县| 丹江口市| 甘谷县| 湘阴县| 临朐县| 宽甸| 开平市| 平山县| 博客| 瓮安县| 睢宁县| 阳东县| 香河县| 兴海县| 建昌县| 敦煌市| 昌宁县| 壤塘县| 平和县| 平顶山市| 邯郸县| 互助| 突泉县| 南郑县| 温宿县| 宜兴市| 洛扎县|