IOS 学习笔记(5) 控件 文本视图(UITextView)的使用方法

相对于UILabell所支持的较短文本内容,UITextView对于长文本的支持更好。UITextView能够以滚动的方式全部浏览到长文本,并且就像UILabel那样,从ISO6,他也提供了对NSAttributeString的支持.

1.不可编辑的文本视图控件

在类文件中声明一个UITextView的IBOutlet对象

@property (nonatomic, retain) IBOutlet UITextView *textView;

textView的代码配置示例如下:

  //背景颜色
self.textView.backgroundColor = [UIColor lightGrayColor];
//文字颜色
self.textView.textColor = [UIColor blackColor];
//文字字体
self.textView.font = [UIFont systemFontOfSize:14.0f];
//排版
self.textView.textAlignment = NSTextAlignmentLeft;
//是否支持滚动
self.textView.scrollEnabled = YES;
//确保静态文本不可编辑
self.textView.editable = NO;

另外,如果想要控件拥有圆角和边线,可以使用UIView的CALayer对象进行配置,再引入QuartzCore的系统框架后,实现代码如下:

    #import <QuartzCore/QuartzCore.h>
...
//边框
self.textView.layer.borderColor = [UIColor blackColor].CGColor;
self.textView.layer.borderWidth = 2.0;
//圆角
self.textView.layer.cornerRadius = 5.0;

简单的配置代码不仅将UITextView显示可以上下拖动浏览(文本内容的“\n”起到了换行的作用)还显示优雅的边框。

UITextView还能够从他的内容中自动的检测到超链接,地址,电话,日历项等元素,并且以相应的系统内置动作来处理。

 //自动检测的内容类型
self.textView.dataDetectorTypes = UIDataDetectorTypeAll;
self.textView.dataDetectorTypes = UIDataDetectorTypePhoneNumber | UIDataDetectorTypeLink | UIDataDetectorTypeAddress | UIDataDetectorTypeCalendarEvent;

2.自定义选中文本后的弹出选项

相对于普通文本内容长按是,系统会弹出一个放大镜来放大当前选中的文字。如果此时松手又会发现一个系统的贴心服务,他会在选中的地方之上弹出一个备选的动作选单列表,让用户的选择文字操作变得有意义起来。

其中“copy”会将所选中文字复制到系统粘贴板上,"Paste"则会将粘贴板上的内容粘贴在所选区域。我们还可以自定义弹出选项。代码如下:

  //为系统的动作选单中增加一项候选项
UIMenuItem *menuItem = [[UIMenuItem alloc]initWithTitle:@"I Love You" action:@selector(actLoveU:)];
UIMenuController *menu = [UIMenuController sharedMenuController];
[menu setMenuItems:[NSArray arrayWithObjects:menuItem, nil]]; //随后重写UIResponder类的方法
-(BOOL)canPerformAction:(SEL)action withSender:(id)sender
{
//显示“I Love You”
if(action == @selector(actLoveU:))
{
//如果UITextView控件意有所指
if(self.textView.selectedRange.length>)
{
return YES;
}
}
//不破坏原有机制
return [super canPerformAction:action withSender:sender];
} //最后完成actLoveU:的响应函数
-(IBAction)actLoveU:(id)sender
{
//任意响应内容
NSLog(@"I Love You");
}

显示效果如图所示:IOS 学习笔记(5) 控件 文本视图(UITextView)的使用方法

3.可编辑的文本视图

当开发者将UITextView设置成可编辑的状态时,每当用户点击到UITextView中任何内容,系统默认会弹出一个键盘供文本输入。并且由于UITextView遵守了UITextInputTraits的协议,对于输入内容来说,诸如是否首字母大写,是否开启自动校正,是否开启拼写检查,以及弹出键盘的式样等都可以从UITextView对象中进行配置,再输入的过程中,或许我们相对输入的内容做些某些特殊指定。代码如下:

//确保静态文本可编辑
self.textView.editable = YES; //所有输入文本的句子首字母大写
self.textView.autocapitalizationType = UITextAutocapitalizationTypeSentences;
//自动校正开始
self.textView.autocorrectionType = UITextAutocorrectionTypeYes;
//拼写检查开始
self.textView.spellCheckingType = UITextSpellCheckingTypeYes;
//没有输入内容时,键盘返回键置灰
self.textView.enablesReturnKeyAutomatically = YES;
//键盘外观
self.textView.keyboardAppearance = UIKeyboardAppearanceAlert;
//键盘种类
self.textView.keyboardType = UIKeyboardTypeEmailAddress;
//键盘返回键的种类
self.textView.returnKeyType = UIReturnKeyDone;
//输入内容是否加密
self.textView.secureTextEntry = NO;

4.收起键盘

系统所弹出键盘虽然会自动显示,但是他是否隐藏却常常需要开发者自己控制,一般有两种方式可以让键盘隐藏起来,首先就是对于当前的UITextView对象通过执行resignFirstResponder方法来退出对象自己作为屏幕的第一焦点。再则,对于UITextView所在的视图对象UIView进行“endEdit:Yes”的调用也可以让视图上所有的控件都退出第一焦点。是的,就像你所想的那样,系统的键盘之所以显示出来,正是因为系统检测到用户将焦点移到了UITextView上欲进行文本输入。

如果成了UITextView的代理对象,将会收到一系列包括开始编辑,结束编辑,修改内容等代理方法被动调用,这些代理回调方法如下:

(1)是否允许编辑

-(BOOL)textViewShouldBeginEditing:(UITextView *)textView

(2)开始编辑

-(void)textViewDidBeginEditing:(UITextView *)textView

(3)新的内容被输入,并且有可能会替代当前的某些内容

-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text

(4)文本内容已经被修改

-(void)textViewDidChange:(UITextView *)textView

(5)文本的选中内容发生变化

-(void)textViewDidChangeSelection:(UITextView *)textView

(6)是否允许结束编辑

-(BOOL)textViewShouldEndEditing:(UITextView *)textView

(7)结束编辑状态

-(void)textViewDidEndEditing:(UITextView *)textView

既然“返回键”不能作为键盘的触发键,那对于UITextView的键盘收起问题,我们以诸多用户体验优秀的前辈程序作为参考得出如下三种方案:

(1)在界面上方增加一条导航栏并且在导航栏右侧提供一个”完成“按钮,当“textViewDidBeginEditing”代理方法回调时,将此按钮显示出来,相反的,当"textViewDidEndEditing"代理方法回调时,按钮需要隐藏

(2)在整个屏幕的背景上增加一个捕获"点击事件"的视图,当捕获到事件时无条件地收起键盘。

(3)在键盘上端增加一条工具栏,其中提供一个“完成”按钮以收起键盘.

比较这3种方案,最后一种是用户体验最好的一项。使用UITextView的inputAccessoryView属性将会很方便地实现这项方案,具体代码如下:

  //工具栏
UIToolbar *accessBar = [[UIToolbar alloc] initWithFrame:CGRectMake(0.0f, 0.0f, CGRectGetWidth(self.view.frame), 44.0f)];
[accessBar setBarStyle:UIBarStyleBlackOpaque]; //从左至右,工具栏第一个控件是"可拉伸的空间",会将之后的控件顶向右侧
UIBarButtonItem *space = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:self action:nil];
//第二个控件“Done”,由于”有可拉伸的空间“在左侧存在,所以“Done”被顶到最右侧
UIBarButtonItem *doneButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(actFinishInput:)];
[accessBar setItems:[NSArray arrayWithObjects:space,doneButton, nil]]; //键盘上端的辅助视图设置
self.textView.inputAccessoryView = accessBar; -(IBAction)actFinishInput:(id)sender
{
//收起键盘
[self.view endEditing:YES];
}

运行效果如下:IOS 学习笔记(5) 控件 文本视图(UITextView)的使用方法

上一篇:python的变量与赋值


下一篇:js知识点总结