zoukankan      html  css  js  c++  java
  • 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显示可以上下拖动浏览(文本内容的“ ”起到了换行的作用)还显示优雅的边框。

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

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

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

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

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

     1  //为系统的动作选单中增加一项候选项
     2     UIMenuItem *menuItem = [[UIMenuItem alloc]initWithTitle:@"I Love You" action:@selector(actLoveU:)];
     3     UIMenuController *menu = [UIMenuController sharedMenuController];
     4     [menu setMenuItems:[NSArray arrayWithObjects:menuItem, nil]];
     5 
     6 //随后重写UIResponder类的方法
     7 -(BOOL)canPerformAction:(SEL)action withSender:(id)sender
     8 {
     9     //显示“I Love You”
    10     if(action == @selector(actLoveU:))
    11     {
    12         //如果UITextView控件意有所指
    13         if(self.textView.selectedRange.length>0)
    14         {
    15             return YES;
    16         }
    17     }
    18     //不破坏原有机制
    19     return [super canPerformAction:action withSender:sender];
    20 }
    21 
    22 //最后完成actLoveU:的响应函数
    23 -(IBAction)actLoveU:(id)sender
    24 {
    25     //任意响应内容
    26     NSLog(@"I Love You");
    27 }

    显示效果如图所示:

    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属性将会很方便地实现这项方案,具体代码如下:

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

    运行效果如下:

    

  • 相关阅读:
    [HDU1561]The more, The Better
    [洛谷P1352][codevs1380]没有上司的舞会
    【51Nod1773】A国的贸易 解题报告
    快速沃尔什变换
    【SDOI2015】序列统计 解题报告
    【CF438E】小朋友和二叉树 解题报告
    多项式Ⅰ
    洛谷 P5105 不强制在线的动态快速排序
    【BZOJ4916】神犇和蒟蒻 解题报告
    【BZOJ3309】DZY Loves Math 解题报告
  • 原文地址:https://www.cnblogs.com/haibosoft/p/3664737.html
Copyright © 2011-2022 走看看