• iOS微信朋友圈 评论点击姓名功能


    可以使用PPLabel来实现这个功能,下载代码https://github.com/petrpavlik/PPLabel。

    这个demo有两个小bug:

    1、如果最后一个单词后面没有空格字符,那么不能点击。

    修改办法:在ViewController中,有一个代理方法:

    - (void)highlightWordContainingCharacterAtIndex:(CFIndex)charIndex 

    将这个代理方法中的代码:

     if (end.location == NSNotFound) {

            end.location = string.length-1; //last word was selected

        }

    修改成:

     if (end.location == NSNotFound) {

            end.location = string.length//last word was selected

        }

     

    2、这个label中的最后一行无法点击

    修改办法:

    在PPlabel.m中,有以下代码:

    - (CGRect)textRect {

        CGRect textRect = [self textRectForBounds:self.bounds limitedToNumberOfLines:0];

        textRect.origin.y = (self.bounds.size.height - textRect.size.height)/2;

        if (self.textAlignment == NSTextAlignmentCenter) {

            textRect.origin.x = (self.bounds.size.width - textRect.size.width)/2;

        }

        if (self.textAlignment == NSTextAlignmentRight) {

            textRect.origin.x = self.bounds.size.width - textRect.size.width;

        }

        

        return textRect;

    }

    将其修改为:

    - (CGRect)textRect {

        CGRect textRect = [self textRectForBounds:self.bounds limitedToNumberOfLines:0];

        textRect.origin.y = (self.bounds.size.height - textRect.size.height)/2;

        textRect.size.height += 100;

        if (self.textAlignment == NSTextAlignmentCenter) {

            textRect.origin.x = (self.bounds.size.width - textRect.size.width)/2;

        }

        if (self.textAlignment == NSTextAlignmentRight) {

            textRect.origin.x = self.bounds.size.width - textRect.size.width;

        }

        

        return textRect;

    }

    为什么要+100?

    因为用CoreText在计算点击的字符位置时,textRect大小造成最后一行无法统计,将高度增加一部分,可以避免在计算点击的字符位置时造成最后一行遗漏。

  • 相关阅读:
    关于初入.NET的那些事
    有趣的接口和抽象类
    类型转换的那些趣事(is和as)
    【项目实践】SpringBoot三招组合拳,手把手教你打出优雅的后端接口
    【项目实践】一文带你搞定Session和JWT的登录认证方式
    【项目实践】后端接口统一规范的同时,如何优雅得扩展规范
    羊车门问题简析
    对于python这门课程的一些想法、计划、期望
    Android 4.1果冻豆新特性详解
    使用include实现布局(layout)复用
  • 原文地址:https://www.cnblogs.com/zengyanzhi/p/3862595.html
Copyright © 2020-2023  润新知