iOS学习--UITextView的那些事

一、UITextView的基础使用详解

  

//初始化并定义大小   

 UITextView *textview = [[UITextView allocinitWithFrame:CGRectMake(201028030)];

    textview.backgroundColor=[UIColor whiteColor]; //背景色

    textview.scrollEnabled = NO   //当文字超过视图的边框时是否允许滑动,默认为“YES”

    textview.editable = YES       //是否允许编辑内容,默认为“YES”

    textview.delegate = self;       //设置代理方法的实现类

    textview.font=[UIFont fontWithName:@"Arial" size:18.0]; //设置字体名字和字体大小;

    textview.returnKeyType = UIReturnKeyDefault;//return键的类型

    textview.keyboardType = UIKeyboardTypeDefault;//键盘类型

    textview.textAlignment = NSTextAlignmentLeft; //文本显示的位置默认为居左

    textview.dataDetectorTypes = UIDataDetectorTypeAll; //显示数据类型的连接模式(如电话号码、网址、地址等)

    textview.textColor = [UIColor blackColor];

    textview.text = @"UITextView详解";//设置显示的文本内容

    [self.view addSubview:textview];


UITextView的代理方法如下:

//将要开始编辑

- (BOOL)textViewShouldBeginEditing:(UITextView *)textView;


//将要结束编辑

- (BOOL)textViewShouldEndEditing:(UITextView *)textView;


//开始编辑

- (void)textViewDidBeginEditing:(UITextView *)textView;


//结束编辑

- (void)textViewDidEndEditing:(UITextView *)textView;


//内容将要发生改变编辑

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


//内容发生改变编辑

- (void)textViewDidChange:(UITextView *)textView;


//焦点发生改变

- (void)textViewDidChangeSelection:(UITextView *)textView;


有时候我们要控件自适应输入的文本的内容的高度,只要在textViewDidChange的代理方法中加入调整控件大小的代理即可

 

 

- (void)textViewDidChange:(UITextView *)textView{

    //计算文本的高度

    CGSize constraintSize;

    constraintSize.width = textView.frame.size.width-16;

    constraintSize.height = MAXFLOAT;

    CGSize sizeFrame =[textView.text sizeWithFont:textView.font

                                constrainedToSize:constraintSize

                                    lineBreakMode:UILineBreakModeWordWrap];

    

 //重新调整textView的高度

    textView.frame = CGRectMake(textView.frame.origin.x,textView.frame.origin.y,textView.frame.size.width,sizeFrame.height+5);

}


 

控制输入文字的长度和内容,可通调用以下代理方法实现

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

{

    if (range.location>=100)

    {

        //控制输入文本的长度

        return  NO;

    }

    if ([text isEqualToString:@"\n"]) {

        //禁止输入换行

        return NO;

    }

    else

    {

        return YES;

    }

}


二、设置UITextView的行间距 & 行高等

1.如果只是静态显示textView的内容为设置的行间距,执行如下代码:

//    textview 改变字体的行间距 
    NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc] init]; 
    paragraphStyle.lineSpacing = 10;// 字体的行间距 
     
    NSDictionary *attributes = @{ 
                                 NSFontAttributeName:[UIFont systemFontOfSize:15], 
                                 NSParagraphStyleAttributeName:paragraphStyle 
                                 }; 
    textView.attributedText = [[NSAttributedString alloc] initWithString:@"输入你的内容" attributes:attributes];

 

2.如果是想在输入内容的时候就按照设置的行间距进行动态改变,那就需要将上面代码放到textView的delegate方法里

-(void)textViewDidChange:(UITextView *)textView

{

    //    textview 改变字体的行间距

    NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc] init];

    paragraphStyle.lineSpacing = 20;// 字体的行间距

    

    NSDictionary *attributes = @{

                                 NSFontAttributeName:[UIFont systemFontOfSize:15],

                                 NSParagraphStyleAttributeName:paragraphStyle

                                 };

    textView.attributedText = [[NSAttributedString alloc] initWithString:textView.text attributes:attributes];

 

}


3.关于行高和文本缩进、铺满的定制

使用NSAttributeString进行定制

具体方法如下: 

  1. NSMutableParagraphStyle *paragraphStyle = [[NSMutableParagraphStyle alloc]init];  
  2.     paragraphStyle.lineHeightMultiple = 20.f;  
  3.     paragraphStyle.maximumLineHeight = 25.f;  
  4.     paragraphStyle.minimumLineHeight = 15.f;  
  5.     paragraphStyle.firstLineHeadIndent = 20.f;  
  6. paragraphStyle.alignment = NSTextAlignmentJustified;  
  7.   
  8. NSDictionary *attributes = @{ NSFontAttributeName:[UIFont systemFontOfSize:14], NSParagraphStyleAttributeName:paragraphStyle, NSForegroundColorAttributeName:[UIColor colorWithRed:76./255. green:75./255. blue:71./255. alpha:1]  
  9.                                  };  
  10.  textView.attributedText = [[NSAttributedString alloc]initWithString:content attributes:attributes];  

 

当然也可以初始化一个NSMutableAttributedString,然后向里面添加文字样式,最后将它赋给textView的AttributedText即可 

  1. NSMutableAttributedString *atr = [[NSMutableAttributedString alloc]initWithString:detail];  
  2.     [atr addAttribute:NSFontAttributeName value:[UIFont systemFontOfSize:14] range:NSMakeRange(0, detail.length)];  
  3.     textView.attributedText = atr;  

 

另外,对于textview中的链接样式,同样也可以定制 

  1. NSDictionary *linkAttributes = @{NSForegroundColorAttributeName: [UIColor blueColor],  
  2.                                      NSUnderlineColorAttributeName: [UIColor blackColor],  
  3.                                      NSUnderlineStyleAttributeName: @(NSUnderlinePatternDash)};  
  4. self.linkTextAttributes = linkAttributes;  

三、设置UITextView的placeholder


UITextView上如何加上类似于UITextField的placeholder呢,其实在UITextView上加上一个UILabel或者UITextView,如果用UILable的话,会出现一个问题就是当placeholder的文字过长导致换行的时候就会出现问题,而用UITextView则可以有效避免此问题。

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

{    if (![text isEqualToString:@""])

        {

            _placeholderLabel.hidden = YES;

        }

     if ([text isEqualToString:@""] && range.location == 0 && range.length == 1)

        {

            _placeholderLabel.hidden = NO;

        }

    return YES;

}

 

说明如下:

  (1) _placeholderLabel 是加在UITextView后面的UITextView,_placeholderLabel要保证和真正的输入框的设置一样,字体设置成浅灰色,然后[_placeholderLabel setEditable:NO];真正的输入框要设置背景色透明,保证能看到底部的_placeholderLabel。

    (2) [text isEqualToString:@""] 表示输入的是退格键

    (3) range.location == 0 && range.length == 1 表示输入的是第一个字符














  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值