我之前开发了一个 Android 应用程序,作为用户的参考指南。它使用 sqlite 数据库来存储信息。数据库存储不带格式的 UTF-8 文本(即粗体或下划线)
为了突出显示文本的哪些部分需要格式化,我使用分隔符标记(特别是 $$)将它们括起来,因为这不会作为信息出现在数据库中。在向用户显示文本之前,我编写了一个方法来查找这些分隔符并向其中包含的文本添加格式并删除分隔符。所以 $$foo$$ 变成了foo.
我的java代码如下:
private static CharSequence boldUnderlineText(CharSequence text, String token) {
int tokenLen = token.length();
int start = text.toString().indexOf(token) + tokenLen;
int end = text.toString().indexOf(token, start);
while (start > -1 && end > -1)
{
SpannableStringBuilder spannableStringBuilder = new SpannableStringBuilder(text);
//add the formatting required
spannableStringBuilder.setSpan(new UnderlineSpan(), start, end, 0);
spannableStringBuilder.setSpan(new StyleSpan(Typeface.BOLD), start, end, 0);
// Delete the tokens before and after the span
spannableStringBuilder.delete(end, end + tokenLen);
spannableStringBuilder.delete(start - tokenLen, start);
text = spannableStringBuilder;
start = text.toString().indexOf(token, end - tokenLen - tokenLen) + tokenLen;
end = text.toString().indexOf(token, start);
}
return text;
}
我已经在 Swift for iOS 中重新创建了我的应用程序,除了显示正确的格式之外,它是完整的。看来 Swift 处理字符串的方式与其他语言不同。
到目前为止,我已经尝试对原始未格式化段落使用 NSString 和 String 类型,并设法获取第一个分隔符的范围、开始和结束索引:
func applyFormatting2(noFormatString: NSString, delimiter: String){
let paragraphLength: Int = noFormatString.length //length of paragraph
let tokenLength: Int = delimiter.characters.count //length of token
let rangeOfToken = noFormatString.rangeOfString(formatToken) //range of the first delimiter
let startOfToken = rangeOfToken.toRange()?.startIndex //start index of first delimiter
let endOfToken = rangeOfToken.toRange()?.endIndex //end index of first delimiter
var startOfFormatting = endOfToken //where to start the edit (end index of first delimiter)
}
OR
func applyFormatting(noFormatString: String, token: String){
let paragraphLength: Int = noFormatString.characters.count
let tokenLength: Int = token.characters.count //length of the $$ Token (2)
let rangeOfToken = noFormatString.rangeOfString(formatToken) //The range of the first instance of $$ in the no format string
let startOfToken = rangeOfToken?.startIndex //the starting index of the found range for the found instance of $$
let endOfToken = rangeOfToken?.endIndex //the starting index of the found range for the found instance of $$
var startOfFormatting = endOfToken
}
我很欣赏这段代码冗长且具有毫无意义的变量,但它可以帮助我在解决问题时思考我的代码。
我目前正在努力研究如何找到第二个/结束分隔符。我想从特定索引搜索字符串,就像我在 Java 中使用该行所做的那样
int end = text.toString().indexOf(token, start);
但是我无法弄清楚如何使用范围来做到这一点。
谁能帮我解决如何正确识别结束分隔符的位置或如何完成代码块以格式化所有必需的文本?
Thanks
Aldo