首页 > 代码库 > iOS微信朋友圈 评论点击姓名功能
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大小造成最后一行无法统计,将高度增加一部分,可以避免在计算点击的字符位置时造成最后一行遗漏。