iOS-YYText實現(xiàn)高亮效果

傳送門:YYKit

第一種方法

- (void)viewDidLoad {
    [super viewDidLoad];
    
    CGFloat WIDTH = [UIScreen mainScreen].bounds.size.width;
    NSString *str = @"Some Text, blabla...哈哈啊哈哈哈哈呵《我是協(xié)議》呵《我是協(xié)議》額呵呵呵呵好的好的好的好的好的好的好的";
    // 1. 創(chuàng)建一個"高亮"屬性,當(dāng)用戶點擊了高亮區(qū)域的文本時警检,"高亮"屬性會替換掉原本的屬性
    YYTextBorder *border = [YYTextBorder borderWithFillColor:[UIColor yellowColor] cornerRadius:3];
    
    YYTextHighlight *highlight = [YYTextHighlight highlightWithBackgroundColor:[UIColor redColor]];
    [highlight setColor:[UIColor greenColor]];
    [highlight setBackgroundBorder:border];
//    highlight.tapAction = ^(UIView *containerView, NSAttributedString *text, NSRange range, CGRect rect) {
//        NSLog(@"tap text range:...");
//        // 你也可以把事件回調(diào)放到 YYLabel 和 YYTextView 來處理甜害。
//    };
    // 1. 創(chuàng)建一個屬性文本
    NSMutableAttributedString *text = [[NSMutableAttributedString alloc] initWithString:str];
    text.yy_font = [UIFont boldSystemFontOfSize:30];
    text.yy_color = [UIColor blueColor];
    text.yy_lineSpacing = 10;
    NSString *highlightStr = @"《我是協(xié)議》";
    NSArray *array = [self rangeOfSubString:highlightStr inString:str];
    for (NSInteger i = 0; i < array.count; i++) {
        NSValue *value = array[i];
        // 2. 把"高亮"屬性設(shè)置到某個文本范圍
        [text yy_setTextHighlight:highlight range:value.rangeValue];
        [text yy_setColor:[UIColor redColor] range:value.rangeValue];
    }
    
    // 3. 賦值到 YYLabel 或 YYTextView
    YYLabel *label = [[YYLabel alloc] init];
    label.numberOfLines = 0;
    label.preferredMaxLayoutWidth = WIDTH-30;
    label.attributedText = text;
    [self.view addSubview:label];
    [label mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(15);
        make.right.mas_equalTo(-15);
        make.top.mas_equalTo(100);
    }];
    label.textTapAction = ^(UIView * _Nonnull containerView, NSAttributedString * _Nonnull text, NSRange range, CGRect rect) {
        NSLog(@"textTapAction");
    };
}
  • 注意:YYText用masonry布局要想自適應(yīng)高度就必須設(shè)置以下兩點
    label.numberOfLines = 0;
    label.preferredMaxLayoutWidth = WIDTH-30;

第二種方法

- (void)viewDidLoad {
    [super viewDidLoad];
    CGFloat WIDTH = [UIScreen mainScreen].bounds.size.width;
    
    NSString *str = @"Some Text, blabla...哈哈啊哈哈哈哈呵《我是協(xié)議》呵《我是協(xié)議》額呵呵呵呵好的好的好的好的好的好的好的";
    // 1. 創(chuàng)建一個屬性文本
    NSMutableAttributedString *text = [[NSMutableAttributedString alloc] initWithString:str];
    NSString *highlightStr = @"《我是協(xié)議》";
    NSArray *array = [self rangeOfSubString:highlightStr inString:str];
    // 2. 為文本設(shè)置屬性
    text.yy_font = [UIFont boldSystemFontOfSize:30];
    text.yy_color = [UIColor blueColor];
    text.yy_lineSpacing = 10;
    for (NSInteger i = 0; i < array.count; i++) {
        NSValue *value = array[i];
//        [text yy_setColor:[UIColor redColor] range:value.rangeValue];
        [text yy_setTextHighlightRange:value.rangeValue
                  color:[UIColor redColor]
        backgroundColor:[UIColor grayColor]
              tapAction:^(UIView *containerView, NSAttributedString *text, NSRange range, CGRect rect){
                  NSLog(@"tap text range:...");
        }];
    }
    // 3. 賦值到 YYLabel 或 YYTextView
    YYLabel *label = [[YYLabel alloc] init];
    label.numberOfLines = 0;
    label.preferredMaxLayoutWidth = WIDTH-30;
    label.attributedText = text;
    [self.view addSubview:label];
    [label mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(15);
        make.right.mas_equalTo(-15);
        make.top.mas_equalTo(100);
    }];
//    label.textTapAction = ^(UIView * _Nonnull containerView, NSAttributedString * _Nonnull text, NSRange range, CGRect rect) {
//     NSLog(@"點擊了");
//     };
    
}
  • 獲取一個字符在字符串中出現(xiàn)的所有位置 返回一個被NSValue包裝的NSRange數(shù)組
//獲取一個字符在字符串中出現(xiàn)的所有位置 返回一個被NSValue包裝的NSRange數(shù)組
- (NSArray *)rangeOfSubString:(NSString *)subStr inString:(NSString *)string {
    if (subStr == nil && [subStr isEqualToString:@""]) {
        return nil;
    }
    NSMutableArray *rangeArray = [NSMutableArray array];
    NSString *string1 = [string stringByAppendingString:subStr];
    NSString *temp;
    for (int i = 0; i < string.length; i ++) {
        temp = [string1 substringWithRange:NSMakeRange(i, subStr.length)];
        if ([temp isEqualToString:subStr]) {
            NSRange range = {i,subStr.length};
            [rangeArray addObject:[NSValue valueWithRange:range]];
        }
    }
    return rangeArray;
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末七咧,一起剝皮案震驚了整個濱河市注祖,隨后出現(xiàn)的幾起案子品嚣,更是在濱河造成了極大的恐慌磁浇,老刑警劉巖送滞,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件侠草,死亡現(xiàn)場離奇詭異,居然都是意外死亡犁嗅,警方通過查閱死者的電腦和手機边涕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人功蜓,你說我怎么就攤上這事园爷。” “怎么了式撼?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵童社,是天一觀的道長。 經(jīng)常有香客問我著隆,道長扰楼,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任美浦,我火速辦了婚禮弦赖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘抵代。我一直安慰自己腾节,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布荤牍。 她就那樣靜靜地躺著,像睡著了一般庆冕。 火紅的嫁衣襯著肌膚如雪康吵。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天访递,我揣著相機與錄音晦嵌,去河邊找鬼。 笑死拷姿,一個胖子當(dāng)著我的面吹牛惭载,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播响巢,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼描滔,長吁一口氣:“原來是場噩夢啊……” “哼蚊俺!你這毒婦竟也來了蠢络?” 一聲冷哼從身側(cè)響起溪烤,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤悠咱,失蹤者是張志新(化名)和其女友劉穎拷呆,沒想到半個月后耻卡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體舷胜,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡叁扫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年枕扫,在試婚紗的時候發(fā)現(xiàn)自己被綠了陪腌。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖诗鸭,靈堂內(nèi)的尸體忽然破棺而出商叹,到底是詐尸還是另有隱情,我是刑警寧澤只泼,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布剖笙,位于F島的核電站,受9級特大地震影響请唱,放射性物質(zhì)發(fā)生泄漏弥咪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一十绑、第九天 我趴在偏房一處隱蔽的房頂上張望聚至。 院中可真熱鬧,春花似錦本橙、人聲如沸扳躬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贷币。三九已至,卻和暖如春亏狰,著一層夾襖步出監(jiān)牢的瞬間役纹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工暇唾, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留促脉,地道東北人。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓策州,卻偏偏與公主長得像瘸味,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子够挂,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348