效果图如下:
关键代码如下:
StringBuffer sb = new StringBuffer(); if(day > 0) { sb.append("<a href=\"1\">"); sb.append(""+day); sb.append("</a>"); sb.append(""+Global.getString(R.string.unit_Day2)); } sb.append("<a href=\"2\">"); if(hour > 9) { sb.append(" "+hour); } else { sb.append(" 0"+hour); } sb.append("</a>"); sb.append(""+Global.getString(R.string.unit_Hour2)); sb.append("<a href=\"3\">"); if(minute > 9) { sb.append(" "+minute); } else { sb.append(" 0"+minute); } sb.append("</a>"); sb.append(""+Global.getString(R.string.unit_Minute2)); sb.append("<a href=\"4\">"); if(second > 9) { sb.append(" " + second); } else { sb.append(" 0" + second); } sb.append("</a>"); sb.append(""+Global.getString(R.string.unit_Second)); int end = sb.length(); SpannableString ss = new SpannableString(Html.fromHtml(sb.toString())); URLSpan[] urls = ss.getSpans(0, end, URLSpan.class); String resultStr = sb.toString(); Pattern p_html = Pattern.compile(REGEX_HTML, Pattern.CASE_INSENSITIVE); Matcher m_html = p_html.matcher(resultStr); resultStr = m_html.replaceAll(""); // 过滤html标签 SpannableString span = new SpannableString(resultStr); for (URLSpan url : urls) { int startIndex = ss.getSpanStart(url); int endIndex = ss.getSpanEnd(url); // 原字两倍大小 span.setSpan(new AbsoluteSizeSpan(Global.dpToPx(24)), startIndex, endIndex, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); // 设置样式2 span.setSpan(new ForegroundColorSpan(Color.WHITE), startIndex, endIndex, Spannable.SPAN_EXCLUSIVE_INCLUSIVE); // 设置样式3 span.setSpan(new StyleSpan(Typeface.BOLD), startIndex, endIndex, Spannable.SPAN_EXCLUSIVE_INCLUSIVE); } mBottomLL2_Detail.setText(span);
说明:
1.主要原理为使用SpannableString来做多样式的String给TextView显示
2.用到<a href>标签的原因是为了做到国际化,因为span是按照index来多样化的,所以需要用href来标识多样化的index