android TextView中識別多個url并分別點擊跳轉(zhuǎn)方法詳解
更新時間:2019年08月26日 15:25:31 作者:煢&煢
在本篇文章里小編給大家整理的是關于android TextView中識別多個url并分別點擊跳轉(zhuǎn)方法詳解,需要的朋友們可以學習參考下。
實現(xiàn)方案:
我們直接參考實例代碼:
private String pattern = "((http|ftp|https)://)(([a-zA-Z0-9\\._-]+\\.[a-zA-Z]{2,6})|([0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}))(:[0-9]{1,4})*(/[a-zA-Z0-9\\&%_\\./-~-]*)?|(([a-zA-Z0-9\\._-]+\\.[a-zA-Z]{2,6})|([0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}))(:[0-9]{1,4})*(/[a-zA-Z0-9\\&%_\\./-~-]*)?"; Pattern r = Pattern.compile(pattern); Matcher m; mTv.setText(identifyUrl(richURL.msg)); public SpannableStringBuilderForAllvers identifyUrl(CharSequence text) { CharSequence contextText; CharSequence clickText; text = text == null ? "" : text; //以下用于拼接本來存在的spanText SpannableStringBuilderForAllvers span = new SpannableStringBuilderForAllvers(text); ClickableSpan[] clickableSpans = span.getSpans(0, text.length(), ClickableSpan.class); if (clickableSpans.length > 0) { int start = 0; int end = 0; for (int i = 0; i < clickableSpans.length; i++) { start = span.getSpanStart(clickableSpans[0]); end = span.getSpanEnd(clickableSpans[i]); } //可點擊文本后面的內(nèi)容頁 contextText = text.subSequence(end, text.length()); //可點擊文本 clickText = text.subSequence(start, end); } else { contextText = text; clickText = null; } m = r.matcher(contextText); //匹配成功 while (m.find()) { //得到網(wǎng)址數(shù)m.group() if (m.start() < m.end()) { span.setSpan(new LinkClickSpan(m.group(), m.group(), mUrlSpanClickListener), m.start(), m.end(), Spanned.SPAN_INCLUSIVE_EXCLUSIVE); } } return span; } private static final String HTTPS = "https://"; private static final String HTTP = "http://"; private static final String FTP = "ftp://"; public static boolean hasNetUrlHead(String url) { return (!TextUtils.isEmpty(url)) && (url.startsWith(HTTP) || url.startsWith(HTTPS) || url.startsWith(FTP)); } private UrlSpanClickListener mUrlSpanClickListener = new UrlSpanClickListener() { @Override public void onClick(View view, String url, String content) { if (TextUtils.isEmpty(url)) { return; } Matcher url_matcher = Patterns.WEB_URL.matcher(url); if (url_matcher.matches()) { String tempUrl; if (hasNetUrlHead(url)) { tempUrl = url; } else { tempUrl = HTTPS + url; } //通過webview打開相應的url //Bundle bundle = new Bundle(); //bundle.putString(WebCordovaBaseFragment.EXTRA_URL, tempUrl); //bundle.putBoolean(WebCordovaBaseFragment.ENABLE_WEB_TITLE, true); //WebViewActivity.presentWeb(Utilities.getApplicationContext(), WebViewActivity.class, WebCommonFragment.class, content, bundle); } } }; public interface UrlSpanClickListener { void onClick(View view, String url, String content); } public static class LinkClickSpan extends ClickableSpan { private int mColor = Utilities.getApplicationContext().getResources().getColor(R.color.yc_color_007AFF_CBN); private String mUrl; private String mContent; UrlSpanClickListener mClickListener; public LinkClickSpan(String url, String content, UrlSpanClickListener onClickListener) { super(); mUrl = url; mContent = content; mClickListener = onClickListener; } @Override public void updateDrawState(TextPaint ds) { ds.setColor(mColor); ds.linkColor = mColor; ds.setUnderlineText(true);//設置是否下劃線 ds.clearShadowLayer(); } @Override public void onClick(View widget) { if (mClickListener != null) { mClickListener.onClick(widget, mUrl, mContent); } } } public class SpannableStringBuilderForAllvers extends SpannableStringBuilder{ public SpannableStringBuilderForAllvers() { super(""); } public SpannableStringBuilderForAllvers(CharSequence text) { super(text, 0, text.length()); } public SpannableStringBuilderForAllvers(CharSequence text, int start, int end){ super(text,start,end); } @Override public SpannableStringBuilder append(CharSequence text) { if (text == null) { return this; } int length = length(); return (SpannableStringBuilderForAllvers)replace(length, length, text, 0, text.length()); } /**該方法在原API里面只支持API21或者以上,這里適應低版本*/ public SpannableStringBuilderForAllvers append(CharSequence text, Object what, int flags) { if (text == null) { return this; } int start = length(); append(text); setSpan(what, start, length(), flags); return this; } } public class ClickableSpanTextView extends AppCompatTextView { private BackgroundColorSpan backgroundColorSpan; private boolean hasSpan; public ClickableSpanTextView(Context context) { super(context); init(); } public ClickableSpanTextView(Context context, AttributeSet attrs) { super(context, attrs); init(); } public ClickableSpanTextView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(); } private void init() { setMovementMethod(LinkMovementMethod.getInstance()); backgroundColorSpan = new BackgroundColorSpan(getContext().getResources().getColor(R.color.yc_color_4B4B4B_CDG)); } @Override public boolean onTouchEvent(MotionEvent event) { boolean handled = super.onTouchEvent(event); int action = event.getAction(); if (!(getText() instanceof Spannable)) { return handled; } Spannable spannable = (Spannable) getText(); if (action == MotionEvent.ACTION_UP || action == MotionEvent.ACTION_DOWN) { int x = (int) event.getX(); int y = (int) event.getY(); x -= getTotalPaddingLeft(); y -= getTotalPaddingTop(); x += getScrollX(); y += getScrollY(); Layout layout = getLayout(); int line = layout.getLineForVertical(y); int off = layout.getOffsetForHorizontal(line, x); if (off >= getText().length()) { int off1 = layout.getOffsetForHorizontal(line, x - getTextSize()); if (off == off1) { return handled; } } ClickableSpan[] links = spannable.getSpans(off, off, ClickableSpan.class); if (links.length > 0) { ClickableSpan clickableSpan = links[0]; int start = spannable.getSpanStart(clickableSpan); int end = spannable.getSpanEnd(clickableSpan); if (action == MotionEvent.ACTION_DOWN && !hasSpan) { spannable.setSpan(backgroundColorSpan, start, end, Spanned.SPAN_INCLUSIVE_INCLUSIVE); hasSpan = true; } else if (hasSpan) { spannable.removeSpan(backgroundColorSpan); hasSpan = false; } } return links.length != 0; } else { if (hasSpan && action != MotionEvent.ACTION_MOVE) { spannable.removeSpan(backgroundColorSpan); hasSpan = false; } } return handled; } }
以上實例代碼大家可以測試下,感謝大家的學習和對腳本之家的支持。
您可能感興趣的文章:
- Android文本視圖TextView實現(xiàn)跑馬燈效果
- Android文本視圖TextView實現(xiàn)聊天室效果
- Android使用TypeFace設置TextView的文字字體
- Flutter中嵌入Android 原生TextView實例教程
- android使用TextView實現(xiàn)跑馬燈效果
- Android開發(fā)實現(xiàn)TextView超鏈接5種方式源碼實例
- Android開發(fā)中TextView各種常見使用方法小結(jié)
- Android開發(fā)之TextView使用intent傳遞信息,實現(xiàn)注冊界面功能示例
- Android使用AutoCompleteTextView實現(xiàn)自動填充功能的案例
- Android為textView設置setText的時候報錯的講解方案
- 詳解Android TextView屬性ellipsize多行失效的解決思路
- 在Android TextView中顯示圖片的4種方式詳解
- Android實現(xiàn)梯形TextView效果
相關文章
Android如何實現(xiàn)一個DocumentProvider示例詳解
這篇文章主要為大家介紹了Android如何實現(xiàn)一個DocumentProvider示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12Handler實現(xiàn)線程之間的通信下載文件動態(tài)更新進度條
每一個線程對應一個消息隊列MessageQueue,實現(xiàn)線程之間的通信,可通過Handler對象將數(shù)據(jù)裝進Message中,再將消息加入消息隊列,而后線程會依次處理消息隊列中的消息。這篇文章主要介紹了Handler實現(xiàn)線程之間的通信下載文件動態(tài)更新進度條,需要的朋友可以參考下2017-08-08Android開發(fā)基于ScrollView實現(xiàn)的漸變導航欄效果示例
這篇文章主要介紹了Android開發(fā)基于ScrollView實現(xiàn)的漸變導航欄效果,涉及ScrollView事件響應及元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下2017-12-12Android ActionBar完全解析使用官方推薦的最佳導航欄(上)
Action Bar是一種新増的導航欄功能,在Android 3.0之后加入到系統(tǒng)的API當中,它標識了用戶當前操作界面的位置,并提供了額外的用戶動作、界面導航等功能2017-04-04Android開發(fā)之無痕過渡下拉刷新控件的實現(xiàn)思路詳解
下拉刷新效果功能在程序開發(fā)中經(jīng)常會見到,今天小編抽時間給大家分享Android開發(fā)之無痕過渡下拉刷新控件的實現(xiàn)思路詳解,需要的朋友參考下吧2016-11-11Android中 TeaScreenPopupWindow多類型篩選彈框功能的實例代碼
這篇文章主要介紹了Android TeaScreenPopupWindow多類型篩選彈框功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下2019-06-06