欢迎访问移动开发之家(rcyd.net),关注移动开发教程。移动开发之家  移动开发问答|  每日更新
页面位置 : > > 内容正文

android textview 中url识别,androidtextview

来源: 开发者 投稿于  被查看 36531 次 评论:270

android textview 中url识别,androidtextview


android5.0+中对textview中的url识别可能不会是自己想要的结果。例如它会将1.###识别为url。可能它的本意是对baidu.com支持,导致一些我们不能接受的结果。
没有好的办法,只能自己处理了。
首先检索出textview内容中的url:
public List<String> getUrlsInContent(String content){
List<String> termList = new ArrayList<String>();

String patternString = "[http|https]+[://]+[0-9A-Za-z:/[-]_#[?][=][.][&][%]]*";
Pattern pattern = Pattern.compile(patternString);

Matcher matcher = pattern.matcher(content);

while(matcher.find()){
termList.add(matcher.group());
}

for(String temp:termList){
Log.i("", temp);
}

return termList;
}


然后将内容中的这些字符串处理为超链接:
TextView note_item_content = (TextView) parentView
.findViewById(R.id.note_item_content);

String content = tempStruct.getContent();
if (content.equals("")) {
parentView.removeView(note_item_content);
} else {

SpannableString ss = new SpannableString(content);
List<String> tempL = Utilities.getInstance().getUrlsInContent(content);
if(tempL != null){
for(String temp : tempL){
int index = content.indexOf(temp);
ss.setSpan(new URLSpan(temp), index, index+temp.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
}
}

note_item_content.setText(ss);
note_item_content.setMovementMethod(LinkMovementMethod.getInstance());


CharSequence text = note_item_content.getText();
if (text instanceof Spannable) {
int end = text.length();
Spannable sp = (Spannable) note_item_content.getText();
URLSpan[] urls = sp.getSpans(0, end, URLSpan.class);
SpannableStringBuilder style = new SpannableStringBuilder(text);
style.clearSpans();// should clear old spans


// 循环把链接发过去
for (URLSpan url : urls) {
MyURLSpan myURLSpan = new MyURLSpan(url.getURL(), myHandler);
style.setSpan(myURLSpan, sp.getSpanStart(url),
sp.getSpanEnd(url), Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
}
note_item_content.setText(style);
}
}


这里有个瑕疵:我只对首个匹配的url做了处理,如果内容里面有多个相同的url,后面的并没有做特殊处理.

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关频道:

用户评论