zoukankan      html  css  js  c++  java
  • 如何在UIlabel显示图片、文字、修改文字颜色

    效果图:

    UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(10, 70, self.view.frame.size.width - 20, 20)];
        
        label.backgroundColor = [UIColor yellowColor];
        [self.view addSubview:label];
       
        NSString *str1 = @"不变色 ";
        NSString *str2 = @"变色内容";
       
        NSMutableAttributedString *string = [self setDoNotChangeTheContentTextString:str1 discolorationContentTextString:str2 changeWhatColour:[UIColor redColor] ImageViewString:@"call_inCall_ loudspeaker_select_icon"];
       
        [string appendAttributedString:[[NSMutableAttributedString alloc] initWithString:@"又可以拼接内容"]];
        
        label.attributedText = string;

    /**
     图片与已变色文字

     @param unchangingStr 不变色内容
     @param changeStr 变色内容
     @param color 变颜色
     @param imgString 图片string
     @return 返回 图片与已变色文字
     */

    - (NSMutableAttributedString *)setDoNotChangeTheContentTextString:(NSString *)unchangingStr discolorationContentTextString:(NSString *)changeStr changeWhatColour:(UIColor *)color ImageViewString:(NSString *)imgString{
        
        NSMutableAttributedString *str = [[NSMutableAttributedString alloc] initWithString:[NSString stringWithFormat:@"%@%@",unchangingStr,changeStr]];
        
        [str addAttribute:NSForegroundColorAttributeName value:color range:NSMakeRange(unchangingStr.length,changeStr.length)];
        
        
        NSMutableAttributedString *goalTipStr = [[NSMutableAttributedString alloc] initWithAttributedString:str];
        NSTextAttachment *alertImg = [[NSTextAttachment alloc]init];
        alertImg.image = [UIImage imageNamed:imgString];
        alertImg.bounds=CGRectMake(0, -3, 17, 17);
        NSAttributedString *imgStr = [NSAttributedString attributedStringWithAttachment:alertImg];
        [goalTipStr insertAttributedString:imgStr atIndex:0];
        
        return goalTipStr;
        
    }

  • 相关阅读:
    你知道吗,Flutter内置了10多种show
    强大的Flutter App升级功能
    Flutter 日期时间DatePicker控件及国际化
    你知道吗,Flutter内置了10多种Button控件
    Flutter Form表单控件超全总结
    Flutter 裁剪类组件 最全总结
    Flutter 拖拽控件Draggable看这一篇就够了
    Python 浮点数的冷知识
    Python 为了提升性能,竟运用了共享经济
    Python 之父的解析器系列之六:给 PEG 语法添加动作
  • 原文地址:https://www.cnblogs.com/Yishu/p/7490585.html
Copyright © 2011-2022 走看看