1.創建並初始化
@property (nonatomic, strong) UITextView *textView; // 創建 self.textView = [[UITextView alloc] initWithFrame:self.view.frame]; // 設置textview裡面的字體顏色 self.textView.textColor = [UIColor blackColor]; // 設置字體名字和字體大小 self.textView.font = [UIFont fontWithName:@"Arial" size:18.0]; // 設置代理 self.textView.delegate = self; // 設置它的背景顏色 self.textView.backgroundColor = [UIColor whiteColor]; self.textView.text = @“hehe”; // 返回鍵的類型 self.textView.returnKeyType = UIReturnKeyDefault; // 鍵盤類型 self.textView.keyboardType = UIKeyboardTypeDefault; // 是否可以拖動 self.textView.scrollEnabled = YES;
2. UITextView退出鍵盤的幾種方式
(1)如果你程序是有導航條的,可以在導航條上面加多一個Done的按鈕,用來退出鍵盤,當然要先實現UITextViewDelegate。
- (void)textViewDidBeginEditing:(UITextView *)textView { self.navigationItem.rightBarButtonItem = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(getOverEditing)]; } - (void)textViewDidEndEditing:(UITextView *)textView { self.navigationItem.rightBarButtonItem = nil; } - (void)getOverEditing{ [self.textView resignFirstResponder]; }
(2)如果你的textview裡不用回車鍵,可以把回車鍵當做退出鍵盤的響應鍵。
#pragma mark - UITextView Delegate Methods -(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text { if ([text isEqualToString:@"\n"]) { [textView resignFirstResponder]; return NO; } return YES; }
(3)還有你也可以自定義其他視圖控件加載到鍵盤上用來退出,比如在彈出的鍵盤上面加一個view來放置退出鍵盤的Done按鈕。
UIToolbar * topView = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 30)]; UIBarButtonItem * cancelButton= [[UIBarButtonItem alloc]initWithTitle:@"Done" style:UIBarButtonItemStyleDone target:self action:@selector(dismissKeyBoard)]; NSArray * buttonsArray = @[cancelButton]; [topView setItems:buttonsArray]; [self.textView setInputAccessoryView:topView]; -(void)dismissKeyBoard { [tvTextView resignFirstResponder]; }
3.UITextView自定選擇文字後的菜單
在ViewDidLoad中加入:
- (void)viewDidLoad { [super viewDidLoad]; self._textView = [[UITextView alloc] initWithFrame:CGRectMake(10, 100, 300, 200)]; [self.view addSubview:_textView]; UIMenuItem *menuItem = [[UIMenuItem alloc]initWithTitle:@“我是自定義的菜單" action:@selector(didClickCustomMenuAction)]; UIMenuController *menu = [UIMenuController sharedMenuController]; [menu setMenuItems:[NSArray arrayWithObject:menuItem]]; [menuItem release]; }
當然上面那個@selector裡面的changeColor方法還是自己寫吧,也就是說點擊了我們自定義的菜單項後會觸發的方法。
然後還得在代碼裡加上一個方法:
-(BOOL)canPerformAction:(SEL)action withSender:(id)sender { if(action ==@selector(changeColor) || action == @selector(copy:)) { if(_textView.selectedRange.length>0) return YES; } return NO; } -(void)didClickCustomMenuAction { NSLog(@"%@“,__function__); }
4.設置UITextView內邊距
當我們因為一些需求將UITextView當成UILabel使用(為了使用UITextView自帶的復制,粘貼,選擇功能),這時我們只需要禁用UITextView的幾個屬性就行了
textView.editable = NO;//不可編輯 textView.scrollEnabled = NO;//不可滾動 textView.editable = NO;//不可編輯 textView.scrollEnabled = NO;//不可滾動
這樣就ok;
但是當我們在實際運用時,想計算文字的大小並設置UITextView的顯示大小
UIFont *font = [UIFont systemFontOfSize:14.0f]; //指定字符串的大小 [textView setText:content]; CGSize textSize = [content sizeWithFont:font constrainedToSize:CGSizeMake(200, 2000) lineBreakMode:UILineBreakModeCharacterWrap]; CGRect articleframe = [articleLabel frame]; textView.size.height = textSize.height ; textView.size.width = textSize.width; [textView setFrame:articleframe]; UIFont *font = [UIFont systemFontOfSize:14.0f]; //指定字符串的大小 [textView setText:content]; CGSize textSize = [content sizeWithFont:font constrainedToSize:CGSizeMake(200, 2000) lineBreakMode:UILineBreakModeCharacterWrap]; CGRect articleframe = [articleLabel frame]; textView.size.height = textSize.height ; textView.size.width = textSize.width; [textView setFrame:articleframe];
但是通過這種方法在UILabel上使用沒有任何問題,但是在UITextView是卻不行,文字總是顯示不全,不管你主動寫多了高度給它,當文字不一樣了雙會顯示不全或顯示高度過多;
可以用下面的方法試一下
[self.articleLabel setContentInset:UIEdgeInsetsMake(-10, -5, -15, -5)];//設置UITextView的內邊距 [self.articleLabel setTextAlignment:NSTextAlignmentLeft];//並設置左對齊 [self.articleLabel setContentInset:UIEdgeInsetsMake(-10, -5, -15, -5)];//設置UITextView的內邊距 [self.articleLabel setTextAlignment:NSTextAlignmentLeft];//並設置左對齊