5

我使用以下代码筛选跨区字符串,将所有粗体文本保存为数组中的字符串:

StyleSpan[] spans = storyText.getSpans(0,
        storyText.length(), StyleSpan.class);
List<String> boldedWords = new ArrayList<String>();
for (StyleSpan span : spans) {
    if (span.getStyle() == Typeface.BOLD) {
        //start
        int s = storyText
                .getSpanStart(span);
        //end
        int e = storyText.getSpanEnd(span);
        boldedWords.add(storyText.subSequence(
                s, e).toString());
    }
}

String[] array = boldedWords
        .toArray(new String[boldedWords.size()]);

但是,我在数组中收到的字符串是乱序的。例如:

句子可能是(CAPS 表示粗体文本):

storyText = "This ADJECTIVE NOUN is VERB"

我要返回的数组将是:“名词、动词、形容词”按此顺序排列。应该是:“形容词、名词、动词”

关于为什么会发生这种情况的任何见解?

4

1 回答 1

3

用于int nextSpanTransition(int start, int limit, Class kind)迭代您的跨度。这样你就得到了阅读顺序。

于 2014-08-05T23:53:32.697 回答