1,直接在<TextView>中设置

<TextView
        android:id="@+id/tv_badge_view_count"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@drawable/badge_view_layout_bg"
        android:gravity="center_vertical|center_horizontal"
        android:text="5"
        android:textColor="@android:color/white"
        android:textSize="12sp" />

2,在<TextView style="xxx">中用sytle属性引用其它样式

注意是  style 而不是 android:style

 <TextView
         android:id="@+id/tab_title"
         style="@style/TextViewStyle"
         android:textColor="#EEEE00"
          />

在style.xml中定义样式,好处是可以重用,上述代码就引用了TextViewStyle这个样式,并重载了其中的android:textColor,最终字的颜色为#EEEE00

   <style name="TextViewStyle" parent="android:Widget.TextView">
         <!-- <item name="android:background">#FF00FF</item> -->
         <!-- <item name="android:textStyle">bold</item> -->
         <item name="android:layout_width">match_parent</item>
         <item name="android:layout_height">wrap_content</item>
         <item name="android:textColor">#32CD32</item>
         <item name="android:textSize">14sp</item>
         <item name="android:gravity">center_horizontal</item>
         <item name="android:typeface">monospace</item>
         <item name="android:maxLines">1</item>
         <item name="android:ellipsize">end</item>
         <item name="android:maxLength">15</item>
     </style>

3,在代码中使用 SpannableString 格式化

 public class TextViewLinkActivity extends Activity {
     TextView mTextView = null;
     SpannableString msp = null;    

     @Override
     public void onCreate(Bundle savedInstanceState) {
         super.onCreate(savedInstanceState);
         setContentView(R.layout.main);  

         mTextView = (TextView)findViewById(R.id.myTextView);  

         //创建一个 SpannableString对象
         msp = new SpannableString("字体测试字体大小一半两倍前景色背景色正常粗体斜体粗斜体下划线删除线x1x2电话邮件网站短信彩信地图X轴综合");   

         //设置字体(default,default-bold,monospace,serif,sans-serif)
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  

         //设置字体大小(绝对值,单位:像素)
         msp.setSpan(), , , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
         msp.setSpan(,, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //第二个参数boolean dip,如果为true,表示前面的字体大小单位为dip,否则为像素,同上。  

         //设置字体大小(相对值,单位:像素) 参数表示为默认字体大小的多少倍
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //0.5f表示默认字体大小的一半
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //2.0f表示默认字体大小的两倍  

         //设置字体前景色
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置前景色为洋红色  

         //设置字体背景色
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //设置背景色为青色  

         //设置字体样式正常,粗体,斜体,粗斜体
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //正常
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗体
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //斜体
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  //粗斜体  

         //设置下划线
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  

         //设置删除线
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);  

         //设置上下标
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //下标
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);   //上标              

         //超级链接(需要添加setMovementMethod方法附加响应)
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //电话
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //邮件
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //网络
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //短信   使用sms:或者smsto:
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //彩信   使用mms:或者mmsto:
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);     //地图     

         //设置字体大小(相对值,单位:像素) 参数表示为默认字体宽度的多少倍
         msp.setSpan(, , Spanned.SPAN_EXCLUSIVE_EXCLUSIVE); //2.0f表示默认字体宽度的两倍,即X轴方向放大为默认字体的两倍,而高度不变
         //SpannableString对象设置给TextView
         myTextView.setText(sp);
         //设置TextView可点击
         myTextView.setMovementMethod(LinkMovementMethod.getInstance());
     }
 }

TextView设置样式的3种方式的更多相关文章

  1. WPF设置样式的几种方式

    第一种方式是直接使用Setter来进行,可以对Background等进行设置. <Window.Resources> <Style TargetType="Button&q ...

  2. 给TextView添加超链接的四种方式

    因为在上上篇博客中介绍了SpannableString的使用(SpannableString使用详解),由此想到给TextView添加超链接究竟有多少种方式?经过个人总结,现在一共发现四种,如果还有其 ...

  3. 原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  4. 【javascript】原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  5. javascript总结40:DOM中操作样式的两种方式

    1 DOM中操作样式的两种方式 1 通过元素的style属性 注意: 通过style属性设置样式时,css中要写单位的属性,在js代码中也要加单位 //html <div id="bo ...

  6. 我给女朋友讲编程CSS系列(1) –添加CSS样式的3种方式及样式表的优先权

    如果说,原生态就是美,那么,我们就没有必要穿衣打扮. 网页是什么? 说白了,网页就是一堆[html标签]有序的搭配,让[CSS属性值]整整容,请[Javascript语言]处理一下事件. 一个人的整容 ...

  7. 【iOS开发-72】设置状态栏的两种方式、程序生命周期以及更好地理解几大类(对象)之间的关系

    (1)设置状态栏的2种方式 --第一种方式就是我们在控制器中设置,系统默认就是交给视图控制器去管理的,这样不同视图控制器能够自己定义不同的状态栏例如以下: -(BOOL)prefersStatusBa ...

  8. HTML 引用Css样式的四种方式

    不才,只知道HTML引用CSS样式有四种方式,内部引用和外部引用各两种,因为老是忘记细节,记下了随时翻阅亦可方便如我般的初学者 内部引用方式1: 直接在标签内用 style 引用,如: <div ...

  9. python 中增加css样式的三种方式

    增加css样式的三种方式: <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...

随机推荐

  1. TweenMax动画库学习(四)

    目录            TweenMax动画库学习(一)            TweenMax动画库学习(二)            TweenMax动画库学习(三)            Tw ...

  2. 一句话解释jquery中offset、pageX, pageY、position、scrollTop, scrollLeft的区别

    offset   元素相对文档的偏移 pageX, pageY 事件(鼠标)相对文档的偏移 注意:文档是指document, 而不是当前窗口,是包含了滚动位置的,即滚动条的位置对这些值是不产生影响的 ...

  3. ES6学习笔记(九)

    1.概述 ES5的对象属性名都是字符串,这容易造成属性名的冲突.比如,你使用了一个他人提供的对象,但又想为这个对象添加新的方法(mixin模式),新方法的名字就有可能与现有方法产生冲突.如果有一种机制 ...

  4. json数据与字符串相互转化的例子

    json与字符串之间的转换,本文分享一个小例子.   json转成string[需要引用json2.js文件]:  var arr=[{id:'id',name:'Spring'},{id:'id2' ...

  5. 关于B/S系统在移动端应用的一些注意的地方(不断更新)

    1.不要直接把PC端的页面直接搬到移动端来用.这里举个例子:有个活动页面,在PC端和手机端的Safari里展现都好,但是当用手机APP(如手机淘宝)扫码打开后,却没法顺畅的异步获取到jsonp的信息. ...

  6. 使用JS来实现验证码功能

    最近想为自己的Django博客添加验证码功能,本来想使用第三方库来实现的,不过考虑到添加第三方库对性能的影响,以及第三方库是否安全可靠的问题,还是用自己的代码来实现吧.反正用JS来实现验证码功能又不是 ...

  7. PCB优化设计(转载)

    PCB优化设计(一) 2011-04-25 11:55:36|  分类: PCB设计   目 前SMT技术已经非常成熟,并在电子产品上广泛应用,因此,电子产品设计师有必要了解SMT技术的常识和可制造性 ...

  8. Python for 循环 失效

    昨天发现一个负责处理观察者模式的基类工作失败,默认的N个观察者负责处理 发送的一些东西, 其中提供一个内置接口移除观察者: def removeObserver(self, observer): if ...

  9. 【BZOJ 1009】 [HNOI2008]GT考试

    Description 阿申准备报名参加GT考试,准考证号为N位数X1X2....Xn(0<=Xi<=9),他不希望准考证号上出现不吉利的数字.他的不吉利数学A1A2...Am(0< ...

  10. H2嵌入式数据库的各种连接方式

    H2database是一款用java语言编写的开源数据库, 一般用作游戏的数据存储, 当然web项目也是可以用的, web项目也可以将该数据库 首先要安装H2数据库 http://www.h2data ...