UITextView的一些知识

今天朋友问了一个关于textview的问题,我下午也用到了textview,接触的比较多,突然就萌生了写一下的想法,哈哈,第一次写,终于要跨出这一步了.
1.朋友给我发的图,输入文本居中,而不是从最上方开始?
如下图:textview输入
如果你查看一下UITextView的定义,你就会看到这样一行代码

NS_CLASS_AVAILABLE_IOS(2_0) @interface UITextView : UIScrollView <UITextInput>

由于textview是继承scrollview的,而iOS7增加了一个属性automaticallyAdjustsScrollViewInsets,会自动下压一个导航条的高度,所以我们需判断一下iOS版本并设置一下这个属性为NO不让它自动布局,添加以下代码

    if ([[[UIDevice currentDevice]systemVersion]floatValue] >= 7.0) {
        self.automaticallyAdjustsScrollViewInsets = NO;
    }

2.placeholder水印占位字
当然textview是没有的,但可以通过代码实现大致效果,需要在textview的代理方法中实现

#pragma mark --textView delegate

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

    if ([textView.text isEqualToString:@"请在这里写"]) {
        textView.text = nil;
        textView.textColor = [UIColor lightGrayColor];
    }
}
-(void)textViewDidEndEditing:(UITextView *)textView{

    if ([textView.text isEqualToString:@""]) {
        textView.text = @"请在这里写";
        textView.textColor = [UIColor lightGrayColor];
        return;
    }
    //保存,写在这里
    _textStr = textView.text;
}

3.字数限制,也是代理方法

//宏定义最大字数
#define kWordLimit 200
-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text{
    NSString * str = textView.text;
/*  
//这段可写可不写,以给用户提示下 
 if (str.length == kWordLimit) {
        [SVProgressHUD showInfoWithStatus:@"亲,您已经写200字了哟!"];
    }
    */
    //根据字符串长度判断
    if (str.length > kWordLimit) {
    //字符串截取方法,用户输入字数达到限制后,无法再往里添加    
        textView.text = [textView.text substringToIndex:kWordLimit];

        return NO;
    }
    return YES;
}
//这里主要是处理联想字
-(void)textViewDidChange:(UITextView *)textView{
    if (textView.text.length > kWordLimit) {
        textView.text = [textView.text substringToIndex:kWordLimit];
    }
}

4.边框
textview默认是没有边框的颜色的,所以位置不明显,看着很别扭,我们一般都要设置一下,设置边框我常用的有两种方法:
一 是 使用layer的属性 二 是放张背景图
这两种方法,可以直接写在textview所在viewcontroller中,也可以自定义一个继承于UITextView的子类,在drawRect方法中实现,(代码类似,不分开写了)如下

- (void)drawRect:(CGRect)rect {
  //方法一   图片  
    [[UIImage imageNamed:@"check"] drawInRect:rect blendMode:kCGBlendModeNormal alpha:0.8];
    //方法二   layer
    self.layer.borderColor = [UIColor yellowColor].CGColor;//边框颜色
    self.layer.borderWidth = 1;//边框宽度(别忘记宽度呀,不设置显示不出来的)
    //如需要也可以设置圆角矩形
    self.layer.cornerRadius = 10;
    self.layer.masksToBounds = YES;

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UITextView是UIKit框架中的一个控件,可以用来显示和编辑长文本。而富文本则是指带有丰富样式的文本,可以设置文字的字体、颜色、大小、间距、行高等属性。 要在UITextView中实现富文本,首先需要创建一个NSAttributedString对象,并通过NSMutableAttributedString来设置文字的样式。NSAttributedString是不可变的,而NSMutableAttributedString可以修改和添加样式。 创建NSMutableAttributedString对象后,可以使用其方法来设置文字的样式,比如设置字体可以使用NSFontAttributeName属性,设置颜色可以使用NSForegroundColorAttributeName属性,设置字号可以使用NSFontAttributeName属性,设置段落样式可以使用NSParagraphStyleAttributeName属性等等。 设置完成后,就可以将NSMutableAttributedString对象赋值给UITextView的attributedText属性,以实现富文本的显示。 例如,我们想将某个UITextView的文字样式设置为红色、字号为20、字体为粗体,可以按如下方式设置: ``` NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:@"这是富文本"]; [attributedString addAttribute:NSForegroundColorAttributeName value:[UIColor redColor] range:NSMakeRange(0, attributedString.length)]; [attributedString addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:20] range:NSMakeRange(0, attributedString.length)]; textView.attributedText = attributedString; ``` 通过上述代码,就可以在UITextView中显示带有红色、字号为20、字体为粗体的文字。 除了以上示例外,UITextView还支持更多的富文本样式设置,根据具体需求,可以设置更多的属性来实现更丰富的文本效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值