IOS UI學習教程之設定UITextField各種屬性_IOS

來源:互聯網
上載者:User

UITextField是IOS中非常常用的一個控制項,用來接收使用者輸入資訊,完成應用和使用者的互動。它的主要屬性設定如下:

//初始化textfield並設定位置及大小 UITextField *text = [[UITextField alloc]initWithFrame:CGRectMake(20, 20, 130, 30)]; //設定邊框樣式,只有設定了才會顯示邊框樣式  text.borderStyle = UITextBorderStyleRoundedRect; typedef enum { UITextBorderStyleNone,  UITextBorderStyleLine, UITextBorderStyleBezel, UITextBorderStyleRoundedRect  } UITextBorderStyle; //設定輸入框的背景顏色,此時設定為白色 如果使用了自訂的背景圖片邊框會被忽略掉  text.backgroundColor = [UIColor whiteColor]; //設定背景 text.background = [UIImage imageNamed:@"dd.png"]; //設定背景  text.disabledBackground = [UIImage imageNamed:@"cc.png"];//當輸入框沒有內容時,浮水印提示 提示內容為password text.placeholder = @"password"; //設定輸入框內容的字型樣式和大小 text.font = [UIFont fontWithName:@"Arial" size:20.0f]; //設定字型顏色 text.textColor = [UIColor redColor]; //輸入框中是否有個叉號,在什麼時候顯示,用於一次性刪除輸入框中的內容 text.clearButtonMode = UITextFieldViewModeAlways; typedef enum { UITextFieldViewModeNever, 重不出現 UITextFieldViewModeWhileEditing, 編輯時出現 UITextFieldViewModeUnlessEditing, 除了編輯外都出現 UITextFieldViewModeAlways 一直出現} UITextFieldViewMode; //輸入框中一開始就有的文字 text.text = @"一開始就在輸入框的文字"; //每輸入一個字元就變成點 用語密碼輸入 text.secureTextEntry = YES; //是否錯誤修正 text.autocorrectionType = UITextAutocorrectionTypeNo; typedef enum { UITextAutocorrectionTypeDefault, 預設 UITextAutocorrectionTypeNo, 不自動錯誤修正 UITextAutocorrectionTypeYes, 自動錯誤修正} UITextAutocorrectionType; //再次編輯就清空 text.clearsOnBeginEditing = YES;  //內容對齊 text.textAlignment = UITextAlignmentLeft; //內容的垂直對齊 UITextField繼承自UIControl,此類中有一個屬性contentVerticalAlignment text.contentVerticalAlignment = UIControlContentVerticalAlignmentCenter; //設定為YES時文本會自動縮小以適應文字視窗大小.預設是保持原來大小,而讓長文本滾動  textFied.adjustsFontSizeToFitWidth = YES; //設定自動縮小顯示的最小字型大小 text.minimumFontSize = 20; //設定鍵盤的樣式 text.keyboardType = UIKeyboardTypeNumberPad; typedef enum { UIKeyboardTypeDefault,  預設鍵盤,支援所有字元    UIKeyboardTypeASCIICapable, 支援ASCII的預設鍵盤 UIKeyboardTypeNumbersAndPunctuation, 標準電話鍵盤,支援+*#字元 UIKeyboardTypeURL,   URL鍵盤,支援.com按鈕 只支援URL字元UIKeyboardTypeNumberPad,    數字鍵台UIKeyboardTypePhonePad,  電話鍵盤 UIKeyboardTypeNamePhonePad, 電話鍵盤,也支援輸入人名UIKeyboardTypeEmailAddress, 用於輸入電子 郵件地址的鍵盤  UIKeyboardTypeDecimalPad,  數字鍵台 有數字和小數點 UIKeyboardTypeTwitter,  最佳化的鍵盤,方便輸入@、#字元 UIKeyboardTypeAlphabet = UIKeyboardTypeASCIICapable, } UIKeyboardType; //首字母是否大寫 text.autocapitalizationType = UITextAutocapitalizationTypeNone; typedef enum { UITextAutocapitalizationTypeNone, 不自動大寫 UITextAutocapitalizationTypeWords, 單字首大寫 UITextAutocapitalizationTypeSentences, 句子的首字母大寫 UITextAutocapitalizationTypeAllCharacters, 所有字母都大寫} UITextAutocapitalizationType; //return鍵變成什麼鍵 text.returnKeyType =UIReturnKeyDone; typedef enum { UIReturnKeyDefault, 預設 灰色按鈕,標有Return UIReturnKeyGo,  標有Go的藍色按鈕 UIReturnKeyGoogle,標有Google的藍色按鈕,用語搜尋 UIReturnKeyJoin,標有Join的藍色按鈕 UIReturnKeyNext,標有Next的藍色按鈕 UIReturnKeyRoute,標有Route的藍色按鈕 UIReturnKeySearch,標有Search的藍色按鈕 UIReturnKeySend,標有Send的藍色按鈕 UIReturnKeyYahoo,標有Yahoo的藍色按鈕 UIReturnKeyYahoo,標有Yahoo的藍色按鈕 UIReturnKeyEmergencyCall, 緊急電話按鈕} UIReturnKeyType; //鍵盤外觀textView.keyboardAppearance=UIKeyboardAppearanceDefault;typedef enum {UIKeyboardAppearanceDefault, 預設面板,淺灰色UIKeyboardAppearanceAlert,  深灰 石墨色 } UIReturnKeyType;//設定代理 用於實現協議 text.delegate = self; //把textfield加到視圖中 [self.window addSubview:text]; //最右側加圖片是以下代碼 左側類似 UIImageView *image=[[UIImageView alloc] initWithImage:[UIImage imageNamed:@"right.png"]]; text.rightView=image; text.rightViewMode = UITextFieldViewModeAlways;  typedef enum { UITextFieldViewModeNever, UITextFieldViewModeWhileEditing, UITextFieldViewModeUnlessEditing, UITextFieldViewModeAlways} UITextFieldViewMode;//按return鍵鍵盤往下收 becomeFirstResponder 類要採用UITextFieldDelegate協議 text.delegate = self; 聲明text的代理是我,我會去實現把鍵盤往下收的方法 這個方法在UITextFieldDelegate裡所以我們要採用UITextFieldDelegate這個協議 - (BOOL)textFieldShouldReturn:(UITextField *)textField{ [text resignFirstResponder]; //主要是[receiver resignFirstResponder]在哪調用就能把receiver對應的鍵盤往下收 return YES;}重寫繪製行為除了UITextField對象的風格選項,你還可以定製化UITextField對象,為他添加許多不同的重寫方法,來改變文字欄位的顯示行為。這些方法都會返回一個CGRect結構,制定了文字欄位每個組件的邊界範圍。以下方法都可以重寫。 – textRectForBounds:   //重寫來重設文字地區– drawTextInRect:    //改變繪文字屬性.重寫時調用super可以按預設圖形屬性繪製,若自己完全重寫繪製函數,就不用調用super了.– placeholderRectForBounds:  //重寫來重設預留位置地區– drawPlaceholderInRect:  //重寫改變繪製預留位置屬性.重寫時調用super可以按預設圖形屬性繪製,若自己完全重寫繪製函數,就不用調用super了.– borderRectForBounds:  //重寫來重設邊緣地區– editingRectForBounds:  //重寫來重設編輯地區– clearButtonRectForBounds:  //重寫來重設clearButton位置,改變size可能導致button的圖片失真– leftViewRectForBounds:– rightViewRectForBounds: 委託方法 - (BOOL)textFieldShouldBeginEditing:(UITextField *)textField{  //返回一個BOOL值,指定是否循序文字欄位開始編輯   return YES; }  - (void)textFieldDidBeginEditing:(UITextField *)textField{  //開始編輯時觸發,文字欄位將成為first responder }  - (BOOL)textFieldShouldEndEditing:(UITextField *)textField{ //返回BOOL值,指定是否允許文字欄位結束編輯,當編輯結束,文字欄位會讓出first responder  //要想在使用者結束編輯時阻止文字欄位消失,可以返回NO  //這對一些文字欄位必須始終保持活躍狀態的程式很有用,比如立即訊息   return NO; }  - (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{ //當使用者使用自動校正功能,把輸入的文字修改為推薦的文字時,就會調用這個方法。 //這對於想要加入撤銷選項的應用程式特別有用 //可以跟蹤欄位內所做的最後一次修改,也可以對所有編輯做日誌記錄,用作審計用途。  //要防止文字被改變可以返回NO //這個方法的參數中有一個NSRange對象,指明了被改變文字的位置,建議修改的文本也在其中    return YES; }  - (BOOL)textFieldShouldClear:(UITextField *)textField{  //返回一個BOOL值指明是否允許根據使用者請求清除內容 //可以設定在特定條件下才允許清除內容    return YES; }  -(BOOL)textFieldShouldReturn:(UITextField *)textField{  //返回一個BOOL值,指明是否允許在按下斷行符號鍵時結束編輯  //如果允許要調用resignFirstResponder 方法,這回導致結束編輯,而鍵盤會被收合[textField resignFirstResponder];//查一下resign這個單詞的意思就明白這個方法了   return YES; }

以上就是本文的全部內容,希望對大家學習IOS程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.