设置textview部分字体样式

一般在一个TextView中的字体颜色,效果都是统一的。

如果一段文字,前几个文字要显示高亮,中间部分一个超链接,后半部分自定义颜色。

简单点可能直接用3个textView来表示了。

因为上次做一个彩票的软件,对于双色球来说,大家都知道。

双色,那就有两种颜色。


很显然,这个效果,最后需要在一个TextView中完成。(当然也可以2个,红色和蓝色分开)。

然后我们第一反应是想到一个SpannableString这个类。

以下是网上copy过来一段代码:

[java]
  1. //创建一个 SpannableString对象     
  2.       SpannableString sp = new SpannableString("这句话中有百度超链接,有高亮显示,这样,或者这样,还有斜体.");    
  3.       //设置超链接     
  4.       sp.setSpan(new URLSpan("http://www.baidu.com"), 57,    
  5.               Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  6.       //设置高亮样式一     
  7.       sp.setSpan(new BackgroundColorSpan(Color.RED), 17 ,19,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);    
  8.       //设置高亮样式二     
  9.       sp.setSpan(new ForegroundColorSpan(Color.YELLOW),20,24,Spannable.SPAN_EXCLUSIVE_INCLUSIVE);      
  10.       //设置斜体     
  11.       sp.setSpan(new StyleSpan(Android.graphics.Typeface.BOLD_ITALIC), 2729, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);    
  12.       //SpannableString对象设置给TextView     
  13.       myTextView.setText(sp);    
  14.       //设置TextView可点击     
  15.       myTextView.setClickable(true);  
  16.       myTextView.setMovementMethod(LinkMovementMethod.getInstance());    

恩。一个不错的解决方式。

但是后来发现一个问题。

在对于SpannableString对象做整体操作时,我们对于里面的要设置的部分文字都是以截取方式,因此,也就是我们在构造这个

对象然后操作时,对于构造进去的String内容都是事先知道了。
那我这个开奖号码:双色球是7个数字,其他的就不一定了。而且还有一个问题,文字中我是带有空格的,
这使得在setxx对于索引起始位置定位比较困难。

后面了解了一个新方式:Html.fromHtml();
直接把文字组装成html文本。
代码:
[java]
  1.               String redNums = nums[0].replace(","" ");  
  2. String blueNums = nums[1].replace(","" ");  
  3. StringBuilder  sb = new StringBuilder();  
  4. sb.append("</font>");  
  5. sb.append("<font color='#ff00ff'>");  
  6. sb.append(redNums);  
  7. sb.append("</font>");  
  8. sb.append(" ");  
  9. sb.append("</font>");  
  10. sb.append("<font color='#0000cc'>");  
  11. sb.append(blueNums);  
  12. sb.append(" ");  
  13. sb.append("</font>");  
  14. Spanned spanned = Html.fromHtml(sb.toString());  
  15. preNumView.setText(spanned);  
效果就是上图那样的显示。

当然最后发现其实用SpannableString也能实现:
我构造两个SpannableString,一个红球,一个篮球的。
然后StringBuider组装下。适合在构造的SpannableString不是太多的情况下挺好的。

Html.fromHtml()这个api适合搞过网页开发的用户。本人没做过前端。对于几个标签都不是很熟悉。
而且适合设置大篇幅的版面文字,图片等资源。



在Android中,TextView是我们最常用的用来显示文本的控件。

  一般情况下,TextView中的文本都是一个样式。那么如何对于TextView中各个部分的文本来设置字体,大小,颜色,样式,以及超级链接等属性呢?下面我们通过SpannableString的具体实例操作来演示一下。


[java]  view plain copy
  1. //创建一个 SpannableString对象      
  2. SpannableString msp = new SpannableString("字体测试字体大小一半两倍前景色背景色正常粗体斜体粗斜体下划线删除线x1x2电话邮件网站短信彩信地图X轴综合");     
  3.           
  4.       //设置字体(default,default-bold,monospace,serif,sans-serif)    
  5.       msp.setSpan(new TypefaceSpan("monospace"), 02, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  6.       msp.setSpan(new TypefaceSpan("serif"), 24, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  7.           
  8.       //设置字体大小(绝对值,单位:像素)     
  9.       msp.setSpan(new AbsoluteSizeSpan(20), 46, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  10.       msp.setSpan(new AbsoluteSizeSpan(20,true), 68, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //第二个参数boolean dip,如果为true,表示前面的字体大小单位为dip,否则为像素,同上。    
  11.           
  12.       //设置字体大小(相对值,单位:像素) 参数表示为默认字体大小的多少倍    
  13.       msp.setSpan(new RelativeSizeSpan(0.5f), 810, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //0.5f表示默认字体大小的一半    
  14.       msp.setSpan(new RelativeSizeSpan(2.0f), 1012, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //2.0f表示默认字体大小的两倍    
  15.           
  16.       //设置字体前景色    
  17.       msp.setSpan(new ForegroundColorSpan(Color.MAGENTA), 1215, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置前景色为洋红色    
  18.           
  19.       //设置字体背景色    
  20.       msp.setSpan(new BackgroundColorSpan(Color.CYAN), 1518, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置背景色为青色    
  21.        
  22.       //设置字体样式正常,粗体,斜体,粗斜体    
  23.       msp.setSpan(new StyleSpan(android.graphics.Typeface.NORMAL), 1820, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //正常    
  24.       msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD), 2022, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗体    
  25.       msp.setSpan(new StyleSpan(android.graphics.Typeface.ITALIC), 2224, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //斜体    
  26.       msp.setSpan(new StyleSpan(android.graphics.Typeface.BOLD_ITALIC), 2427, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗斜体    
  27.           
  28.       //设置下划线    
  29.       msp.setSpan(new UnderlineSpan(), 2730, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  30.           
  31.       //设置删除线    
  32.       msp.setSpan(new StrikethroughSpan(), 3033, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);    
  33.           
  34.       //设置上下标    
  35.       msp.setSpan(new SubscriptSpan(), 3435, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //下标       
  36.       msp.setSpan(new SuperscriptSpan(), 3637, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);   //上标                
  37.           
  38.       //超级链接(需要添加setMovementMethod方法附加响应)    
  39.       msp.setSpan(new URLSpan("tel:4155551212"), 3739, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //电话       
  40.       msp.setSpan(new URLSpan("mailto:webmaster@google.com"), 3941, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //邮件       
  41.       msp.setSpan(new URLSpan("http://www.baidu.com"), 4143, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //网络       
  42.       msp.setSpan(new URLSpan("sms:4155551212"), 4345, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //短信   使用sms:或者smsto:    
  43.       msp.setSpan(new URLSpan("mms:4155551212"), 4547, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //彩信   使用mms:或者mmsto:    
  44.       msp.setSpan(new URLSpan("geo:38.899533,-77.036476"), 4749, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //地图       
  45.           
  46.       //设置字体大小(相对值,单位:像素) 参数表示为默认字体宽度的多少倍    
  47.       msp.setSpan(new ScaleXSpan(2.0f), 4951, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //2.0f表示默认字体宽度的两倍,即X轴方向放大为默认字体的两倍,而高度不变    
  48.             
  49.       //设置项目符号    
  50.       msp.setSpan(new BulletSpan(android.text.style.BulletSpan.STANDARD_GAP_WIDTH,Color.GREEN), 0 ,53, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //第一个参数表示项目符号占用的宽度,第二个参数为项目符号的颜色    
  51.       tv_textView.setText(msp);    
  52.       tv_textView.setMovementMethod(LinkMovementMethod.getInstance());    

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值