iOS學習筆記——鍵盤處理

来源:http://www.cnblogs.com/shouce/archive/2016/05/17/5503078.html
-Advertisement-
Play Games

在網上找到的資料比較零散,這部分學起來感覺也有點空虛,內容就只包括隱藏鍵盤和鍵盤高度兩部分 隱藏鍵盤其實就在我學習iOS開發的第一個程式裡面已經實踐過了,不過當時還懵懵懂懂,現在就瞭解了是什麼一回事,就記錄一下,也額外加點內容上去。 說這個鍵盤的出現和隱藏是和輸入框獲取和失去焦點有關係,輸入框獲取了 ...


  在網上找到的資料比較零散,這部分學起來感覺也有點空虛,內容就只包括隱藏鍵盤和鍵盤高度兩部分

    隱藏鍵盤其實就在我學習iOS開發的第一個程式裡面已經實踐過了,不過當時還懵懵懂懂,現在就瞭解了是什麼一回事,就記錄一下,也額外加點內容上去。

    說這個鍵盤的出現和隱藏是和輸入框獲取和失去焦點有關係,輸入框獲取了焦點,軟鍵盤就會出現;輸入框失去了焦點,軟鍵盤就會消失。這個就和Android的有出入。所以要鍵盤消失其實很簡單的一行代碼就可以完成了

[nameTextField resignFirstResponder]; //nameTextFiled就是輸入框的名字

但是在哪個地方執行,觸發機制就多加一點步驟了。讓鍵盤消失首要的肯定是文本框輸入完畢(以按回車鍵為準)就應該消失,那就要去實現UITextFieldDelegate的- (BOOL)textFieldShouldReturn:(UITextField *)textField 方法,並且把輸入框的delegate設置成當前的ViewController。代碼如下

複製代碼
@interface HGTabItem2KeyboardViewController : UIViewController<UITextFieldDelegate>

{

}

@end
複製代碼

 ViewDidLoad的代碼

self.txtTextBox.delegate=self;

 添加方法

複製代碼
-(BOOL)textFieldShouldReturn:(UITextField *)textField

{

if(self.txtTextBox==textField)

[textField resignFirstResponder];

return true;

} 
複製代碼

在平時使用軟鍵盤的時候總有一個習慣:不是沒次打字都想打完結束的,當打字打到一半然後推出不想打讓軟鍵盤消失的時候,就會點擊一下屏幕空白的地方,軟鍵盤就消失了。現在已經學習了觸控事件的話對這個已經不難了,除了在- (BOOL)textFieldShouldReturn:(UITextField *)textField 方法裡面調用resignFirstResponder方法外,還在觸控的事件里也調用self.view endEditing就行了,這個觸控事件可以使用touchesEnded:withEvent:,也可以使用UITapGestureRecognizer 

-(void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event
{

  [self.view endEditing:true];

}

 聲明代碼

@interface HGTabItem2KeyboardViewController : UIViewController<UITextFieldDelegate,UIGestureRecognizerDelegate>
{

}

@end

ViewDidLoad中的代碼

UITapGestureRecognizer *gestrue=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(singleTap:)];

gestrue.numberOfTouchesRequired=1;

[self.view addGestureRecognizer:gestrue];

 添加方法

-(void)singleTap:(UITapGestureRecognizer *)gecognizer
{

  [self.txtTextBox endEditing:true];

}

處理鍵盤高度實際上是利用了鍵盤的全局事件,網上有種說法是在iOS5.0以後,鍵盤會在不同的輸入語言下高度會有所變化,但經我在模擬器上實踐後發現這個高度的差別不存在,但是這個鍵盤高度還是有用的,例如QQ,微信在鍵盤出現的時候,整個視圖會往上移動,移動的距離就是鍵盤高度,這個就用到了鍵盤高度了。鍵盤高度是用到鍵盤的全局事件

  • UIKeyboardWillShowNotification;
  • UIKeyboardDidShowNotification;
  • UIKeyboardWillHideNotification;
  • UIKeyboardDidHideNotification;

iOS5.0還增加了兩個事件

  • UIKeyboardWillChangeFrameNotification
  • UIKeyboardDidChangeFrameNotification

以上的事件看名字就知道是在什麼時候觸發,但是ChangeFrame事件的效果不算明顯,當因為當鍵盤高度變化的時候同時觸發了showChangeFrame兩個事件,下麵還是把代碼粘出來

ViewDidLoad加入以下方法

複製代碼
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil];

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

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillChange:) name:UIKeyboardWillChangeFrameNotification object:nil];

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardDidChange:) name:UIKeyboardDidChangeFrameNotification object:nil];
複製代碼

再加入以下事件方法

複製代碼
- (void)didReceiveMemoryWarning
{

[super didReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

 

-(BOOL)textFieldShouldReturn:(UITextField *)textField
{

if(self.txtTextBox==textField)

[textField resignFirstResponder];

return true;

}

 

-(void)keyboardWillChange:(NSNotification *)notif
{

NSLog(@"keyboardWillChange");

}

 

-(void)keyboardDidChange:(NSNotification*)notif
{

 

}

 

-(void)keyboardWillShow:(NSNotification*)notif
{
//keyboard height will be 216, on iOS version older than 5.0 CGRect boxFrame = self.view.frame; boxFrame.origin.y = -[[[notif userInfo]objectForKey:UIKeyboardFrameEndUserInfoKey]CGRectValue].size.height+ self.tabBarController.tabBar.frame.size.height;//50; [UIView animateWithDuration:0.3f animations:^{ self.view.frame = boxFrame; }]; NSLog(@"keyboardWillShow"); } -(void)keyboardWillHide:(NSNotification*)notif
{ CGRect boxFrame
= self.view.frame; boxFrame.origin.y =0; //216; [UIView animateWithDuration:0.3f animations:^{ self.view.frame = boxFrame; }]; }
複製代碼

在點擊的時候,文本框會上移,但是文本框剛好在鍵盤的頂部,還是在視圖的最底部。當鍵盤隱藏時,文本框剛好下移,最終剛好在屏幕最底端。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 各大瀏覽器廠商對es2015功能支持不完全,等到全部支持會等很長時間,如果現在使用es2015,可以選擇babel一個將ES6/ES7寫的代碼轉換為ES5代碼的編譯器. 我們選擇使用gulp自動化編譯生成es5代碼. 假設你已經安裝過了nodejs. 配置開發環境: 1. 建立工程目錄: 2. 新建 ...
  • 本章以實際案例分析在android開發中,性能方面的優化和處理。設計到知識點有弱引用,memory monitor,Allocation Tracker和leakcanary插件。 1.測試demo 下載bug項目:https://github.com/lzyzsd/MemoryBugs,請註意配合 ...
  • 非同步任務+並行隊列 把非同步任務放到並行隊列進行執行,非同步任務會在不同的線程中執行。 運行結果如下。非同步任務+並行隊列組合情況下,每個任務會在不同的線程中同時執行。 非同步任務+串列隊列(主隊列) 對於非同步任務放在串列隊列中執行時,任務只會在一個新開的線程中,按照順序進行執行。 運行結果如下。可以看到, ...
  • 前面我們把需要攔截的手機號都存儲和展示出來了,接下來是使用廣播接收者攔截簡訊了,這個廣播接收者需要和一個服務綁定,服務開啟的時候,接收者存在,服務停掉時,接收者關閉 在service包下定義一個類CallSmsSafeService繼承系統的Service 重寫onCreate()方法 獲取Broa ...
  • 1. 多線程概述 1> 程式、進程和進程的概念 程式:由源代碼生成的可執行應用。(例如:QQ.app) 進程:一個正在運行的程式可以看做一個進程。(例如:正在運行的QQ就是一個進程),進程擁有獨立運行所需的全部資源。 線程:程式中獨立運行的代碼段。(例如:接收QQ消息的代碼) 一個進程是由一或多個線 ...
  • 深入剖析通知中心和KVO 要先瞭解KVO和通知中心,就得先說說觀察者模式,那麼觀察者模式到底是什麼呢?下麵來詳細介紹什麼是觀察者模式。 觀察者模式 A對B的變化感興趣,就註冊成為B的觀察者,當B發生變化時通知A,告知B發生了變化,這就是觀察者模式。 觀察者模式定義了一對一對多的依賴關係,讓多個觀察者 ...
  • 一、多線程概述 1、程式,進程,線程 程式:由源代碼生成的可執行應用。(例如:QQ.app) 進程:一個正在運行的程式可以看做一個進程。(例如:正在運行的QQ就是一個進程),進程擁有獨立運行所需的全部資源。 線程:程式中獨立運行的代碼段。(例如:接收QQ消息的代碼) 一個進程是由一或多個線程組成。進 ...
  • 數據存儲的持久化技術 數據存儲主要有五種方式: (1)文件存儲或者SD卡 (2)SharedPreferences (3)SQLite (4)ContentProvider (5)網路存儲 下麵簡單介紹一下前三種存儲 1.文件存儲 比較適合存儲一些簡單的文本數據或者二進位數據,主要用到的方法是ope ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...