1.創建并初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
@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。
1
2
3
4
5
6
7
8
9
10
11
|
- (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里不用回車鍵,可以把回車鍵當做退出鍵盤的響應鍵。
1
2
3
4
5
6
7
8
9
|
#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按鈕。
1
2
3
4
5
6
7
8
9
|
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中加入:
1
2
3
4
5
6
7
8
9
10
|
- (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方法還是自己寫吧,也就是說點擊了我們自定義的菜單項后會觸發的方法。
然后還得在代碼里加上一個方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
-(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的幾個屬性就行了
1
2
3
4
|
textView.editable = NO;//不可編輯 textView.scrollEnabled = NO;//不可滾動 textView.editable = NO;//不可編輯 textView.scrollEnabled = NO;//不可滾動 |
這樣就ok;
但是當我們在實際運用時,想計算文字的大小并設置UITextView的顯示大小
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
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是卻不行,文字總是顯示不全,不管你主動寫多了高度給它,當文字不一樣了雙會顯示不全或顯示高度過多;
可以用下面的方法試一下
1
2
3
4
|
[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];//并設置左對齊 |